@charset "UTF-8";
:root {
    --color-principal: #00b6e4;
    --color-secundario: #343d46
}

html {
    font: 400 1rem/1.15 "Cabin", -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    scroll-behavior: smooth!important
}

*,
*:focus,
*:hover {
    outline: 0
}

i {
    vertical-align: bottom
}

body {
    margin: 0;
    color: rgba(68, 68, 68, 0.659);
    text-align: left;
    user-select: none;
    overflow-x: hidden
}

footer {
    display: block
}

b,
.b {
    font-weight: 700
}

footer {
    margin-top: auto
}

a {
    background-color: transparent;
    text-decoration: none;
    color: inherit;
    cursor: pointer
}

b {
    font-weight: bolder
}

img {
    border-style: none
}

button {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button {
    overflow: visible
}

button {
    text-transform: none
}

button {
    -webkit-appearance: button
}

button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring {
    outline: 1px dotted
}

[hidden] {
    display: none
}

*,
*::before,
*::after {
    box-sizing: border-box
}

button {
    background-color: transparent;
    color: inherit;
    border-width: 0;
    padding: 0;
    cursor: pointer
}

h2 {
    margin: 0;
    font-weight: inherit
}

.grilla-magica {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 25rem), 1fr))
}

.texto-blanco {
    color: #fff
}

@media (max-width:500px) {
    .contenedor {
        width: 100%!important
    }
}

.contenedor {
    width: 90%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 10px;
    padding-right: 10px
}

.oculto-movil {
    display: none
}

.oculto-movil-footer {
    display: none
}

.line-in-middle {
    background: rgba(255, 255, 255, 0);
    background: linear-gradient(90deg, var(--color-principal) 50%, rgba(255, 255, 255, 0) 49.9999999999%)
}

@media (min-width:500px) {
    .line-in-middle {
        background: rgba(255, 255, 255, 0);
        background: linear-gradient(90deg, rgba(255, 255, 255, 0) 29.9999999999%, var(--color-principal) 30%, var(--color-principal) 69.9999999999%, rgba(255, 255, 255, 0) 70%)
    }
}

@media (min-width:1080px) {
    .line-in-middle {
        background: rgba(255, 255, 255, 0);
        background: linear-gradient(90deg, rgba(255, 255, 255, 0) 39.9999999999%, var(--color-principal) 40%, var(--color-principal) 59.9999999999%, rgba(255, 255, 255, 0) 60%)
    }
}

.mostrar-movil-footer {
    display: block
}

@media (min-width:768px) {
    .oculto-movil-footer {
        display: block
    }
    .mostrar-movil-footer {
        display: none
    }
}

@media (min-width:500px) {
    .oculto-movil {
        display: block
    }
    .mostrar-movil {
        display: none
    }
}

.caja-flexible {
    display: flex
}

.caja-flexible-movil {
    display: flex
}

@media (max-width:768px) {
    .caja-flexible-movil {
        display: block
    }
}

.flexible {
    flex-grow: 1
}

.margen-arriba-0 {
    margin-top: 0
}

.margen-arriba-05 {
    margin-top: 0.5em
}

.margen-arriba-1 {
    margin-top: 1em
}

.margen-arriba-2 {
    margin-top: 2em
}

.margen-arriba-3 {
    margin-top: 3em
}

.margen-abajo-0 {
    margin-bottom: 0
}

.margen-abajo-05 {
    margin-bottom: 0.5em
}

.margen-abajo-1 {
    margin-bottom: 1em
}

.margen-abajo-2 {
    margin-bottom: 2em
}

.margen-final-05 {
    margin-right: .5em
}

.margen-final-1 {
    margin-right: 1em
}

.relleno-arriba-6 {
    padding-top: 6em
}

.relleno-abajo-6 {
    padding-bottom: 6em
}

.margen-y-05 {
    margin-top: .5em;
    margin-bottom: .5em
}

.margen-y-1 {
    margin-top: 1em;
    margin-bottom: 1em
}

.margen-y-2 {
    margin-top: 2em;
    margin-bottom: 2em
}

.margen-y-3 {
    margin-top: 3em;
    margin-bottom: 3em
}

.relleno-2 {
    padding: 2em
}

.relleno-y-1 {
    padding-top: 1em;
    padding-bottom: 1em
}

.relleno-y-2 {
    padding-top: 2em;
    padding-bottom: 2em
}

.relleno-y-3 {
    padding-top: 3em;
    padding-bottom: 3em
}

.relleno-y-6 {
    padding-top: 6em;
    padding-bottom: 6em
}

.relleno-y-10 {
    padding-top: 10em;
    padding-bottom: 10em
}

.fuente-s {
    font-size: 0.9rem;
    line-height: 131%
}

.fuente-l {
    font-size: 1.25rem;
    line-height: 138%
}

.fuente-xl {
    font-size: 1.5rem
}

.centrado {
    display: flex;
    justify-content: center;
    align-items: center
}

.alineado {
    display: flex;
    align-items: center
}

.alineado-final {
    display: flex;
    justify-content: flex-end!important;
    align-items: center
}

.texto-centro {
    text-align: center;
    margin-left: auto;
    margin-right: auto
}

.fondo-color-secundario {
    background-color: var(--color-secundario)
}

.texto-principal {
    color: var(--color-principal)
}

.texto-negro {
    color: #000
}

.boton-principal-lineal {
    border: 1px solid var(--color-principal);
    background-color: transparent;
    color: var(--color-principal);
    border-radius: 3em;
    padding: 0.5em;
    text-align: center;
    font-size: 1em
}

@keyframes giro {
    0% {
        transform: rotate(0deg)
    }
    100% {
        transform: rotate(360deg)
    }
}

.imagen-flexible {
    max-width: 100%;
    height: auto
}

.manito {
    cursor: pointer
}

@keyframes pulse {
    0% {
        border: 1px solid rgba(220, 0, 40, 0.555)
    }
    50% {
        border: 1px solid rgba(233 120 126 / 50%);
        box-shadow: 0px 0px 15px 3px rgba(220 0 40 / 15%)
    }
    100% {
        border: 1px solid rgba(233 120 126 / 30%)
    }
}

@keyframes teto {
    0% {
        transform: translateY(-100px)
    }
    100% {
        transform: translateY(0px)
    }
}

@keyframes indeterminateAnimation {
    0% {
        transform: translateX(0) scaleX(0)
    }
    40% {
        transform: translateX(0) scaleX(0.3)
    }
    100% {
        transform: translateX(100%) scaleX(0.6)
    }
}

.fondo-imagen {
    background: url(../img/bg-05.png) 0% 50%;
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
    -o-background-size: cover
}

.fondo-nosotros {
    background: url(../img/bg-06.png) 50% 50%;
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
    -o-background-size: cover
}

.fondo-pac {
    background: url(../img/bg-08.png) 50% 50%;
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
    -o-background-size: cover
}

.fondo-spgc {
    background: url(../img/bg-07.png) 50% 50%;
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
    -o-background-size: cover
}

.fondo-pmc {
    background: url(../img/bg-09.png) 50% 50%;
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
    -o-background-size: cover
}

@media (max-width:360px) {
    .contenedor {
        width: 100%
    }
}

.texto-blanco-70 {
    color: rgba(255, 255, 255, 0.7)
}

.subordinado {
    padding-left: 1rem;
    border-left: 3px solid
}

.bg-gradiente {
    background-image: linear-gradient(to bottom, #ececec, #f5f5f5, #fff)
}


    .testimonial-right{
        display: block;
    }
    .testimonial-left{
        display: block;
    }
    .testimonial-text-right{
        text-align: justify; margin-left: 1rem;
        font-style: italic;
    }
    .testimonial-text-left{
        text-align: justify; margin-right: 1rem;
        font-style: italic;
    }
    .data-testimonial{
        margin-top: 0.5em;
    }
    @media (max-width: 994px){
        .testimonial-right{
            flex-direction: column-reverse;
        }
        .testimonial-text-right{
            margin-bottom: 2rem !important;
        }
        .testimonial-text-left{
            margin-bottom: 2rem !important;
        }
        .testimonial-left{
            display: block;
        }
        .data-testimonial{
            margin-top: 0;
        }
    }
    .mx-auto{
        margin-left: auto;
        margin-right: auto;
    }
    .my-auto{
        margin-top: auto;
        margin-bottom: auto;
    }
    .width-fit-content{
        width: fit-content;
    }
.fw-bolder{
    font-weight: bolder;
}
.margen-arriba-test {
    margin-top: 7em
}