@charset "UTF-8";

article, aside, figure, footer, header, hgroup, section {
    display: block
}

blockquote, body, dd, dl, dt, fieldset, figure, h1, h2, h3, h4, h5, h6, hr, html, iframe, legend, li, ol, p, pre, textarea, ul {
    margin: 0;
    padding: 0
}

h1, h2, h3, h4, h5, h6 {
    font-size: 100%;
    font-weight: 400
}

ol, ul {
    list-style: none
}

button, input, select, textarea {
    margin: 0
}

*, :after, :before, html {
    box-sizing: border-box
}

audio, img, video {
    height: auto;
    max-width: 100%
}

iframe {
    border: none
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

td, th {
    padding: 0;
    text-align: left
}

svg:not(:root) {
    overflow: hidden
}

svg {
    display: block;
    max-width: 100%
}

body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    color: #006e7d;
    font-family: -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.6;
    text-rendering: optimizeLegibility
}

.link, a {
    color: #4589ff;
    cursor: pointer;
    text-decoration: none
}

    .link:visited, a:visited {
        opacity: .9
    }

    .link:hover, a:hover {
        text-decoration: underline;
        transition: all .1s ease-in-out
    }

.small, small {
    display: inline-block;
    font-size: 85%;
    line-height: 150%
}

.small, figcaption, small {
    color: #006e7d;
    font-size: 85%;
    line-height: 150%
}

.bold, b, strong {
    color: #001417;
    font-weight: 500
}

.italic, em, i {
    font-style: italic
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
    font-family: -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;
    font-weight: 600;
    line-height: 1.15;
    margin: 0 0 16px
}

.h1, h1 {
    font-size: 400%
}

.h2, h2 {
    font-size: 250%
}

.h3, h3 {
    font-size: 200%
}

.h4, h4 {
    font-size: 150%
}

.h5, h5 {
    font-size: 125%
}

.h6, h6 {
    font-size: 100%
}

.block-margins, ol, pre, ul {
    margin: 0 0 16px
}

.unordered-list, ul {
    list-style-type: disc
}

.ordered-list, ol {
    list-style: decimal
}

.list-content li + li, p + p {
    margin-bottom: 0;
    margin-top: 16px
}

.lead {
    font-size: 133%
}



span {
    font-style: inherit;
    font-weight: inherit
}

hr {
    border: 0;
    border-bottom: 1px dashed #006e7d;
    margin: 0
}

code, pre {
    -moz-osx-font-smoothing: auto;
    -webkit-font-smoothing: auto;
    font-family: monospace
}

abbr, acronym {
    border-bottom: 1px dotted #006e7d;
    cursor: help;
    text-decoration: none
}

html {
    scroll-behavior: smooth
}

body, html {
    -webkit-overflow-scrolling: touch;
    background-color: #fff;
    font-display: optional;
    height: 100%;
    margin: 0;
    max-width: 100vw;
    min-width: 300px;
    overflow-x: hidden;
    padding: 0;
    position: relative;
    width: 100%
}

body {
    -ms-flex-line-pack: stretch;
    -ms-flex-align: stretch;
    -ms-flex-pack: start;
    align-content: stretch;
    align-items: stretch;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    justify-content: flex-start;
    min-height: 100vh;
    overflow-y: auto
}

    body > .main {
        -ms-flex: 1;
        flex: 1
    }

img, video {
    -ms-flex-negative: 0 !important;
    flex-shrink: 0 !important;
    height: auto
}

iframe, img, video {
    display: block;
    max-width: 100%
}

.text-center {
    text-align: center
}

.embed-container {
    height: 0;
    overflow: hidden;
    padding-bottom: 56.25%;
    position: relative
}

    .embed-container iframe {
        height: 100%;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%
    }

.tag {
    background-color: #ff6d4b;
    border-radius: 25px;
    color: #3075b0;
    font-size: 80%;
    font-weight: 500;
    line-height: 1;
    padding: .25rem .5rem;
    text-transform: uppercase
}

.section-header {
    margin: 2rem auto;
    position: relative;
    text-align: center;
    width: 60%
}

    .section-header .section-title {
        color: #00383f;
        font-size: 32px;
        font-weight: 500;
        font-weight: 800;
        line-height: 120%;
        margin-bottom: 16px
    }

    .section-header .section-description {
        line-height: 1.5rem;
        margin-bottom: 2rem
    }

    .section-header .section-icon {
        position: absolute;
        right: 1rem;
        top: 1rem
    }

        .section-header .section-icon svg {
            fill: #ff6d4b
        }

.home .grid {
    display: grid;
    gap: 4rem;
    grid-template-columns: repeat(2,160px);
    margin-left: auto;
    margin-right: auto
}

    .home .grid img {
        border-radius: 36px;
        box-shadow: 0 52px 45px rgba(110,38,85,.052),0 32.1879px 25.9137px rgba(110,38,85,.074),0 18.3248px 16.3552px rgba(110,38,85,.082),0 9.94125px 12.7207px rgba(110,38,85,.084),0 4.99418px 11.056px rgba(110,38,85,.087),0 2.13471px 8.9465px rgba(110,38,85,.102),0 .61294px 5.36161px rgba(110,38,85,.17)
    }

.block-center {
    -ms-flex-pack: center;
    -ms-flex-align: center;
    align-items: center;
    display: -ms-flexbox;
    display: flex;
    justify-content: center
}

.section {
    background-color: #f9f9f9;
    padding: 3rem 0 5rem
}

.office {
    margin-bottom: 1rem
}

    .office h5 {
        color: #ff6d4b;
        font-size: 1rem;
        font-weight: 700;
        margin-bottom: .5rem;
        text-transform: uppercase
    }

    .office a:hover {
        text-decoration: none
    }

    .office .address, .office .email, .office .phone {
        -ms-flex-align: start;
        align-items: flex-start;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: row;
        flex-direction: row;
        line-height: 1rem;
        margin-bottom: 1.2rem;
        position: relative
    }

        .office .address br, .office .email br, .office .phone br {
            margin-bottom: .5rem
        }

        .office .address span, .office .email span, .office .phone span {
            clear: both;
            display: inline-block
        }

        .office .address .icon, .office .email .icon, .office .phone .icon {
            margin-right: .5rem
        }

.cookie-consent {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    -ms-flex-align: center;
    -ms-flex-pack: center;
    align-items: center;
    animation-duration: .2s;
    animation-iteration-count: 1;
    animation-name: slideIn;
    animation-timing-function: ease-in-out;
    background: #00262b;
    border-radius: 0 100px 100px 0;
    bottom: 15px;
    box-shadow: 0 3px 15px 0 rgba(0,0,0,.25);
    color: #fff;
    display: -ms-flexbox;
    display: flex;
    font-size: 1rem;
    justify-content: center;
    left: 0;
    margin: 0;
    max-width: 66%;
    min-height: 48px;
    padding: .75rem 1.5rem;
    position: fixed;
    right: auto;
    transition: all .4s,bottom .8s ease-in-out;
    width: auto;
    z-index: 10
}

@media (max-width:640px) {
    .cookie-consent {
        border-radius: 0 30px 30px 0;
        -ms-flex-direction: column;
        flex-direction: column;
        height: auto;
        padding: 1rem;
        width: 66%
    }
}

.cookie-consent a {
    color: #dbf3b4;
    white-space: nowrap
}

.cookie-consent p {
    margin: 0 1rem 0 0;
    padding-left: 1.75rem
}

    .cookie-consent p:before {
        content: "🍪";
        display: inline-block;
        margin-left: -1.75rem;
        position: absolute;
        vertical-align: middle
    }

@media (max-width:640px) {
    .cookie-consent p {
        margin-bottom: 1rem
    }
}

.cookie-consent .cookie-consent__agree {
    background-color: #dbf3b4;
    border: none;
    border-radius: 100px;
    color: #00262b;
    cursor: pointer;
    display: inline-block;
    font-family: -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;
    font-size: 14px;
    font-weight: 700;
    padding: .33rem 1rem
}

    .cookie-consent .cookie-consent__agree:hover {
        background-color: #bbe872
    }

@media (max-width:640px) {
    .cookie-consent .cookie-consent__agree {
        padding: .66rem;
        width: 100%
    }
}

.elevated {
    background: #fff;
    border-bottom: 1px solid rgba(0,0,0,.2);
    box-shadow: 0 -60px 50px rgba(0,0,0,.07),0 -18px 12px rgba(0,0,0,.045),0 -8px 4px rgba(0,0,0,.035),0 -3px 1px rgba(0,0,0,.025),0 100px 80px rgba(0,0,0,.07),0 42px 33px rgba(0,0,0,.05),0 22px 18px rgba(0,0,0,.04),0 12px 10px rgba(0,0,0,.035),0 6px 5px rgba(0,0,0,.028),0 3px 2px rgba(0,0,0,.02);
    position: relative;
    z-index: 1
}

.stack {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    position: absolute
}

.stack-item {
    -ms-flex-positive: 0;
    -ms-flex-negative: 1;
    -ms-flex-preferred-size: 52%;
    flex-basis: 52%;
    flex-grow: 0;
    flex-shrink: 1;
    margin-left: -32%
}

    .stack-item img {
        transition: all .3s ease-in-out
    }

.app-services {
    -ms-flex-pack: distribute;
    justify-content: space-around
}

.app-item, .app-services {
    display: -ms-flexbox;
    display: flex
}

.app-item {
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-direction: column;
    flex-direction: column;
    text-align: center
}

.app-item-brand {
    margin-top: 1rem
}

.app-item-title {
    font-size: 1.33rem;
    font-weight: 600
}

.app-item-services {
    list-style: none;
    margin: 1rem 0;
    padding: 0
}

    .app-item-services li {
        margin-bottom: .5rem
    }

.container {
    margin: 0 auto;
    max-width: 1344px;
    position: relative;
    width: 94%
}

@media only screen and (max-width:639px) {
    .container {
        padding: 0 16px;
        width: calc(100% - 16px)
    }
}

@media only screen and (min-width:640px) {
    .container {
        padding: 0 32px;
        width: calc(100% - 32px)
    }
}

@media only screen and (min-width:1280px) {
    .container {
        padding: 0 48px;
        width: calc(100% - 48px)
    }
}

.row-cols-1 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(100% - 16px);
    flex-basis: calc(100% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(100% - 16px)
}

@media (max-width:961px) {
    .row-cols-1 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-2 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(50% - 16px);
    flex-basis: calc(50% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(50% - 16px)
}

@media (max-width:961px) {
    .row-cols-2 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-3 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(33.33333% - 16px);
    flex-basis: calc(33.33333% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(33.33333% - 16px)
}

@media (max-width:961px) {
    .row-cols-3 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-4 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(25% - 16px);
    flex-basis: calc(25% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(25% - 16px)
}

@media (max-width:961px) {
    .row-cols-4 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-5 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(20% - 16px);
    flex-basis: calc(20% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(20% - 16px)
}

@media (max-width:961px) {
    .row-cols-5 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-6 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(16.66667% - 16px);
    flex-basis: calc(16.66667% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(16.66667% - 16px)
}

@media (max-width:961px) {
    .row-cols-6 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-7 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(14.28571% - 16px);
    flex-basis: calc(14.28571% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(14.28571% - 16px)
}

@media (max-width:961px) {
    .row-cols-7 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row-cols-8 > * {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    -ms-flex-preferred-size: calc(12.5% - 16px);
    flex-basis: calc(12.5% - 16px);
    flex-grow: 0;
    flex-shrink: 0;
    max-width: calc(12.5% - 16px)
}

@media (max-width:961px) {
    .row-cols-8 > * {
        max-width: none;
        min-width: calc(50% - 16px)
    }
}

.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -8px;
    margin-right: -8px;
    min-width: 100%
}

@media (max-width:640px) {
    .row {
        -ms-flex-direction: column;
        flex-direction: column
    }
}

.row .col {
    -ms-flex-positive: 0;
    -ms-flex-negative: 0;
    flex-grow: 0;
    flex-shrink: 0;
    margin: 0 8px;
    overflow-wrap: break-word;
    position: relative;
    word-break: break-word
}

.row .col-1 {
    -ms-flex-preferred-size: calc(6.25% - 16px);
    flex-basis: calc(6.25% - 16px)
}

.row .col-2 {
    -ms-flex-preferred-size: calc(12.5% - 16px);
    flex-basis: calc(12.5% - 16px)
}

.row .col-3 {
    -ms-flex-preferred-size: calc(18.75% - 16px);
    flex-basis: calc(18.75% - 16px)
}

.row .col-4 {
    -ms-flex-preferred-size: calc(25% - 16px);
    flex-basis: calc(25% - 16px)
}

.row .col-5 {
    -ms-flex-preferred-size: calc(31.25% - 16px);
    flex-basis: calc(31.25% - 16px)
}

.row .col-6 {
    -ms-flex-preferred-size: calc(37.5% - 16px);
    flex-basis: calc(37.5% - 16px)
}

.row .col-7 {
    -ms-flex-preferred-size: calc(43.75% - 16px);
    flex-basis: calc(43.75% - 16px)
}

.row .col-8 {
    -ms-flex-preferred-size: calc(50% - 16px);
    flex-basis: calc(50% - 16px)
}

.row .col-9 {
    -ms-flex-preferred-size: calc(56.25% - 16px);
    flex-basis: calc(56.25% - 16px)
}

.row .col-10 {
    -ms-flex-preferred-size: calc(62.5% - 16px);
    flex-basis: calc(62.5% - 16px)
}

.row .col-11 {
    -ms-flex-preferred-size: calc(68.75% - 16px);
    flex-basis: calc(68.75% - 16px)
}

.row .col-12 {
    -ms-flex-preferred-size: calc(75% - 16px);
    flex-basis: calc(75% - 16px)
}

.row .col-13 {
    -ms-flex-preferred-size: calc(81.25% - 16px);
    flex-basis: calc(81.25% - 16px)
}

.row .col-14 {
    -ms-flex-preferred-size: calc(87.5% - 16px);
    flex-basis: calc(87.5% - 16px)
}

.row .col-15 {
    -ms-flex-preferred-size: calc(93.75% - 16px);
    flex-basis: calc(93.75% - 16px)
}

.row .offset-1 {
    margin-left: calc(6.25% - 16px)
}

.row .offset-2 {
    margin-left: calc(12.5% - 16px)
}

.row .offset-3 {
    margin-left: calc(18.75% - 16px)
}

.row .offset-4 {
    margin-left: calc(25% - 16px)
}

.row .offset-5 {
    margin-left: calc(31.25% - 16px)
}

.row .offset-6 {
    margin-left: calc(37.5% - 16px)
}

.row .offset-7 {
    margin-left: calc(43.75% - 16px)
}

.row .offset-8 {
    margin-left: calc(50% - 16px)
}

@media (max-width:961px) {
    .row .col-1, .row .col-2 {
        -ms-flex-preferred-size: auto;
        flex-basis: auto
    }

    .row .col-3 {
        -ms-flex-preferred-size: calc(33% - 16px);
        flex-basis: calc(33% - 16px)
    }

    .row .col-6 {
        -ms-flex-preferred-size: calc(50% - 16px);
        flex-basis: calc(50% - 16px)
    }
}

@media (max-width:640px) {
    .row .col-1, .row .col-2, .row .col-3 {
        -ms-flex-preferred-size: auto;
        flex-basis: auto
    }

    .row .col-6 {
        -ms-flex-preferred-size: calc(50% - 16px);
        flex-basis: calc(50% - 16px)
    }
}

.fx {
    display: -ms-flexbox;
    display: flex
}

.gap {
    gap: 1rem
}

.fx-start {
    -ms-flex-pack: start !important;
    justify-content: flex-start !important
}

.fx-center {
    -ms-flex-pack: center !important;
    justify-content: center !important
}

.fx-end {
    -ms-flex-pack: end !important;
    justify-content: flex-end !important
}

.fx-between {
    -ms-flex-pack: justify !important;
    justify-content: space-between !important
}

.fx-around {
    -ms-flex-pack: distribute !important;
    justify-content: space-around !important
}

.fv-start {
    -ms-flex-line-pack: start !important;
    align-content: flex-start !important
}

.fv-center {
    -ms-flex-line-pack: center !important;
    align-content: center !important
}

.fv-end {
    -ms-flex-line-pack: end !important;
    align-content: flex-end !important
}

.fv-between {
    -ms-flex-line-pack: justify !important;
    align-content: space-between !important
}

.fv-around {
    -ms-flex-line-pack: distribute !important;
    align-content: space-around !important
}

.fy-start {
    -ms-flex-align: start !important;
    align-items: flex-start !important
}

.fy-center {
    -ms-flex-align: center !important;
    align-items: center !important
}

.fy-end {
    -ms-flex-align: end !important;
    align-items: flex-end !important
}

.fs-start {
    -ms-flex-item-align: start !important;
    align-self: flex-start !important
}

.fs-center {
    -ms-flex-item-align: center !important;
    align-self: center !important
}

.fs-end {
    -ms-flex-item-align: end !important;
    align-self: flex-end !important
}

@media screen and (min-width:961px) {
    .grid {
        display: grid;
        gap: 2rem;
        grid-template-columns: minmax(480px,4fr) minmax(300px,1fr)
    }
}

/* --- SUBNAV BASE REFORMADO --- */
.subnav {
    background: #ffffff; /* Fondo limpio */
    border-bottom: 1px solid #e1e8ed;
    position: relative;
    box-shadow: 0 2px 15px rgba(0,0,0,0.15);
}

@media (min-width:961px) {
    .subnav {
        display: grid;
        grid-template-columns: minmax(3%,1fr) minmax(300px,1344px) minmax(3%,1fr);
    }
}

.subnav .center {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media (min-width:961px) {
    .subnav .center {
        flex-direction: row;
    }
}

/* Eliminamos degradados grises laterales */
.subnav .first, .subnav .last {
    background: transparent;
}

/* --- MENÚ Y ITEMS --- */
.subnav .menu {
    display: flex;
    justify-content: flex-end;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

/* Quita los puntos de la lista del menú desplegable */
.dropdown-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Por si acaso el estilo viene del contenedor padre */
.menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Y para asegurar que los elementos de la lista no tengan viñetas */
.menu-item, .dropdown-menu li {
    list-style-type: none;
}
@media (max-width:961px) {
    .subnav .menu {
        flex-direction: column;
    }
}

.subnav .menu-item {
    position: relative;
}

    /* Quitamos el degradado del último item */
    .subnav .menu-item:last-child {
        background: transparent;
    }

/* --- BOTONES DE NAVEGACIÓN (navigation-item) --- */
.subnav .navigation-item {
    background: transparent; /* Fondo limpio */
    border: none;
    color: #333;
    display: block;
    padding: 1rem 1.5rem;
    position: relative;
    transition: all 0.3s ease;
    cursor: pointer;
    text-decoration: none;
    width:100%;
}

@media (min-width:961px) {
    .subnav .navigation-item {
        /* He suavizado o eliminado el skew para que combine con el dropdown redondeado */
        display: inline-block;
        padding: 1.5rem 2rem;
        transform: none; /* Si quieres mantener el inclinado, cámbialo a skew(20deg) pero "none" es más moderno */
    }
}

.subnav .navigation-item:hover {
    background-color: #f0f8ff; /* El mismo azul claro que el hover de tus cards */
    color: #2a90d0; /* El azul de tu borde del dropdown */
}

/* Línea indicadora opcional en el hover */
.subnav .navigation-item::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 3px;
    background-color: #2a90d0;
    transition: all 0.3s ease;
    transform: translateX(-50%);
}

.subnav .navigation-item:hover::after {
    width: 100%;
}

.subnav .navigation-item .navigation-item-text {
    align-items: center;
    color: inherit;
    display: flex;
    font-size: 0.95rem;
    font-weight: 600;
    gap: .5rem;
    justify-content: space-between;
    line-height: 24px;
    transform: none; /* Reset del skew */
}

/* --- AJUSTES SVG (flecha abajo) --- */
.btn-dropdown svg {
    transition: transform 0.3s ease;
    width: 18px;
    height: 18px;
    stroke: #2a90d0;
}

/* Si el menú está activo, la flecha gira */
.menu-item:focus-within .btn-dropdown svg,
.menu-item:hover .btn-dropdown svg {
    transform: rotate(180deg);
}

/* --- BREADCRUMB COHERENTE --- */
.breadcrumb a {
    text-decoration: none;
    color: #666;
    font-size: 0.9rem;
    transition: color 0.2s;
}

    .breadcrumb a:hover {
        color: #2a90d0;
    }

.mobile-subnav span {
    background: #2d2f31;
    color: #fff;
    cursor: pointer;
    display: block;
    font-size: 1.2em;
    font-variant: small-caps;
    padding: 30px
}

    .mobile-subnav span:after {
        content: "+";
        float: right;
        right: 10%
    }

.mobile-subnav .slide {
    clear: both;
    height: 0;
    overflow: hidden;
    text-align: center;
    transition: height .4s ease;
    width: 100%
}

    .mobile-subnav .slide li {
        padding: 30px
    }

.mobile-subnav #touch {
    height: 0;
    opacity: 0;
    position: absolute
}

    .mobile-subnav #touch:checked + .slide {
        height: 300px
    }

.header-main {
    background-color: #fff;
    box-shadow: 0 18px 32px rgba(0,0,0,.08),0 8px 16px rgba(0,0,0,.06),0 4px 8px rgba(0,0,0,.04),0 2px 4px rgba(0,0,0,.03),0 2px 2px rgba(0,0,0,.02),0 1px 1px rgba(0,0,0,.01);
    padding: 1rem 0 .5rem;
    position: relative;
    z-index: 2
}

    .header-main .container {
        -ms-flex-pack: justify;
        -ms-flex-direction: row;
        flex-direction: row;
        justify-content: space-between
    }

        .header-main .container, .header-main .container > * {
            -ms-flex-align: center;
            align-items: center;
            display: -ms-flexbox;
            display: flex
        }

            .header-main .container > * {
                -ms-flex-pack: center;
                gap: .25rem;
                justify-content: center
            }

    .header-main .header-brand {
        font-size: 1.15rem;
        font-weight: 600;
        padding: .25rem;
        text-decoration: none;
        white-space: nowrap
    }

        .header-main .header-brand img {
            height: auto;
            width: clamp(1rem,10vw,3rem)
        }

    .header-main .header-menu {
        overflow: hidden;
        transition: height .3s ease-in-out
    }


@media (max-width: 961px) {
    /* Contenedor principal del menú desplegable */
    .header-main .header-menu {
        background-color: #ffffff;
        /* Bordes redondeados y sombra suave como el subnav */
        border-radius: 0 0 1rem 1rem;
        border: 1px solid #e1e8ed;
        border-top: none; 
        box-shadow: 0 10px 15px rgba(0,0,0,0.1);
        
        display: flex;
        flex-direction: column;
        position: absolute;
        left: 0;
        right: 0;
        top: 100%; /* Ajustado para que pegue justo debajo del header */
        
        /* Animación de apertura */
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 999;
        list-style: none;
        padding: 0;
        margin: 0;
    }

    /* Cuando el menú tiene la clase .active */
    .header-main .header-menu.active {
        max-height: 600px;
        padding: 0.5rem 0; /* Un pequeño respiro interno */
    }

    /* Estilo de cada item (el enlace o contenedor) */
    .header-main .header-menu .nav-item {
        color: #333;
        display: block;
        padding: 1rem 1.5rem;
        text-decoration: none;
        font-size: 0.95rem;
        font-weight: 600;
        transition: all 0.3s ease;
        position: relative;
        border-bottom: 1px solid #f5f8fa; /* Separador sutil entre items */
    }

    /* Quitar borde al último item para que no choque con el redondeado */
    .header-main .header-menu .nav-item:last-child {
        border-bottom: none;
    }

    /* Efecto Hover (Igual al Subnav) */
    .header-main .header-menu .nav-item:hover {
        background-color: #f0f8ff;
        color: #2a90d0;
        padding-left: 2rem; /* Pequeño desplazamiento a la derecha al hacer hover */
    }

    /* Línea decorativa lateral al hacer hover (opcional, estilo subnav) */
    .header-main .header-menu .nav-item::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 4px;
        background-color: #2a90d0;
        transform: scaleY(0);
        transition: transform 0.3s ease;
    }

    .header-main .header-menu .nav-item:hover::before {
        transform: scaleY(1);
    }

    .header-menu .btn-dropdown{
        background-color: #fff;
        border:none;
    }
}

/* El botón que activa el menú */
.nav-bloq {
    display: none;
}

.menu-window.show {
    display: block;
}

@media (max-width: 961px) {

    .nav-bloq {
        display: block;
        cursor: pointer;
    }


   .subnav .nav-bloq {
        display: none;
        cursor: pointer;
    }
}




    .header-main .header-menu.open {
        height: 16rem
    }

    .header-main .nav-item {
        color: #00262b;
        font-size: 1rem;
        font-weight: 600;
        line-height: 100%;
        padding: 1rem
    }

    .header-main .phone {
        -ms-flex-align: center;
        align-items: center;
        color: #3075b0;
        display: -ms-flexbox;
        display: flex;
        font-size: 24px;
        font-weight: 510;
        gap: .25rem;
        line-height: 100%;
        padding: 1rem
    }

    @media (max-width:961px) {

        .header-main {
            position: -webkit-sticky; /* Soporte para Safari en iOS */
            position: sticky;
            top: 0;
            z-index: 9999; /* Para que siempre esté por encima del contenido */
            background-color: #ffffff; /* Ajusta esto al color de tu fondo */
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* Sombra para que se note el despegue */
        }
        .header-main .phone span {
            display: none
        }
    }

    .header-main .btn-icon {
        background-color: transparent;
        padding: .5rem
    }

    .header-main .header-right {
        margin-left: auto
    }

    .header-right {
        padding: 5px 0;
    }

    .header-main .header-toggle {
        display: none;
        padding: 1.25rem .75rem
    }

    @media (max-width:961px) {
        .header-main .header-toggle {
            display: block
        }
    }

    .header-main .header-toggle.active .navicon {
        background: transparent
    }

        .header-main .header-toggle.active .navicon:after, .header-main .header-toggle.active .navicon:before {
            top: 0
        }

        .header-main .header-toggle.active .navicon:before {
            transform: rotate(-45deg)
        }

        .header-main .header-toggle.active .navicon:after {
            transform: rotate(45deg)
        }

    .navicon {
        background: #00262b;
        display: block;
        height: 2px;
        position: relative;
        transition: background .2s ease-out;
        width: 18px
    }

        .navicon:after, .navicon:before {
            background: #00262b;
            content: "";
            display: block;
            height: 100%;
            position: absolute;
            transition: all .2s ease-out;
            width: 100%
        }

        .navicon:before {
            top: 5px
        }

        .navicon:after {
            top: -5px
        }

    .hero {
        background-color: #00262b;
        background-image: url(/Theme/assets/img/grid.png);
        background-position: 0 0;
        background-repeat: repeat;
        position: relative
    }

        .hero .container {
            padding-bottom: 4rem;
            padding-top: 4rem
        }

    @media (max-width:1280px) {
        .hero .container {
            padding-bottom: 2rem;
            padding-top: 2rem
        }
    }

    .hero-id {
        color: #fff;
        display: block
    }

    .hero-title {
        font-size: clamp(1rem,3.5vw,3rem);
        font-weight: 510;
        line-height: 1.15
    }

    @media (max-width:640px) {
        .hero-title {
            font-size: 1.6rem
        }
    }

    .hero-description {
        font-size: 1.33rem;
        line-height: 1.4;
        margin: 2rem 0 3rem;
        max-width: 32ch
    }

    @media (max-width:640px) {
        .hero-description {
            font-size: 1.25rem;
            width: 100%
        }
    }

    .hero-content {
        color: #fff;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: column nowrap;
        flex-flow: column nowrap;
        width: 50%
    }

    @media (max-width:1280px) {
        .hero-content {
            width: 100%
        }
    }

    @media (max-width:961px) {
        .hero-content {
            margin-bottom: 0
        }
    }

    .hero-content .overline {
        color: #00b6ce;
        font-size: 1.5rem;
        font-weight: 600;
        line-height: 1
    }

    .courses {
        background-color: #f9f9f9
    }

    .card {
        -ms-flex-item-align: stretch;
        -ms-flex-positive: 1;
        align-self: stretch;
        background-color: #fff;
        border-radius: 8px;
        box-shadow: 0 17px 33px rgba(0,0,0,.05),0 7.10219px 15.3875px rgba(0,0,0,.033),0 3.79717px 7.88821px rgba(0,0,0,.025),0 2.12866px 3.99102px rgba(0,0,0,.02),0 1.13052px 1.79661px rgba(0,0,0,.014),0 .47043px .58174px rgba(0,0,0,.008);
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: column;
        flex-direction: column;
        flex-grow: 1;
        -ms-flex: 0 0 calc(25% - 2rem);
        flex: 0 0 calc(25% - 2rem);
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        position: relative;
        transform: perspective(1px) translateZ(0);
        transition: all .3s ease-in-out
    }

        .card, .card:hover {
            text-decoration: none
        }

            .card:hover {
                box-shadow: 0 14px 28px rgba(0,0,0,.25),0 10px 10px rgba(0,0,0,.22)
            }

    @media (max-width:640px) {
        .card {
            margin-bottom: 2rem
        }
    }

    .card-image {
        -ms-flex-align: center;
        -ms-flex-pack: center;
        align-items: center;
        aspect-ratio: 2/1;
        background-color: #f0f8ff;
        border-radius: .5rem .5rem 0 0;
        display: -ms-flexbox;
        display: flex;
        justify-content: center;
        max-width: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    .card-header {
        padding: 1rem 1.5rem;
        width: 100%
    }

    .card-overline {
        display: block;
        font-size: 80%;
        font-weight: 400;
        line-height: 1.15;
        opacity: .5;
        text-transform: uppercase
    }

    .card-overline, .card-title {
        color: #00262b;
        margin-bottom: .5rem
    }

    .card-title {
        -ms-flex-align: center;
        align-items: center;
        display: -ms-flexbox;
        display: flex;
        font-size: 1.1rem;
        font-weight: 600;
        gap: .25rem
    }

    .card-id {
        font-size: 75%;
        opacity: .5
    }

    .card-list {
        -ms-flex-align: start;
        -ms-flex-item-align: stretch;
        -ms-flex-positive: 0;
        align-items: flex-start;
        align-self: stretch;
        -ms-flex-direction: column;
        flex-direction: column;
        flex-grow: 0;
        gap: .75rem;
        list-style: none;
        padding: 0
    }

        .card-list, .card-list li {
            display: -ms-flexbox;
            display: flex
        }

            .card-list li {
                -ms-flex-align: baseline;
                align-items: baseline;
                color: #00262b;
                gap: .5rem
            }

                .card-list li .text {
                    font-size: .9rem
                }

                .card-list li .icon {
                    opacity: .45;
                    top: 3px
                }

    .card-body {
        margin-top: auto;
        padding: 2rem 1.5rem
    }

    .card-footer {
        -ms-flex-align: center;
        align-items: center;
        border-top: 1px dashed #ddd;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: row;
        flex-direction: row;
        gap: 1rem;
        margin-top: auto;
        padding: 1rem 1.5rem 1.5rem;
        width: 100%
    }

        .card-footer .btn {
            -ms-flex: 1;
            flex: 1
        }

    @media screen and (max-width:640px) {
        .card-footer {
            -ms-flex-direction: column;
            flex-direction: column
        }
    }

    .card .comp-overline {
        color: #3075b0;
        display: block;
        font-size: 85%;
        font-weight: 500;
        margin-bottom: .5rem;
        text-transform: uppercase
    }

    .card .comp-number {
        color: #ff6d4b;
        display: block;
        font-size: 2rem;
        font-weight: 500;
        line-height: 1;
        margin-bottom: 1rem
    }

    .card .comp-title {
        color: #00262b;
        font-size: 1.2rem;
        font-weight: 500;
        line-height: 1.33;
        margin-bottom: .75rem;
        position: relative
    }

    .card .comp-text {
        margin: 0
    }

    .card .comp-metadata {
        margin: 1rem 0
    }

    .cards-grid {
        grid-gap: 1.5rem;
        display: grid;
        grid-auto-rows: minmax(150px,auto);
        grid-template-columns: repeat(auto-fill,minmax(240px,1fr))
    }

    .card-course {
        border: 1px solid #d9e3dc
    }

        .card-course, .card-course:hover {
            box-shadow: none
        }

            .card-course .card-title {
                color: #3075b0;
                display: block;
                margin-bottom: 1rem
            }

    .flow-cards .category-title, .flow-cards .center-title {
        -ms-flex-align: center;
        align-items: center;
        display: -ms-flexbox;
        display: flex;
        gap: .5rem;
        padding-bottom: .5rem
    }

        .flow-cards .category-title .feather, .flow-cards .center-title .feather {
            height: 1em
        }

    .flow-cards .category-title {
        border-bottom: 2px solid #d1dfea;
        color: #00262b;
        font-size: clamp(1rem,1.25vw,1.5rem);
        margin-bottom: 0
    }

    .flow-cards .center-title {
        font-size: clamp(1rem,1vw,1.5rem)
    }

    .flow-cards .category {
        margin: 2rem 0
    }

    .flow-cards .category-centers {
        display: block;
        margin: .5rem 0
    }

    .flow-cards .cards-grid {
        grid-gap: 1.5rem;
        display: grid;
        grid-auto-rows: minmax(150px,auto);
        grid-template-columns: repeat(auto-fill,minmax(300px,1fr))
    }

    .flow-cards .card-course {
        aspect-ratio: 4/3;
        display: grid;
        grid-template-areas: "overlay";
        overflow: hidden
    }

        .flow-cards .card-course .card-title {
            color: #fff;
            font-size: clamp(1rem,2vw,1.25rem);
            font-weight: 700;
            margin-bottom: 0
        }

        .flow-cards .card-course .card-body {
            margin: 0;
            padding-bottom: 0;
            padding-top: 0
        }

    .flow-cards .card-content {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: column-reverse;
        flex-flow: column-reverse
    }

    .flow-cards .card-content, .flow-cards .card-image {
        grid-area: overlay;
        z-index: 10
    }

        .flow-cards .card-image img {
            aspect-ratio: unset;
            height: 100%;
            -o-object-fit: cover;
            object-fit: cover;
            position: relative;
            width: 100%
        }

    .flow-cards .card-image {
        height: 100%;
        width: 100%
    }

        .flow-cards .card-image:after {
            background: linear-gradient(180deg,transparent,rgba(0,0,0,.66));
            border-radius: .5rem;
            content: "";
            inset: 0;
            position: absolute
        }

    .flow-cards .card-list {
        gap: .5rem;
        margin: 0
    }

        .flow-cards .card-list li {
            -ms-flex-align: baseline;
            align-items: baseline;
            background-color: #4489ff;
            border-radius: .25rem;
            color: #fff;
            display: -ms-flexbox;
            display: flex;
            -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
            padding: 0 .35rem
        }

            .flow-cards .card-list li .text {
                font-size: .75rem
            }

    .flow-cards .center + .center {
        margin-top: 1rem
    }

    .form-group {
        -ms-flex: 0 0 48%;
        flex: 0 0 48%;
        margin-bottom: 16px
    }

    .form-label {
        border: 0;
        box-sizing: border-box;
        color: #006e7d;
        display: inline-block;
        font-family: inherit;
        font-size: .75rem;
        font-weight: 400;
        letter-spacing: .32px;
        line-height: 1rem;
        margin: 0 0 .5rem;
        padding: 0;
        text-transform: uppercase;
        vertical-align: initial
    }

        .form-label span {
            color: #ff6d4b;
            font-weight: 700
        }

    .form-helper-text {
        color: #00b6ce;
        font-size: .75rem;
        letter-spacing: .32px;
        line-height: 1rem;
        margin: .5rem 0;
        max-width: 75%;
        opacity: 1;
        z-index: 0
    }

    .form-control, .text-area {
        background-color: #fff;
        border: 1px solid #ddd;
        border-radius: .25rem;
        box-sizing: border-box;
        color: #00262b;
        font-family: inherit;
        font-size: 100%;
        font-size: .875rem;
        font-weight: 400;
        height: 2.5rem;
        letter-spacing: .16px;
        line-height: 1.125rem;
        margin: 0;
        outline: 2px solid transparent;
        outline-offset: -2px;
        padding: 0 1rem;
        transition: background-color 70ms cubic-bezier(.2,0,.38,.9),outline 70ms cubic-bezier(.2,0,.38,.9);
        vertical-align: initial;
        width: 100%
    }

        .form-control:focus {
            outline: 2px solid #ff6d4b;
            outline-offset: -2px
        }

    .text-area {
        -ms-flex-order: 3;
        min-height: 6rem;
        min-width: 10rem;
        order: 3;
        padding: .6875rem 1rem;
        resize: vertical
    }

    .form-select {
        -webkit-appearance: none;
        appearance: none;
        background-color: #fff;
        background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23007CB2%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E"),linear-gradient(180deg,#fff 0,#f7f7f7);
        background-position: right .7em top 50%,0 0;
        background-repeat: no-repeat,repeat;
        background-size: .65em auto,100%
    }

    .file-uploader {
        -ms-flex-pack: justify;
        -ms-flex-align: end;
        align-items: flex-end;
        display: -ms-flexbox;
        display: flex;
        justify-content: space-between
    }

        .file-uploader .form-helper-text {
            margin: 0
        }

    .surname-zq2969o3Ys {
        display: none
    }

    .input-group {
        display: -ms-flexbox;
        display: flex
    }

        .input-group .form-control {
            border-bottom-right-radius: 0;
            border-right: 0;
            border-top-right-radius: 0;
            margin: 0
        }

        .input-group .btn {
            border-bottom-left-radius: 0;
            border-top-left-radius: 0;
            height: 40px;
            line-height: 1;
            min-height: unset
        }

    .input-check {
        -ms-flex-align: baseline;
        align-items: baseline;
        display: -ms-flexbox;
        display: flex;
        gap: .5rem
    }

    .checkbox {
        background-color: #fff;
        border: 1px solid #ddd;
        border-radius: 3px;
        cursor: pointer;
        height: 1rem;
        position: relative;
        top: 3px;
        width: 1rem
    }

    .form-subscription {
        margin: 1rem auto;
        max-width: 32rem
    }

        .form-subscription fieldset {
            border: 1px solid #ddd;
            border-radius: .5rem;
            margin: 0 0 2rem;
            padding: 1rem 2rem
        }

        .form-subscription legend {
            color: #00262b;
            font-size: 1.25rem;
            font-weight: 500;
            padding: .25rem
        }

    .scroll-box {
        background-color: #fff;
        border: 1px solid #ddd;
        border-radius: .5rem;
        height: 8rem;
        margin: 1rem 0;
        overflow-y: auto;
        padding: .5rem 1rem
    }

    .subscription {
        background-color: #f9f9f9
    }

    .heading-group {
        margin-bottom: 2rem;
        text-align: center
    }

        .heading-group .heading-overline {
            color: #006e7d;
            font-size: 1rem;
            font-weight: 400;
            line-height: 1rem;
            margin-bottom: .75rem;
            position: relative;
            text-align: center;
            text-transform: uppercase
        }

        .heading-group .heading-title {
            color: #3075b0;
            font-size: 1.5rem;
            font-weight: 500;
            line-height: 1.33;
            margin-bottom: .75rem;
            position: relative;
            text-align: center
        }

    .navigation-menu {
        margin: 0
    }

        .navigation-menu .navigation-item {
            color: #3075b0;
            display: inline-block;
            font-size: .95rem;
            font-weight: 500;
            letter-spacing: .5px;
            line-height: 2rem;
            padding: 8px;
            position: relative;
            text-align: center;
            text-decoration: none;
            text-transform: uppercase
        }

            .navigation-menu .navigation-item:hover {
                color: #ff6d4b
            }

            .navigation-menu .navigation-item.icon-link {
                -ms-flex-pack: center;
                -ms-flex-align: center;
                align-items: center;
                display: -ms-flexbox;
                display: flex;
                justify-content: center
            }

    .navigation-toggle {
        background-color: transparent;
        background-image: none;
        border: 1px solid transparent;
        border-radius: 4px;
        cursor: pointer;
        float: right;
        margin-bottom: 8px;
        margin-top: 8px;
        padding: 9px 10px;
        position: relative
    }

        .navigation-toggle .icon-bar {
            background: #ff6d4b;
            display: block;
            height: 2px;
            width: 32px
        }

        .navigation-toggle:hover .icon-bar {
            opacity: .75
        }

        .navigation-toggle .icon-bar + .icon-bar {
            margin-top: 8px
        }

    @media (min-width:961px) {
        .navigation-toggle {
            display: none
        }
    }

    .btn {
        -ms-flex-align: center;
        -ms-flex-negative: 0;
        -ms-flex-pack: center;
        align-items: center;
        border: 1px solid transparent;
        border-radius: .25rem;
        box-sizing: border-box;
        cursor: pointer;
        display: -ms-inline-flexbox;
        display: inline-flex;
        flex-shrink: 0;
        font-family: inherit;
        font-size: 100%;
        font-size: 1rem;
        font-weight: 600;
        gap: .5rem;
        justify-content: center;
        letter-spacing: 2%;
        line-height: 1.125rem;
        margin: 0;
        min-height: 3rem;
        outline: none;
        padding: calc(.875rem - 3px) 2rem;
        position: relative;
        text-align: left;
        text-transform: uppercase;
        transition: all 70ms cubic-bezier(0,0,.38,.9);
        white-space: nowrap
    }

        .btn, .btn:hover {
            text-decoration: none
        }

            .btn .icon {
                -ms-flex-negative: 0;
                flex-shrink: 0;
                height: 1rem;
                margin-left: .5rem;
                width: 1rem
            }

    .btn-sm {
        font-size: 1rem;
        padding: .25rem 1rem
    }

    .btn-lg {
        font-size: 125%;
        font-weight: 600;
        letter-spacing: .5px;
        padding: 1.25rem 1.75rem;
        text-transform: uppercase
    }

    .btn-block {
        display: -ms-flexbox;
        display: flex;
        width: 100%
    }

    .btn[class*=-link] {
        background-color: transparent;
        box-shadow: none;
        font-weight: 600;
        text-transform: none
    }

        .btn[class*=-link]:hover {
            text-decoration: underline
        }

    .btn-icon {
        -ms-flex-align: center;
        align-items: center;
        display: -ms-flexbox;
        display: flex
    }

        .btn-icon .icon {
            margin-left: .5rem
        }

    .btn-video {
        padding: 0;
        position: relative
    }

        .btn-video:before {
            border-color: transparent transparent transparent #ff6d4b;
            border-style: solid;
            border-width: 32px 0 32px 64px;
            content: "";
            display: block;
            height: 64px;
            left: calc(50% - 32px);
            margin: 0 auto;
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            width: 64px;
            z-index: 2
        }

    .btn-primary {
        background-color: #ff6d4b;
        color: #fff
    }

        .btn-primary:active, .btn-primary:focus, .btn-primary:hover {
            background-color: #ff4418;
            border-color: #ff4418
        }

    .btn-primary-outline {
        border-color: #ff6d4b;
        color: #ff6d4b
    }

        .btn-primary-outline:active, .btn-primary-outline:focus, .btn-primary-outline:hover {
            background-color: rgba(255,109,75,.1);
            color: #ff5832
        }

    .btn-primary-link {
        color: #ff6d4b
    }

        .btn-primary-link:active, .btn-primary-link:focus, .btn-primary-link:hover {
            color: #ff5832
        }

    .btn-default {
        background-color: #00262b;
        color: #fff
    }

        .btn-default:active, .btn-default:focus, .btn-default:hover {
            background-color: #004a54
        }

    .btn-default-outline {
        border-color: #00262b;
        color: #00262b
    }

        .btn-default-outline:active, .btn-default-outline:focus, .btn-default-outline:hover {
            background-color: #004a54;
            color: #fff
        }

    .btn-bordered-dark {
        border-color: #00383f;
        color: #00383f
    }

        .btn-bordered-dark:active, .btn-bordered-dark:focus, .btn-bordered-dark:hover {
            background-color: rgba(0,0,0,.16);
            color: #00383f
        }

    #scroll-up {
        background-color: #dbf3b4;
        border: 0;
        border-radius: 100%;
        bottom: 88px;
        display: inline-block;
        height: 40px;
        opacity: 0;
        overflow: hidden;
        position: fixed;
        right: 1.5rem;
        text-align: center;
        text-indent: 100px;
        transition: background-color .3s,opacity .5s,visibility .5s;
        visibility: hidden;
        width: 40px;
        z-index: 1000
    }

        #scroll-up:after {
            border-color: transparent transparent #00262b;
            border-style: solid;
            border-width: 0 8px 12px;
            content: "";
            display: block;
            height: 12px;
            left: calc(50% - 8px);
            margin: 0 auto;
            position: absolute;
            top: 50%;
            transform: translateY(-60%);
            width: 12px;
            z-index: 1
        }

        #scroll-up:hover {
            background-color: #bbe872;
            cursor: pointer
        }

        #scroll-up.show {
            opacity: 1;
            visibility: visible
        }

    .close {
        background-color: transparent;
        border: 0;
        box-sizing: border-box;
        cursor: pointer;
        display: inline-block;
        height: 32px;
        line-height: 32px;
        margin: 4px;
        padding: 0;
        position: absolute;
        right: 0;
        top: 0;
        width: 32px
    }

        .close:after, .close:before {
            background-color: #00383f;
            content: "";
            display: block;
            height: 2px;
            left: 50%;
            margin-left: -12px;
            margin-top: -1px;
            position: absolute;
            top: 50%;
            transform: rotate(-45deg);
            transition: all .25s ease-out;
            width: 24px
        }

        .close:after {
            transform: rotate(-135deg)
        }

        .close:hover:after, .close:hover:before {
            transform: rotate(0deg)
        }

    .btn .caret {
        margin-left: 0
    }

    .caret {
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        border-top: 4px dashed;
        border-top: 4px solid\9;
        display: inline-block;
        height: 0;
        margin-left: 2px;
        vertical-align: middle;
        width: 0
    }

    .btn-card {
        background-color: #00262b;
        color: #fff;
        font-size: 1.25rem;
        font-weight: 500;
        height: 100%;
        line-height: 1.25;
        min-height: 8rem;
        padding: 1rem 1.5rem 4rem;
        position: relative;
        text-align: left;
        transition: background-color .3s;
        white-space: normal;
        word-break: normal
    }

        .btn-card:after {
            background-image: url(../icons/28/arrow.svg);
            background-position: 100% 100%;
            background-repeat: no-repeat;
            bottom: 16px;
            content: "";
            display: block;
            height: 24px;
            position: absolute;
            right: 16px;
            transition: right .3s;
            width: 24px
        }

        .btn-card:hover {
            background-color: #000;
            color: #fff
        }

            .btn-card:hover:after {
                right: 8px
            }

    .footer-main {
        background-color: #00262b;
        color: #fff;
        font-size: .96rem
    }

        .footer-main .nav {
            display: -ms-flexbox;
            display: flex;
            -ms-flex-direction: column;
            flex-direction: column;
            list-style: none;
            margin-bottom: 2rem;
            padding: 0
        }

            .footer-main .nav li a {
                -ms-flex-align: center;
                align-items: center;
                color: #fff;
                display: -ms-inline-flexbox;
                display: inline-flex;
                gap: .5rem;
                padding: .33rem 0
            }

                .footer-main .nav li a:hover {
                    background-color: transparent;
                    color: #ff6d4b;
                    text-decoration: none
                }

        .footer-main .list-icons {
            gap: 1rem;
            list-style: none;
            padding: 0
        }

            .footer-main .list-icons, .footer-main .list-icons a {
                -ms-flex-align: center;
                align-items: center;
                display: -ms-flexbox;
                display: flex
            }

                .footer-main .list-icons a {
                    -ms-flex-pack: center;
                    background-color: #fff;
                    border-radius: 1.25rem;
                    color: #00262b;
                    height: 2.5rem;
                    justify-content: center;
                    width: 2.5rem
                }

                    .footer-main .list-icons a:hover {
                        background-color: #3075b0
                    }

                    .footer-main .list-icons a img {
                        width: 24px
                    }

        .footer-main .sub-footer {
            border-top: 1px solid rgba(48,117,176,.15);
            font-size: .8rem;
            margin: 2rem 0;
            padding: 1.8rem 0
        }

    @media (max-width:640px) {
        .footer-main .sub-footer {
            -ms-flex-direction: column;
            flex-direction: column;
            text-align: center
        }
    }

    .corporate-logos {
        background-color: #00262b;
        border-bottom: 1px solid rgba(48,117,176,.15);
        padding: 2rem 0
    }

        .corporate-logos img {
            max-height: 56px
        }

        .corporate-logos .row {
            -ms-flex-pack: center;
            -ms-flex-align: center;
            align-items: center;
            gap: 3rem;
            justify-content: center;
            position: relative
        }

            .corporate-logos .row a:first-child {
                -ms-flex-align: center;
                align-items: center;
                display: -ms-inline-flexbox;
                display: inline-flex;
                gap: 3rem
            }

                .corporate-logos .row a:first-child:after {
                    background-color: #3075b0;
                    content: "";
                    display: block;
                    height: 3rem;
                    width: 1px
                }

    .microdata {
        margin-bottom: 1rem;
        margin-right: 1rem
    }

        .microdata .icon {
            font-size: 1.25rem;
            top: .25rem
        }

        .microdata [itemprop=name] {
            font-size: 1rem;
            margin-bottom: 1rem
        }

        .microdata [itemprop=address], .microdata [itemprop=telephone] {
            -ms-flex-align: baseline;
            align-items: baseline;
            display: -ms-inline-flexbox;
            display: inline-flex;
            gap: 1rem;
            margin-bottom: 1rem
        }

    .copy {
        margin-bottom: 2rem
    }

    .modal {
        display: none
    }

        .modal.is-open {
            display: block
        }

    .modal-overlay {
        -ms-flex-pack: center;
        -ms-flex-align: center;
        align-items: center;
        background: rgba(0,0,0,.6);
        bottom: 0;
        display: -ms-flexbox;
        display: flex;
        justify-content: center;
        left: 0;
        position: fixed;
        right: 0;
        top: 0;
        z-index: 10
    }

    .modal-container {
        box-sizing: border-box;
        height: 100vh;
        overflow-y: auto;
        width: 100%
    }

    @media (max-width:640px) {
        .modal-container {
            margin-top: 4rem;
            max-height: calc(100vh - 48px)
        }
    }

    .modal-container .carousel {
        height: 96vh;
        margin-top: 2vh;
        overflow-x: hidden
    }

    .modal-container .carousel-item {
        -ms-flex-pack: center;
        justify-content: center
    }

    .modal-close {
        background: transparent;
        border: 0;
        color: #fff;
        cursor: pointer;
        font-size: 72px;
        position: absolute;
        right: 1rem;
        top: 1rem;
        z-index: 1
    }

        .modal-close:hover {
            color: #ff6d4b
        }

    @keyframes mmfadeIn {
        0% {
            opacity: 0
        }

        to {
            opacity: 1
        }
    }

    @keyframes mmfadeOut {
        0% {
            opacity: 1
        }

        to {
            opacity: 0
        }
    }

    @keyframes mmslideIn {
        0% {
            transform: translateY(15%)
        }

        to {
            transform: translateY(0)
        }
    }

    @keyframes mmslideOut {
        0% {
            transform: translateY(0)
        }

        to {
            transform: translateY(-10%)
        }
    }

    .micromodal-slide {
        display: none
    }

        .micromodal-slide.is-open {
            display: block
        }

        .micromodal-slide[aria-hidden=false] .modal-overlay {
            animation: mmfadeIn .3s cubic-bezier(0,0,.2,1)
        }

        .micromodal-slide[aria-hidden=false] .modal-container {
            animation: mmslideIn .3s cubic-bezier(0,0,.2,1)
        }

        .micromodal-slide[aria-hidden=true] .modal-overlay {
            animation: mmfadeOut .3s cubic-bezier(0,0,.2,1)
        }

        .micromodal-slide[aria-hidden=true] .modal-container {
            animation: mmslideOut .3s cubic-bezier(0,0,.2,1)
        }

        .micromodal-slide .modal-container, .micromodal-slide .modal-overlay {
            will-change: transform
        }

    .panel {
        background-color: #fff;
        border: 1px solid #d9e3dc;
        border-radius: .5rem;
        box-shadow: none;
        margin-bottom: 1.5rem;
        position: relative
    }

        .panel .panel-header {
            padding: 1rem 1.5rem 0
        }

            .panel .panel-header .panel-title {
                font-size: 1rem;
                font-weight: 600;
                margin-bottom: 0;
                width: 66%
            }

        .panel .panel-body {
            padding: 1rem 1.5rem
        }

            .panel .panel-body ul {
                list-style: none;
                margin: 0;
                padding: 0
            }

            .panel .panel-body address {
                display: -ms-flexbox;
                display: flex;
                font-style: normal;
                gap: .5rem
            }

                .panel .panel-body address .feather {
                    -ms-flex-negative: 0;
                    flex-shrink: 0
                }

        .panel .panel-footer {
            margin-top: auto
        }

    .partners {
        background: #fff;
        border: 1px solid #daf1fc;
        border-radius: .5rem;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        gap: 2rem;
        margin-top: 4rem;
        padding: 2rem 1rem
    }

        .partners, .partners a {
            -ms-flex-pack: center;
            -ms-flex-align: center;
            align-items: center;
            display: -ms-flexbox;
            display: flex;
            justify-content: center
        }

    @media (max-width:961px) {
        .partners a {
            -ms-flex: 0 1 45%;
            flex: 0 1 45%
        }
    }

    .newsletter {
        background: #daf1fc;
        color: #00262b;
        padding: 3.5rem 0
    }

        .newsletter .row {
            -ms-flex-pack: center;
            -ms-flex-pack: justify;
            gap: 2rem;
            justify-content: center;
            justify-content: space-between
        }

    .newsletter-title {
        font-size: 1.5rem;
        font-weight: 500;
        margin-bottom: 1rem
    }

    .newsletter a {
        color: #00262b;
        text-decoration: underline
    }

    .newsletter .input-group {
        margin-bottom: .5rem
    }

    .icon {
        -ms-flex-align: center;
        -ms-flex-pack: center;
        align-items: center;
        display: -ms-inline-flexbox;
        display: inline-flex;
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        height: 1em;
        justify-content: center;
        position: relative;
        white-space: nowrap;
        width: 1em
    }

        .icon svg {
            max-height: 100%;
            max-width: 100%
        }

    .breadcrumb {
        display: none
    }

    @media (min-width:961px) {
        .breadcrumb {
            display: block
        }
    }

    .breadcrumb a {
        -ms-flex-align: center;
        align-items: center;
        display: -ms-inline-flexbox;
        display: inline-flex;
        gap: .5rem
    }

        .breadcrumb a svg {
            fill: currentColor
        }

        .breadcrumb a .text {
            color: #00262b;
            font-size: 1.25rem;
            font-weight: 600
        }

    .animated {
        animation-duration: 1s;
        animation-fill-mode: both
    }

    .delay-1 {
        animation-delay: .3s
    }

    .delay-2 {
        animation-delay: .5s
    }

    .delay-3 {
        animation-delay: .7s
    }

    .delay-4 {
        animation-delay: .9s
    }

    .delay-5 {
        animation-delay: 1.1s
    }

    .delay-6 {
        animation-delay: 1.3s
    }

    .delay-7 {
        animation-delay: 1.5s
    }

    .delay-8 {
        animation-delay: 1.7s
    }

    .delay-9 {
        animation-delay: 1.9s
    }

    @keyframes bounce {
        0%,20%,50%,80%,to {
            transform: translateX(0)
        }

        40% {
            transform: translateX(2rem)
        }

        60% {
            transform: translateX(1rem)
        }
    }

    @keyframes popUp {
        0% {
            opacity: 0;
            transform: scale(0)
        }

        to {
            opacity: 1;
            transform: scale(1)
        }
    }

    @keyframes fadeInDown {
        0% {
            opacity: 0;
            transform: translate3d(0,-100%,0)
        }

        to {
            opacity: 1;
            transform: translateZ(0)
        }
    }

    .fadeInDown {
        animation-name: fadeInDown
    }

    .blink {
        animation: blink-animation 1s steps(5,start) infinite;
        -webkit-animation: blink-animation 1s steps(5,start) infinite
    }

    @keyframes blink-animation {
        to {
            visibility: hidden
        }
    }

    @keyframes fadeIn {
        0% {
            opacity: 0
        }

        to {
            opacity: 1
        }
    }

    @keyframes fadeOut {
        0% {
            opacity: 1
        }

        to {
            opacity: 0
        }
    }

    @keyframes slideIn {
        0% {
            transform: translateX(-15%)
        }

        to {
            transform: translateX(0)
        }
    }

    @keyframes slideOut {
        0% {
            transform: translateY(0)
        }

        to {
            transform: translateY(-10%)
        }
    }

    @keyframes rotate {
        0% {
            transform: rotate(0)
        }

        to {
            transform: rotate(450deg)
        }
    }

    @keyframes line {
        0% {
            stroke-dasharray: 2,85.964;
            transform: rotate(0)
        }

        50% {
            stroke-dasharray: 65.973,21.9911;
            stroke-dashoffset: 0
        }

        to {
            stroke-dasharray: 2,85.964;
            stroke-dashoffset: -65.973;
            transform: rotate(90deg)
        }
    }

    .sr-only {
        clip: rect(1px,1px,1px,1px) !important;
        border: 0 !important;
        -webkit-clip-path: inset(50%) !important;
        clip-path: inset(50%) !important;
        height: 1px !important;
        margin: -1px !important;
        overflow: hidden !important;
        padding: 0 !important;
        position: absolute !important;
        white-space: nowrap !important;
        width: 1px !important
    }

    .sr-only-focusable:active, .sr-only-focusable:focus {
        clip: auto !important;
        -webkit-clip-path: none !important;
        clip-path: none !important;
        height: auto !important;
        margin: auto !important;
        overflow: visible !important;
        white-space: normal !important;
        width: auto !important
    }

    .danger {
        color: #f44336
    }

    .success {
        color: #66bb6a
    }

    .info {
        color: #4589ff
    }

    .warning {
        color: #dab538
    }

    .disabled {
        opacity: .44
    }

    .text-muted {
        opacity: .8
    }

    .bg-light {
        background-color: #dfebf6
    }

    .bg-dark {
        background-color: #00262b;
        color: #fff
    }

    .bg-accent-light {
        background-color: #ccc07610
    }

    .p-0 {
        padding: 0 !important
    }

    .m-0 {
        margin: 0 !important
    }

    .pb-0 {
        padding-bottom: 0 !important
    }

    .pt-0 {
        padding-top: 0 !important
    }

    .pt-1 {
        padding-top: 1rem !important
    }

    .pt-2 {
        padding-top: 2rem !important
    }

    .pt-3 {
        padding-top: 3rem !important
    }

    .pt-4 {
        padding-top: 4rem !important
    }

    .pt-5 {
        padding-top: 5rem !important
    }

    .pt-6 {
        padding-top: 6rem !important
    }

    .mt-0 {
        margin-top: 0 !important
    }

    .mt-1 {
        margin-top: 1rem !important
    }

    .mt-2 {
        margin-top: 2rem !important
    }

    .mt-3 {
        margin-top: 3rem !important
    }

    .mt-4 {
        margin-top: 4rem !important
    }

    .mt-5 {
        margin-top: 5rem !important
    }

    .mt-6 {
        margin-top: 6rem !important
    }

    .mb-0 {
        margin-bottom: 0 !important
    }

    .mb-1 {
        margin-bottom: 1rem !important
    }

    .mb-2 {
        margin-bottom: 2rem !important
    }

    .mb-3 {
        margin-bottom: 3rem !important
    }

    .mb-4 {
        margin-bottom: 4rem !important
    }

    .mb-5 {
        margin-bottom: 5rem !important
    }

    .mb-6 {
        margin-bottom: 6rem !important
    }

    .py-0 {
        padding-bottom: 0 !important;
        padding-top: 0 !important
    }

    .py-1 {
        padding-bottom: 1rem !important;
        padding-top: 1rem !important
    }

    .py-2 {
        padding-bottom: 2rem !important;
        padding-top: 2rem !important
    }

    .py-3 {
        padding-bottom: 3rem !important;
        padding-top: 3rem !important
    }

    .py-4 {
        padding-bottom: 4rem !important;
        padding-top: 4rem !important
    }

    .py-5 {
        padding-bottom: 5rem !important;
        padding-top: 5rem !important
    }

    .py-6 {
        padding-bottom: 6rem !important;
        padding-top: 6rem !important
    }

    .px-0 {
        padding-left: 0 !important;
        padding-right: 0 !important
    }

    .px-1 {
        padding-left: 1rem !important;
        padding-right: 1rem !important
    }

    .px-2 {
        padding-left: 2rem !important;
        padding-right: 2rem !important
    }

    .px-3 {
        padding-left: 3rem !important;
        padding-right: 3rem !important
    }

    .px-4 {
        padding-left: 4rem !important;
        padding-right: 4rem !important
    }

    .px-5 {
        padding-left: 5rem !important;
        padding-right: 5rem !important
    }

    .px-6 {
        padding-left: 6rem !important;
        padding-right: 6rem !important
    }

    .my-0 {
        margin-bottom: 0 !important;
        margin-top: 0 !important
    }

    .my-1 {
        margin-bottom: 1rem !important;
        margin-top: 1rem !important
    }

    .my-2 {
        margin-bottom: 2rem !important;
        margin-top: 2rem !important
    }

    .my-3 {
        margin-bottom: 3rem !important;
        margin-top: 3rem !important
    }

    .my-4 {
        margin-bottom: 4rem !important;
        margin-top: 4rem !important
    }

    .my-5 {
        margin-bottom: 5rem !important;
        margin-top: 5rem !important
    }

    .my-6 {
        margin-bottom: 6rem !important;
        margin-top: 6rem !important
    }

    @media screen and (-webkit-min-device-pixel-ratio:0) {
        .office .address, .office .email, .office .phone {
            line-height: 1.5
        }
    }

    .page-contact .card.card-contact {
        -ms-flex-pack: start;
        -ms-flex-align: stretch;
        align-items: stretch;
        background-color: #fff;
        box-shadow: 0 2px 4px 0 rgba(0,0,0,.15);
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: row;
        flex-direction: row;
        justify-content: flex-start;
        margin: -16rem auto 8rem;
        padding: 0;
        width: 75%
    }

        .page-contact .card.card-contact .contact-data, .page-contact .card.card-contact .contact-form {
            -ms-flex-negative: 1;
            -ms-flex-positive: 0;
            box-shadow: none;
            flex-grow: 0;
            flex-shrink: 1;
            padding: 3rem
        }

        .page-contact .card.card-contact .contact-data {
            -ms-flex-preferred-size: 40%;
            flex-basis: 40%
        }

        .page-contact .card.card-contact .contact-form {
            -ms-flex-preferred-size: 60%;
            flex-basis: 60%
        }

            .page-contact .card.card-contact .contact-form .panel-header {
                padding-top: 0
            }

            .page-contact .card.card-contact .contact-form .panel-content, .page-contact .card.card-contact .contact-form .panel-header {
                padding-left: 0;
                padding-right: 0
            }

    .page-contact .office p {
        margin: 1rem 0
    }

    @media (max-width:1280px) {
        .page-contact .card.card-contact .contact-data, .page-contact .card.card-contact .contact-form {
            -ms-flex-preferred-size: 50%;
            flex-basis: 50%
        }
    }

    @media (max-width:961px) {
        .page-contact .card.card-contact {
            width: 100%
        }

            .page-contact .card.card-contact .contact-data, .page-contact .card.card-contact .contact-form {
                -ms-flex-preferred-size: 50%;
                flex-basis: 50%
            }
    }

    @media (max-width:640px) {
        .page-contact .card.card-contact {
            -ms-flex-direction: column;
            flex-direction: column
        }

            .page-contact .card.card-contact .contact-data, .page-contact .card.card-contact .contact-form {
                -ms-flex-preferred-size: 50%;
                flex-basis: 50%
            }
    }

    .page-about .hero, .page-contact .hero, .page-home .hero {
        background-image: url(/Theme/assets/img/hero-image.png),url(/Theme/assets/img/grid.png);
        background-position: 100%,0;
        background-repeat: no-repeat,repeat
    }

    .page-about .hero-content, .page-contact .hero-content, .page-home .hero-content {
        color: #fff;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: column nowrap;
        flex-flow: column nowrap;
        width: 40%
    }

    span[id*=Repeater_Areas] {
        font-size: 80%;
        margin-left: auto
    }

    .section.text-legal {
        padding-bottom: 8rem
    }

        .section.text-legal .section-heading {
            background-color: #3075b0;
            border-bottom: 1px solid #f9f9f9;
            color: #fff;
            padding: 4rem 0
        }

        .section.text-legal .section-content {
            max-width: 800px
        }

            .section.text-legal .section-content .h4, .section.text-legal .section-content h4 {
                font-size: 125%
            }

            .section.text-legal .section-content > * {
                margin-bottom: 1rem
            }

            .section.text-legal .section-content > .h4, .section.text-legal .section-content > h4 {
                margin-top: 3rem
            }

    .page-course .hero-image img {
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
        position: absolute;
        right: 0;
        top: 0;
        width: 50%
    }

    .page-course .hero-image:after {
        background: linear-gradient(90deg,#00262b,rgba(0,38,43,0));
        bottom: 0;
        content: "";
        position: absolute;
        right: 0;
        top: 0;
        width: 50%
    }

    .share {
        margin: 2rem 0
    }

    .share-text {
        margin-bottom: 1rem
    }

    .share-list {
        display: -ms-flexbox;
        display: flex;
        gap: 1rem;
        list-style: none;
        padding: 0
    }

        .share-list svg {
            width: 2.25rem
        }

    .list-unstyled {
        list-style: none;
        padding: 0
    }

        .list-unstyled li {
            margin-bottom: 1rem
        }

    .card-title {
        color: #3075b0;
        font-size: 1rem;
        text-transform: lowercase
    }

        .card-title:first-letter {
            text-transform: uppercase
        }

        .card-title .icon svg {
            stroke: transparent;
            fill: #3075b0
        }

    .grid-sidebar .card-title {
        color: #00262b;
        text-transform: unset
    }

    .page-about .mosaic {
        -ms-flex-pack: center;
        -ms-flex-align: start;
        align-items: flex-start;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: column;
        flex-direction: column;
        justify-content: center;
        width: 360px
    }

        .page-about .mosaic img {
            mix-blend-mode: multiply
        }

        .page-about .mosaic > img:nth-child(2), .page-about .mosaic > img:nth-child(4) {
            -ms-flex-item-align: end;
            align-self: flex-end
        }

    .page-services .grid {
        display: grid;
        grid-auto-flow: dense;
        grid-template-columns: repeat(2,50%);
        width: 100%
    }

    @media (max-width:640px) {
        .page-services .grid {
            display: block
        }
    }

    .page-services .grid-item:not(.grid-item-image) {
        padding: 3rem 2rem 1rem 0
    }

    .page-services .grid-item-image {
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: cover
    }

    @media (max-width:640px) {
        .page-services .grid-item-image {
            height: 300px;
            margin-left: -1rem;
            margin-right: -1rem
        }
    }

    .page-services .grid-item:nth-child(4n+3) {
        padding: 3rem 2rem 1rem
    }

    @media (max-width:640px) {
        .page-services .grid-item:nth-child(4n+3) {
            padding: 3rem 2rem 1rem 0
        }
    }

    .page-services .grid-item:nth-child(4n+4) {
        grid-column: 1
    }

    .page-services .grid-item:nth-child(4n+3) {
        grid-column: 2
    }

    .page-services .grid-item {
        position: relative
    }

        .page-services .grid-item .grid-item-content {
            width: 80%
        }

    @media (max-width:640px) {
        .page-services .grid-item .grid-item-content {
            margin-bottom: 2rem
        }
    }

    .page-services .grid-item .grid-item-content .grid-item-overline {
        color: #006e7d;
        font-size: 1rem;
        font-weight: 500;
        margin-bottom: 1.5rem;
        text-transform: uppercase
    }

    .page-services .grid-item .grid-item-content .grid-item-title {
        color: #00262b;
        font-size: 2rem;
        font-weight: 500;
        margin-bottom: 1.5rem
    }

    .page-services .grid-item .grid-item-content .grid-item-description {
        margin-bottom: 2rem
    }

    .page-services .grid-item .btn-primary {
        bottom: 0;
        position: absolute;
        right: 0
    }

    @media (max-width:640px) {
        .page-services .grid-item .btn-primary {
            right: -1rem
        }
    }

    @media (-ms-high-contrast:none),screen and (-ms-high-contrast:active) {
        body {
            display: block !important
        }

        .features .key-feature {
            padding: 0 1rem
        }

            .features .key-feature .feature-title {
                background-size: contain
            }

        .page-about .cards-deck {
            margin-top: -6rem
        }

        .tiles .comp {
            max-width: auto !important
        }

        .page-services :not(.grid-item-image).grid-item {
            padding: 3rem 2rem 1rem 0 !important
        }

        .page-services .grid-item-image {
            min-height: 200px
        }
    }

    .grid-test {
        display: grid;
        grid-template-columns: repeat(4,25%)
    }

    h1.test {
        color: #999;
        font-size: 1rem;
        padding: 2rem 1rem 1rem;
        text-transform: uppercase
    }

        h1.test:before {
            content: "# "
        }

/*A partir de aqui es lo de las personitas de las cards*/

.texto-error {
    color: red !important;
    font-weight: bold;
}
/* Contenedor principal */
.curso-stats {
    display: flex;
    align-items: center;
    gap: 20px; /* Espacio entre los dos bloques */
    padding: 8px 0;
    justify-content: center;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

/* Este es el contenedor "que lo envuelve" */
.stats-container-centered {
    display: flex;
    justify-content: center; /* Centra los dos bloques en la pantalla */
    align-items: flex-start; /* Alinea los bloques por la parte superior */
    gap: 100px; /* Espacio generoso entre los dos bloques */
    width: 100%;
    padding: 20px 0;
    text-align: center;
}

/* Tu clase ajustada */
.stat-item {
    display: flex;
    align-items: center; /* Centra el icono y el texto entre sí */
    flex-direction: row; /* Icono arriba, texto abajo */
    gap: 8px; /* Espacio entre icono y número */
    cursor: pointer;
    transition: transform 0.2s;
    white-space: nowrap;
}

    .stat-item:hover {
        transform: scale(1.1); /* Un pequeño zoom al pasar el ratón */
    }

    /* Estetica de los iconos para que se vean como botones */
    .stat-item i {
        font-size: 1.2rem; /* Un poco más grandes ya que están solos arriba */
    }

    .stat-item #text {
        font-size: 0.9rem;
    }

.icon-blue {
    color: #007bff;
}

.icon-green {
    color: #28a745;
}

.stat-value {
    font-size: 0.9rem;
    font-weight: bold;
    color: #333;
}


    .stat-value small {
        color: #6c757d; /* Color más suave para el total de plazas */
    }

/* Separador */
.stat-divider {
    color: #dee2e6;
    font-weight: 200;
}

/* Estilo para el Tooltip Negro (si no usas JS) */
[title]:hover::after {
    content: attr(title);
    position: absolute;
    background: #000;
    color: #fff;
    padding: 4px 8px;
    font-size: 12px;
    border-radius: 4px;
    white-space: nowrap;
    z-index: 10;
    margin-top: -30px;
}
