.m-t-10 {
    margin-top: 10px;
}

.m-t-20 {
    margin-top: 20px;
}

.m-t-30 {
    margin-top: 30px;
}

.m-t-40 {
    margin-top: 40px;
}

.m-t-50 {
    margin-top: 50px;
}

.m-b-10 {
    margin-bottom: 10px;
}

.m-b-20 {
    margin-bottom: 20px;
}

.m-b-30 {
    margin-bottom: 30px;
}

.m-b-40 {
    margin-bottom: 40px;
}

.m-b-50 {
    margin-bottom: 50px;
}


.p-0 {
    padding: 0 !important;
}

.m-0 {
    margin: 0 !important;
}

.p-t-5 {
    padding-top: 5px;
}

.p-t-10 {
    padding-top: 10px;
}

.p-t-20 {
    padding-top: 20px;
}

.p-t-30 {
    padding-top: 30px;
}

.p-t-40 {
    padding-top: 40px;
}

.p-t-50 {
    padding-top: 50px;
}

.p-t-60 {
    padding-top: 60px;
}

.p-t-70 {
    padding-top: 70px;
}

.p-t-80 {
    padding-top: 80px;
}

.p-t-100 {
    padding-top: 100px;
}
.p-t-110 {
    padding-top: 110px;
}
.p-t-120 {
    padding-top: 120px;
}
.p-t-130 {
    padding-top: 130px;
}
.p-t-140 {
    padding-top: 140px;
}

.p-t-148 {
    padding-top: 148px;
}

.p-t-150 {
    padding-top: 150px;
}

.p-t-160 {
    padding-top: 160px;
}

.p-t-170 {
    padding-top: 170px;
}

.p-t-180 {
    padding-top: 180px;
}

.p-t-190 {
    padding-top: 190px;
}


.p-t-200 {
    padding-top: 200px;
}

.p-t-210 {
    padding-top: 210px;
}

.p-t-220 {
    padding-top: 220px;
}

.p-t-230 {
    padding-top: 230px;
}

.p-t-240 {
    padding-top: 240px;
}



.p-t-250 {
    padding-top: 250px;
}

.p-t-260 {
    padding-top: 260px;
}

.p-t-270 {
    padding-top: 270px;
}

.p-t-280 {
    padding-top: 280px;
}

.p-t-290 {
    padding-top: 290px;
}

.p-t-300 {
    padding-top: 300px;
}

.p-t-350 {
    padding-top: 350px;
}


.p-t-400 {
    padding-top: 400px;
}

.p-t-450 {
    padding-top: 450px;
}




.p-t-500 {
    padding-top: 500px;
}


.p-b-10 {
    padding-bottom: 10px;
}

.p-b-20 {
    padding-bottom: 20px;
}

.p-b-30 {
    padding-bottom: 30px;
}

.p-b-40 {
    padding-bottom: 40px;
}

.p-b-50 {
    padding-bottom: 50px;
}

.p-b-60 {
    padding-bottom: 60px;
}

.p-b-70 {
    padding-bottom: 70px;
}

.p-b-80 {
    padding-bottom: 80px;
}

.p-b-90 {
    padding-bottom: 90px;
}


.p-b-100 {
    padding-bottom: 100px;
}

.p-b-120 {
    padding-bottom: 120px;
}


.p-b-130 {
    padding-bottom: 130px;
}


.p-b-135 {
    padding-bottom: 135px;
}


.p-b-140 {
    padding-bottom: 140px;
}


.p-b-150 {
    padding-bottom: 140px;
}

.p-b-190 {
    padding-bottom: 190px;
}

.p-b-200 {
    padding-bottom: 200px;
}

.p-b-230 {
    padding-bottom: 230px;
}

.p-b-300 {
    padding-bottom: 300px;
}

.p-b-310 {
    padding-bottom: 310px;
}

.p-b-410 {
    padding-bottom: 410px;
}

.p-b-450 {
    padding-bottom: 450px;
}

.p-b-500 {
    padding-bottom: 500px;
}

.p-b-550 {
    padding-bottom: 550px;
}

.p-b-600 {
    padding-bottom: 650px;
}

/* Estilos de textos */

:root {
    --site-font-sans: "Montserrat", sans-serif;
    --bs-font-sans-serif: var(--site-font-sans);
    --title-font: var(--site-font-sans);
    --body-font: var(--site-font-sans);
    --udent-blue: #4f8dff;
    --udent-blue-dark: #2f5fdd;
    --udent-blue-hover: #3f75e9;
    --udent-blue-soft: #5db4ff;
    --udent-blue-text: #4f7df3;
    --udent-gray-bg: #f3f3f3;
    --udent-card-bg: #f4f4f4;
    --udent-footer-bg: #cfcfcf;
    --udent-muted-text: #808894;
    --udent-paragraph-size: 0.875rem;
}

body {
    overflow-x: hidden;
    overflow-x: clip;
    max-width: 100%;
    background-color: #fff;
    font-family: var(--site-font-sans);
}

html,
body {
    max-width: 100%;
    background-color: #fff;
}


h1 {
    font-family: var(--title-font);
	font-weight: 700;
    font-size: 2.8em;
}

h2 {
    font-family: var(--title-font);
	font-weight: 800;
	font-size: 2em;
}

h3 {
    font-family: var(--title-font);
	font-weight: 800;
	font-size: 2em;
}

h4 {
    font-family: var(--title-font);
	font-weight: 500;
	font-size: 1em;
}


h5 {
    font-family: var(--title-font);
	font-weight: 600;
	font-size: 1.7em;
    
}

h6 {
    font-family: var(--title-font);
	font-weight: 600;
	font-size: 1.1em;
    
}



p {
    font-family: var(--body-font);
	font-weight: 400;
}



/* Estilos de color */

.c-rojo{ color: rgba(174,38,47,1);}


html {
    scroll-behavior: smooth;
    font-size: 103%;
    --hero-copy-offset: clamp(2.75rem, 8vw, 7.5rem);
}

@media (max-width: 991.98px) {
    html,
    body {
        overflow-x: hidden;
        overflow-x: clip;
        overscroll-behavior-x: none;
    }

    .modal-menu-movil,
    .modal-menu-movil .modal-dialog,
    .modal-menu-movil .modal-content,
    .modal-menu-movil .modal-body,
    .hero-mayorista-section,
    .mayoristas-section,
    .somos-fabrica-section,
    #tipos-salas,
    .porque-samar-hero,
    #samar-catalogo,
    #samar-distribuidor,
    #samar-presencia {
        overflow-x: hidden;
        overflow-x: clip;
    }

    .modal-menu-movil .row {
        --bs-gutter-x: 0;
        margin-left: 0;
        margin-right: 0;
    }

    .modal-menu-movil .row > * {
        padding-left: 0;
        padding-right: 0;
    }

    .modal-menu-movil .modal-header,
    .modal-menu-movil .modal-body {
        padding-left: clamp(1.5rem, 7vw, 2.25rem);
        padding-right: clamp(1.5rem, 7vw, 2.25rem);
    }

    .modal-menu-movil .modal-header {
        justify-content: flex-start;
        padding-top: 1.75rem;
        padding-bottom: 0;
    }

    .modal-menu-movil .modal-header .col {
        text-align: left !important;
    }

    .modal-menu-movil .menu-movil {
        align-items: flex-start;
        margin-top: 2rem !important;
        padding-left: 0;
        text-align: left;
    }

    .modal-menu-movil .menu-movil li {
        width: 100%;
        margin: 0 0 1.2rem;
    }

    .modal-menu-movil .menu-movil li a {
        display: inline-block;
        line-height: 1.15;
    }
}



/* Estilos de seccion */



.seccion-footer{
    background-color: rgba(13,61,97,1);
	padding: 30px 0 30px;
}

.seccion-footer-movil{
    background-color: rgba(13,61,97,1);
	padding: 50px 0 50px;
}

.navbar-custom {
    background-color: rgba(255,255,255,1);
    padding: 0.85rem 0;
}

.navbar-scrolled {
    background-color: rgba(255,255,255,1) !important;
    transition: background-color 0.3s ease;
}

#navbar .container {
    position: relative;
    padding-left: calc(var(--hero-copy-offset) + 3rem);
}

.navbar-nav-wrapper {
    position: static;
    transform: none;
}

.navbar-custom .navbar-nav .nav-link,
.navbar-custom .navbar-nav .nav-link:focus,
.navbar-custom .navbar-nav .nav-link:hover {
    color: var(--udent-blue) !important;
    font-weight: 400;
    font-size: 0.75rem;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.navbar-custom .navbar-nav .nav-link:hover {
    color: var(--udent-blue-hover) !important;
}

.navbar-custom .navbar-nav .nav-link.active,
.navbar-custom .navbar-nav .nav-link.active:focus,
.navbar-custom .navbar-nav .nav-link.active:hover {
    color: var(--udent-blue) !important;
    font-weight: 700;
}

.header-social-link {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.header-social-link img {
    width: 30px;
    height: 30px;
    display: block;
    object-fit: contain;
}

.header-actions .btn-outline-header,
.header-actions .btn-header-action {
    border-radius: 999px;
    padding: 0.35rem 0.75rem;
    font-size: 0.78rem;
    font-weight: 400;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    min-height: 2.1rem;
}

.header-actions .btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.header-actions .btn-outline-header {
    color: #00A099;
    border: 1px solid #00A099;
    background: transparent;
}

.header-actions .btn-outline-header:hover {
    color: #ffffff;
    background: #00A099;
    border-color: #00A099;
}

.header-actions .btn-header-action {
    background-color: #ff6b2b;
    color: #ffffff;
    border: 1px solid transparent;
}

.header-actions .btn-header-action:hover {
    background-color: #e05a20;
}


.header-actions .btn-outline-header {
    color: #00A099;
    border: 1px solid #00A099;
    background: transparent;
}

.header-actions .btn-outline-header:hover {
    color: #ffffff;
    background: #00A099;
    border-color: #00A099;
}

.header-actions .btn-header-action {
    background-color: #ff6b2b;
    color: #ffffff;
    border: 1px solid transparent;
}

.header-actions .btn-header-action:hover {
    background-color: #e05a20;
}

.navbar-brand img {
    max-height: 52px;
}

.navbar-brand {
    padding: 0;
}

.header-logo {
    display: block;
    width: auto;
    max-height: 42px;
}

@media (min-width: 992px) {
    .navbar-brand img.header-logo {
        width: 175px;
        max-height: none;
    }
}

#quienes-somos,
#especialidades {
    scroll-margin-top: 88px;
}

.udent-intro-section {
    padding: clamp(3rem, 5vw, 4.75rem) 0;
}

.udent-intro-section .row {
    --bs-gutter-x: clamp(1.75rem, 4vw, 3.75rem);
    --bs-gutter-y: 2rem;
}

.udent-intro-section__media {
    display: flex;
    align-items: stretch;
}

.udent-intro-section__image {
    width: 100%;
    min-height: 320px;
    max-height: 390px;
    object-fit: cover;
}

.udent-section-axis {
    padding-left: calc(var(--hero-copy-offset) + 3rem);
}

.navbar-custom .navbar-toggler {
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.navbar-custom .navbar-toggler:focus,
.navbar-custom .navbar-toggler:hover,
.navbar-custom .navbar-toggler:active {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.navbar-custom .navbar-toggler-icon {
    width: 1.9rem;
    height: 1.4rem;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%234f8dff' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
    background-size: 100% 100%;
}

.udent-home-hero {
    background: var(--udent-blue);
}

.udent-home-hero__overlay {
    background: linear-gradient(to top, rgba(79, 141, 255, 0.95) 0%, rgba(79, 141, 255, 0.76) 22%, rgba(79, 141, 255, 0.28) 42%, rgba(79, 141, 255, 0) 65%);
    pointer-events: none;
}

.udent-home-hero__content {
    bottom: clamp(2.6rem, 5vw, 4.2rem);
    z-index: 1;
}

.udent-home-hero__copy {
    margin-left: var(--hero-copy-offset, clamp(2.75rem, 8vw, 7.5rem));
}

.udent-home-hero__title {
    font-size: clamp(1.35rem, 3vw, 2.1rem);
    white-space: nowrap;
}

.udent-home-hero__text {
    max-width: 560px;
    font-size: 0.875rem;
    line-height: 1.35;
}

@media (max-width: 767.98px) {
    #navbar .container {
        padding-left: 22px;
        padding-right: 22px;
    }

    .udent-section-axis {
        padding-left: 22px;
        padding-right: 22px;
    }

    .udent-intro-section__image {
        min-height: auto;
        max-height: none;
    }

    .udent-home-hero__content {
        bottom: 1.15rem;
    }

    .udent-home-hero__copy {
        margin-left: 0;
    }

    .udent-home-hero__title {
        font-size: clamp(1rem, 5vw, 1.35rem);
        margin-bottom: 0.35rem !important;
        white-space: normal;
    }

    .udent-home-hero__text {
        max-width: 92%;
        font-size: 0.72rem;
        line-height: 1.25;
    }
}

.udent-specialties-section {
    position: relative;
    --udent-specialties-white-band: 3.1rem;
    background: var(--udent-blue);
    overflow: hidden;
    padding: clamp(3.2rem, 5.4vw, 4.85rem) 0 0;
}

.udent-specialties-section::before {
    content: "";
    position: absolute;
    width: 450px;
    height: 450px;
    right: clamp(-0.5rem, 6vw, 5.25rem);
    top: -74px;
    border-radius: 50%;
    background-color: rgba(93, 180, 255, 0.24);
    pointer-events: none;
}

.udent-specialties-section::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: var(--udent-specialties-white-band);
    background: #ffffff;
    pointer-events: none;
}

.udent-specialties-section .container {
    position: relative;
    z-index: 2;
}

.udent-specialties-section .row {
    align-items: center !important;
}

.udent-specialties-section__media {
    position: relative;
}

.udent-specialties-section__media::after {
    content: "";
    position: absolute;
    width: 48px;
    height: 136px;
    right: -16px;
    top: -2.8rem;
    background-image: radial-gradient(rgba(255, 255, 255, 0.86) 1.2px, transparent 1.4px);
    background-size: 12px 12px;
    pointer-events: none;
    z-index: -1;
}

.udent-specialties-section__copy {
    padding: 0 0 calc(var(--udent-specialties-white-band) + 1.35rem);
    transform: translateY(-1.35rem);
}

.udent-specialties-section__title {
    font-size: clamp(1.1rem, 1.8vw, 1.35rem);
    letter-spacing: 0.02em;
}

.udent-specialties-section__subtitle {
    font-size: 0.68rem;
}

.udent-specialties-section__text {
    max-width: 560px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.72rem;
    line-height: 1.65;
}

.udent-specialties-section__image {
    position: relative;
    z-index: 1;
    width: min(100%, 448px);
    margin-bottom: -0.55rem;
    transform: translateX(2rem);
}

@media (max-width: 991.98px) {
    .udent-specialties-section {
        --udent-specialties-white-band: 2.75rem;
        padding: 3.35rem 0 0;
    }

    .udent-specialties-section::before {
        width: 330px;
        height: 330px;
        right: -92px;
        top: auto;
        bottom: 0.5rem;
    }

    .udent-specialties-section::after {
        display: block;
    }

    .udent-specialties-section__media::after {
        display: none;
    }

    .udent-specialties-section__copy {
        padding: 0 0 1rem;
        transform: none;
    }

    .udent-specialties-section__image {
        width: min(76vw, 330px);
        margin-bottom: -0.5rem;
        transform: none;
    }
}

.udent-rehab-section {
    padding: clamp(3.25rem, 5.2vw, 4.85rem) 0 clamp(3.6rem, 5.8vw, 5.35rem);
}

.udent-detail-section__title {
    font-size: clamp(1.35rem, 2vw, 1.65rem);
    letter-spacing: 0.02em;
    line-height: 1.15;
}

.udent-rehab-section__title {
    color: var(--udent-blue-text);
}

.udent-rehab-section__lead {
    max-width: 940px;
    margin-bottom: clamp(2.25rem, 4vw, 3.5rem) !important;
    color: var(--udent-blue-text);
    font-size: 0.82rem;
    line-height: 1.65;
}

.udent-rehab-section__slide {
    padding-top: 0.45rem;
}

.udent-rehab-section__media {
    flex: 0 0 315px;
    width: 315px;
}

.udent-rehab-section__doctor {
    width: 315px;
    object-fit: cover;
}

.udent-rehab-section__card-column {
    padding-left: 0 !important;
}

.udent-rehab-section__card {
    margin-top: 5rem;
    margin-left: -22px;
    padding: clamp(2rem, 3vw, 2.65rem) clamp(2.15rem, 3.3vw, 3rem);
    background-color: var(--udent-card-bg);
}

.udent-rehab-section__card--featured {
    margin-top: 3.65rem;
    padding-top: 1.55rem;
    padding-bottom: 1.55rem;
}

.udent-rehab-section__text {
    color: var(--udent-blue-text);
    font-size: 0.78rem;
    line-height: 1.72;
}

.udent-rehab-section__indicators [data-bs-target] {
    width: 10px;
    height: 10px;
    border: 0;
    opacity: 0.35;
}

.udent-rehab-section__indicators .active {
    opacity: 1;
}

@media (max-width: 767.98px) {
    .udent-intro-section {
        padding: 2.75rem 0;
    }

    .udent-rehab-section {
        padding: 2.85rem 0 3rem;
    }

    .udent-rehab-section__doctor {
        width: min(78vw, 300px);
    }

    .udent-rehab-section__media {
        flex: 0 0 auto;
        width: 100%;
    }

    .udent-rehab-section__card-column {
        padding-left: calc(var(--bs-gutter-x) * .5) !important;
    }

    .udent-rehab-section__card {
        margin-top: 0;
        margin-left: 0;
        padding: 1.5rem;
    }
}

.udent-surgery-section {
    background-color: var(--udent-blue);
    padding: clamp(3.25rem, 5.2vw, 4.85rem) 0 clamp(3.6rem, 5.8vw, 5.35rem);
}

.udent-surgery-section__text {
    max-width: 900px;
    font-size: 0.78rem;
    line-height: 1.7;
}

.udent-surgery-section__card {
    margin-right: -22px;
    padding: clamp(2rem, 3vw, 2.65rem) clamp(2.15rem, 3.3vw, 3rem);
    color: var(--udent-blue-text);
    position: relative;
    z-index: 1;
}

.udent-surgery-section__card-text {
    font-size: 0.78rem;
    line-height: 1.72;
}

.udent-surgery-section__media {
    flex: 0 0 330px;
    width: 330px;
    position: relative;
    z-index: 2;
}

.udent-surgery-section__media img {
    width: 330px;
}

@media (max-width: 991.98px) {
    .udent-surgery-section__card {
        margin-right: 0;
    }
}

@media (max-width: 767.98px) {
    .udent-surgery-section {
        padding: 2.85rem 0 3rem;
    }

    .udent-surgery-section__card {
        padding: 1.5rem;
    }

    .udent-surgery-section__media {
        flex: 0 0 auto;
        width: 100%;
        padding-left: calc(var(--bs-gutter-x) * .5) !important;
    }

    .udent-surgery-section__media img {
        width: min(78vw, 300px);
    }
}

.udent-ortho-section {
    border-color: var(--udent-blue) !important;
    padding: clamp(3.65rem, 5.6vw, 5.25rem) 0 clamp(4.25rem, 6vw, 5.85rem);
}

.udent-ortho-section__title {
    color: var(--udent-blue-text);
}

.udent-ortho-section__lead {
    max-width: 900px;
    margin-bottom: clamp(1.65rem, 3vw, 2.5rem) !important;
    color: var(--udent-blue-text);
    font-size: 0.64rem;
    line-height: 1.55;
}

.udent-ortho-section__layout {
    margin-top: 1.15rem;
}

.udent-ortho-section__media {
    flex: 0 0 305px;
    width: 305px;
    position: relative;
    z-index: 2;
}

.udent-ortho-section__image {
    display: block;
    width: 305px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 1.35rem;
}

.udent-ortho-section__card-column {
    padding-left: 0 !important;
}

.udent-ortho-section__card {
    margin-left: -16px;
    padding: clamp(2.75rem, 4vw, 4rem) clamp(2.5rem, 4vw, 3.75rem) clamp(2.75rem, 4vw, 3.85rem);
    background-color: var(--udent-card-bg);
    border-radius: 0.75rem;
}

.udent-ortho-section__text {
    color: var(--udent-blue-text);
    font-size: 0.68rem;
    line-height: 1.65;
}

@media (max-width: 767.98px) {
    .udent-ortho-section {
        padding: 3rem 0 3.45rem;
    }

    .udent-ortho-section__lead {
        font-size: 0.72rem;
    }

    .udent-ortho-section__layout {
        margin-top: 0.35rem;
    }

    .udent-ortho-section__image {
        width: min(100%, 305px);
        margin: 0 auto;
    }

    .udent-ortho-section__media {
        flex: 0 0 auto;
        width: 100%;
        text-align: center;
    }

    .udent-ortho-section__card-column {
        padding-left: calc(var(--bs-gutter-x) * .5) !important;
    }

    .udent-ortho-section__card {
        margin-top: 0;
        margin-left: 0;
        padding: 1.5rem;
    }

    .udent-ortho-section__text {
        font-size: 0.74rem;
    }
}

.udent-about-us-section {
    background-color: var(--udent-blue);
    padding: clamp(3.25rem, 5.2vw, 4.85rem) 0 clamp(3.6rem, 5.8vw, 5.35rem);
}

.udent-about-us-section__lead {
    max-width: 900px;
    font-size: 0.82rem;
    line-height: 1.65;
}

.udent-about-us-section__content {
    margin-top: clamp(1.5rem, 3vw, 2.4rem);
}

.udent-about-us-section__items,
#carouselNosotros,
.udent-about-us-section__carousel,
.udent-about-us-section__carousel .carousel-item,
.udent-about-us-section__image {
    height: 100%;
}

.udent-about-us-section__item {
    padding: 1.12rem 1.25rem;
}

.udent-about-us-section__icon {
    width: 46px;
}

.udent-about-us-section__item-title {
    color: var(--udent-blue-text);
    font-size: 0.92rem;
}

.udent-about-us-section__item-text {
    color: var(--udent-blue-text);
    font-size: 0.76rem;
    line-height: 1.4;
}

.udent-about-us-section__carousel-column {
    display: flex;
    align-items: stretch;
    margin-left: 2.25rem;
}

#carouselNosotros {
    height: 100%;
    width: min(100%, 352px);
}

.udent-about-us-section__carousel {
    width: 100%;
    height: 100%;
}

.udent-about-us-section__image {
    display: block;
    width: 100%;
    aspect-ratio: 2 / 3;
    height: 100%;
    object-fit: cover;
}

#carouselNosotros .carousel-control-prev,
#carouselNosotros .carousel-control-next {
    width: 2.4rem;
    opacity: 1;
}

#carouselNosotros .carousel-control-prev-icon,
#carouselNosotros .carousel-control-next-icon {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background-color: rgba(79, 141, 255, 0.95);
    background-size: 58% 58%;
}

@media (max-width: 767.98px) {
    .udent-about-us-section {
        padding: 2.85rem 0 3rem;
    }

    .udent-about-us-section__carousel {
        width: 100%;
        height: auto;
        margin: 0;
    }

    .udent-about-us-section__items,
    #carouselNosotros,
    .udent-about-us-section__carousel .carousel-item,
    .udent-about-us-section__image {
        height: auto;
    }

    .udent-about-us-section__image {
        aspect-ratio: 2 / 3;
    }

    .udent-about-us-section__carousel-column {
        margin-left: 0;
    }

    #carouselNosotros {
        width: 100%;
    }
}

.hero-section {
    --hero-surface: #ffffff;
    background-color: var(--hero-surface) !important;
    padding-top: 5rem; /* Más aire arriba */
}

.hero-badge {
    display: inline-flex;
    border: 2px solid #00A099;
    color: #00A099;
    padding: 0.42rem 1rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-bottom: 2.25rem; /* Espacio entre badge y título */
}

.hero-title {
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 0.95;
    font-weight: 800;
    text-transform: uppercase;
    color: #00A099;
    margin-bottom: 1.5rem;
}

.hero-text {
    max-width: 520px;
    color: #00A099;
    font-size: 0.9rem;
    line-height: 1.7;
}

.hero-buttons {
    align-items: center;
    margin-bottom: 2.5rem;
}

.btn-hero-primary,
.btn-hero-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.35rem 1rem;
    min-height: 2.2rem;
    text-decoration: none;
}

.btn-hero-primary {
    background-color: #00A099;
    color: #ffffff;
    border: 1px solid transparent;
    box-shadow: 0 10px 25px rgba(0, 160, 153, 0.18);
}

.btn-hero-primary:hover {
    background-color: #008f87;
    color: #ffffff;
    text-decoration: none;
}

.btn-hero-secondary {
    background-color: #ffffff;
    color: #ff6b2b;
    border: 1px solid #ff6b2b;
    box-shadow: inset 0 0 0 1px rgba(255, 107, 43, 0.15);
}

.btn-hero-secondary:hover {
    background-color: #ff6b2b;
    color: #ffffff;
    text-decoration: none;
}

.ratio-4x5 {
    --bs-aspect-ratio: calc(5 / 4 * 100%);
}

.hero-main-image {
    border-radius: 0;
    box-shadow: none;
    background-color: var(--hero-surface);
    overflow: hidden;
    width: 80%;
    max-width: none;
    margin-left: auto; /* Alinear al margen derecho */
}

.hero-main-image img {
    object-fit: cover;
    border-radius: inherit;
}

.hero-bottom-image {
    border-radius: 2rem;
    overflow: hidden;
    height: 100%;
}

.hero-bottom-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-stats {
    gap: 1.5rem;
    width: 100%;
}

.hero-stats .display-4 {
    font-size: clamp(2rem, 3vw, 2.4rem);
    line-height: 0.95;
    color: #ff6b2b !important;
}

.hero-stats .text-warning {
    color: #ff6b2b !important;
}

.hero-stats .text-info-emphasis {
    max-width: none;
    font-size: 0.8rem;
    line-height: 1.35;
    color: #00A099 !important;
}

@media (min-width: 768px) {
    .hero-bottom-image-col {
        flex: 0 0 52%;
        max-width: 52%;
    }

    .hero-bottom-stats-col {
        flex: 0 0 48%;
        max-width: 48%;
        align-self: flex-start;
        transform: translateX(1rem);
    }

    .hero-bottom-image {
        min-height: 240px;
    }
}

@media (min-width: 992px) {
    .hero-text {
        max-width: 560px;
    }

    .hero-bottom-image-col {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .hero-bottom-stats-col {
        flex: 0 0 50%;
        max-width: 50%;
        align-self: flex-start;
        transform: translateX(1.5rem);
    }

    .hero-bottom-image {
        min-height: 280px;
    }
}


.btn-close{
    color: rgb(255,255,255,1);
    opacity: 1;
    font-size: 1.8em;
}

.close-menu-movil{
    filter: invert(1) grayscale(100%) brightness(200%);
}



.modal-menu li {
    margin: 20px 0;
}

.modal-menu a {
    color: rgba(13,61,97,1);
    font-size: 1.5rem;
    text-decoration: none;
}


.menu-movil li a {
  font-family: var(--site-font-sans);
  color: rgba(255,255,255,1);
  font-size: 1.5em;
  font-weight: 500;
}

.menu-movil li a.active {
  font-weight: 700;
  color: #ffffff;
}


.modal-menu-movil {
  background-color: var(--udent-blue);
}

.modal-menu-movil .modal-dialog {
  margin-left: auto;
}

.modal-menu-movil.fade .modal-dialog {
  transform: translateX(100%);
  transition: transform .32s ease;
}

.modal-menu-movil.show .modal-dialog {
  transform: translateX(0);
}


/* 🔹 Hace que el modal sea pantalla completa, sin márgenes */
.modal-dialog {
  margin: 0;
  max-width: 100%;
  height: 100%;
}

/* 🔹 Elimina el “card” blanco del modal */
.modal-content {
  background: var(--udent-blue) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  height: 100%;
  padding: 0;
}

.modal-menu-movil .modal-header,
.modal-menu-movil .modal-body,
.modal-menu-movil .modal-content,
.modal-menu-movil .modal-dialog {
  background-color: var(--udent-blue) !important;
}

.menu-movil {
  background-color: var(--udent-blue) !important;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* 🔹 Cuerpo interno sin márgenes */
.menu-movil .modal-body {
  flex: 1;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.menu-movil-direccion {
  margin-top: .8rem;
  padding: 0 .5rem;
  color: rgba(255,255,255,.88);
  font-size: .72rem;
  line-height: 1.35;
}

.menu-movil-sociales {
  margin-top: .45rem;
}

.menu-movil-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  text-decoration: none;
}

.menu-movil-social-link img {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.btn-brown {
  background-color: rgba(13,61,97,1);
  color:white;
}


.btn-asesor{
    background-color: rgba(13,61,97,1);
    color: rgba(255,255,255);
    border-radius: 10px !important;
    display: inline-block;
    font-weight: 600;
    line-height: 1.5;
    text-decoration: none;
    cursor: pointer;
    padding: 10px 50px;
}

.btn-asesor:hover{
    background-color: rgba(13,61,97,1);
    color: rgba(255,255,255);
    border-radius: 10px !important;
    display: inline-block;
    font-weight: 600;
    line-height: 1.5;
    text-decoration: none;
    cursor: pointer;
    padding: 10px 50px;
}



.btn-ver:hover{
    background: rgba(18,13,64,1);
    color: rgba(255,255,255);
    border-radius: 10px !important;
    display: inline-block;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    padding: 10px 50px;
}

.samar-action {
    position: relative;
    z-index: 1;
    display: inline-block;
    overflow: hidden;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: .375rem .75rem;
    font-size: 1rem;
    border-radius: .25rem;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.samar-action:hover {
    color: #212529;
    text-decoration: none;
}

.samar-action:focus {
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(13, 110, 253, .25);
}

.samar-action.disabled,
.samar-action:disabled,
fieldset:disabled .samar-action {
    pointer-events: none;
    opacity: .65;
}

.input-group .samar-action {
    position: relative;
    z-index: 2;
}

.input-group .samar-action:focus {
    z-index: 3;
}


.whatsapp-float {
	position: fixed;
	z-index: 99;
	bottom: 20px;
	right: 20px;
	transition: all 300ms ease 0ms;
}


.whatsapp-float p {
	font-weight: 700;
	padding: 2px 10px;
	border-radius: 10px;
	margin-top: 10px;
	background: rgba(0, 192, 75, 1);
}

.whatsapp-float:hover {
	box-shadow: 0px 15px 20px rgba(42, 183, 84, 0.3);
	transform: translateY(-7px);
}



  /* Botón tipo pastilla con hover SIN crecer ni moverse */
  .hero-link {
    border-width: 2px;
    background-color: transparent;
    color: #ffffff;
    transition: background-color .2s ease, color .2s ease, border-color .2s ease;
  }

  .hero-link:hover {
    background-color: #ffffff;   /* se rellena blanco */
    color: #000000;              /* texto oscuro */
    border-color: #ffffff;
    text-decoration: none;       /* sin subrayado en hover */
  }

  .hero-link:focus,
  .hero-link:active {
    box-shadow: none;            /* sin halo raro */
  }


/* Eje compartido de header + hero + respaldamos */
:root {
    --layout-axis: 12px;
}

@media (min-width: 576px) {
    :root {
        --layout-axis: calc((100vw - 540px) / 2 + 12px);
    }
}

@media (min-width: 768px) {
    :root {
        --layout-axis: calc((100vw - 720px) / 2 + 12px);
    }
}

@media (min-width: 992px) {
    :root {
        --layout-axis: calc((100vw - 960px) / 2 + 12px);
    }
}

@media (min-width: 1200px) {
    :root {
        --layout-axis: calc((100vw - 1140px) / 2 + 12px);
    }
}

@media (min-width: 1400px) {
    :root {
        --layout-axis: calc((100vw - 1320px) / 2 + 12px);
    }
}

.site-content-shell,
.home-section-shell {
    width: 100%;
    padding-left: max(12px, var(--layout-axis));
    padding-right: max(12px, var(--layout-axis));
}

.hero-copy-wrap {
    width: 100%;
    padding-left: max(12px, var(--layout-axis));
    padding-right: max(12px, var(--layout-axis));
}

.packages-content-shell {
    width: 100%;
    max-width: 1220px;
    margin-right: auto;
}

@media (min-width: 992px) {
    .hero-copy-wrap {
        padding-right: clamp(1.5rem, 3vw, 4rem);
    }
}

@media (max-width: 575.98px) {
    .hero-copy-wrap {
        padding-top: 2rem !important;
    }
}

.hero-mayorista-panel {
    justify-content: flex-start !important;
}

.hero-mayorista-content {
    width: 100%;
    max-width: 290px;
    margin-left: clamp(26px, var(--layout-axis), 180px);
    margin-right: 0;
    text-align: left !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.hero-mayorista-logo {
    display: block;
}

/* Seccion respaldamos mayoristas */
.mayoristas-section {
    background: #1556bf;
    color: #ffffff;
    font-family: var(--site-font-sans);
    position: relative;
    overflow: visible;
    margin-top: 0;
    z-index: 2;
}

.mayoristas-top {
    position: relative;
    z-index: 4;
    padding-top: 8px;
}

.mayoristas-brand {
    display: flex;
    align-items: center;
    min-height: 118px;
    padding: 30px 26px 20px clamp(26px, var(--layout-axis), 180px);
}

.mayoristas-brand-inner {
    display: flex;
    align-items: center;
    gap: 14px;
    width: 100%;
    max-width: 290px;
}

.mayoristas-brand-icon {
    width: 58px;
    max-width: 58px;
    flex-shrink: 0;
}

.mayoristas-brand-copy {
    line-height: 0.92;
}

.mayoristas-brand-title {
    font-size: 1.38rem;
    font-weight: 800;
    letter-spacing: 0.2px;
}

.mayoristas-brand-subtitle {
    font-size: 1.74rem;
    font-weight: 900;
    letter-spacing: 0.2px;
}

.mayoristas-brand-note {
    margin-top: 5px;
    font-size: 0.4rem;
    font-weight: 600;
    letter-spacing: 1.15px;
}

.mayoristas-card-col {
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
    padding: 0 26px 0 18px;
    position: relative;
    z-index: 5;
}

.mayoristas-card {
    width: 100%;
    max-width: 540px;
    min-height: 168px;
    padding: 24px 30px 26px;
    margin-top: -78px;
    margin-bottom: -20px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 28px;
    background: linear-gradient(
        to bottom,
        rgba(255, 255, 255, 0.26) 0%,
        rgba(255, 255, 255, 0.14) 24%,
        rgba(255, 255, 255, 0.05) 100%
    );
    box-shadow:
        0 18px 42px rgba(10, 39, 94, 0.24),
        inset 0 10px 18px rgba(255, 255, 255, 0.1);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    position: relative;
    z-index: 6;
}

.mayoristas-card-title {
    font-size: 3.05rem;
    line-height: 0.86;
    font-weight: 900;
    letter-spacing: 0.45px;
}

.mayoristas-card-copy {
    margin-top: 10px;
    font-size: 0.72rem;
    line-height: 1.38;
    letter-spacing: 0.52px;
    font-weight: 600;
}

.mayoristas-card-actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.mayoristas-card-btn {
    border: 1px solid rgba(255, 255, 255, 0.55);
    border-radius: 7px;
    color: #ffffff;
    background: transparent;
    font-size: 0.74rem;
    line-height: 1;
    font-weight: 600;
    padding: 10px 18px;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.mayoristas-card-btn:hover {
    border-color: rgba(255, 255, 255, 0.95);
    background-color: rgba(255, 255, 255, 0.95);
    color: #1556bf;
}

.mayoristas-card-btn:focus,
.mayoristas-card-btn:active {
    color: #ffffff;
    box-shadow: none;
}

.mayoristas-image-wrap {
    min-height: 165px;
    height: 100%;
    overflow: hidden;
    border-top-right-radius: 105px;
}

.mayoristas-image {
    width: 100%;
    height: 100%;
    min-height: 165px;
    display: block;
    object-fit: cover;
    object-position: center;
}

.mayoristas-stats {
    display: flex;
    align-items: center;
    background: #1556bf;
    min-height: 198px;
}

.mayoristas-stats-inner {
    --stat-copy-width: 248px;
    --stat-dot-size: 18px;
    --stat-gap: 8px;
    --stat-offset-x: 14px;
    width: 100%;
    max-width: 324px;
    margin-left: var(--stat-offset-x);
    padding: 26px 1rem 26px 1.75rem;
}

.mayoristas-stat-item {
    display: grid;
    width: 100%;
    max-width: calc(var(--stat-copy-width) + var(--stat-dot-size) + var(--stat-gap));
    grid-template-columns: var(--stat-copy-width) var(--stat-dot-size);
    column-gap: var(--stat-gap);
    align-items: start;
    text-transform: uppercase;
}

.mayoristas-stat-item + .mayoristas-stat-item {
    margin-top: 18px;
}

.mayoristas-stat-copy {
    width: var(--stat-copy-width);
}

.mayoristas-stat-title {
    display: block;
    width: 100%;
    font-size: 1.72rem;
    line-height: 0.9;
    font-weight: 900;
    letter-spacing: -0.18px;
    white-space: nowrap;
    text-align: left;
}

.mayoristas-stat-label {
    display: block;
    width: 100%;
    margin-top: 3px;
    font-size: 0.53rem;
    line-height: 1;
    letter-spacing: 0.3px;
    font-weight: 600;
    white-space: nowrap;
}

.mayoristas-stat-item--left .mayoristas-stat-label {
    font-size: 0.62rem;
    letter-spacing: 0.32px;
    text-align: right;
}

.mayoristas-stat-item--left .mayoristas-stat-copy {
    width: 206px;
    max-width: 100%;
}

.mayoristas-stat-item--left .mayoristas-stat-title {
    text-align: right;
}

.mayoristas-stat-item--right .mayoristas-stat-copy {
    width: max-content;
    max-width: 100%;
}

.mayoristas-stat-item--right .mayoristas-stat-title {
    width: auto;
}

.mayoristas-stat-item--right .mayoristas-stat-label {
    width: 100%;
    text-align: right;
}

.mayoristas-stat-dot {
    width: var(--stat-dot-size);
    height: var(--stat-dot-size);
    background: #e4b322;
    display: inline-block;
    justify-self: end;
    align-self: start;
    margin-top: 5px;
}

@media (min-width: 992px) {
    .mayoristas-image-col {
        flex: 0 0 61.5%;
        max-width: 61.5%;
    }

    .mayoristas-stats {
        flex: 0 0 38.5%;
        max-width: 38.5%;
    }
}

@media (max-width: 991.98px) {
    .hero-mayorista-panel {
        justify-content: center !important;
    }

    .hero-mayorista-content {
        margin: 0 auto;
        text-align: center !important;
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .hero-mayorista-logo {
        margin-left: auto;
        margin-right: auto;
    }

    .mayoristas-top {
        padding-top: 0;
    }

    .mayoristas-brand {
        min-height: auto;
        justify-content: center;
        padding: 24px 18px 12px;
    }

    .mayoristas-brand-inner {
        width: auto;
        max-width: 100%;
    }

    .mayoristas-card-col {
        justify-content: center;
        padding: 0 14px;
    }

    .mayoristas-card {
        max-width: 620px;
        margin-top: 0;
        margin-bottom: 0;
        border-radius: 14px;
        padding: 18px 20px 18px;
        min-height: auto;
        border: 1px solid rgba(255, 255, 255, 0.16);
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
        box-shadow: inset 0 10px 18px rgba(255, 255, 255, 0.1);
    }

    .mayoristas-card-title {
        font-size: 2.35rem;
    }

    .mayoristas-card-copy {
        margin-top: 8px;
        font-size: 0.66rem;
    }

    .mayoristas-card-btn {
        font-size: 0.68rem;
        padding: 9px 14px;
    }

    .mayoristas-image-wrap {
        margin-top: 14px;
        border-top-right-radius: 56px;
    }

    .mayoristas-stats-inner {
        --stat-copy-width: 232px;
        --stat-dot-size: 17px;
        --stat-gap: 8px;
        --stat-offset-x: 10px;
        max-width: 300px;
        margin: 0 auto 0 var(--stat-offset-x);
        padding: 24px 20px 26px 20px;
    }

    .mayoristas-stat-title {
        font-size: 1.58rem;
    }

    .mayoristas-stat-label {
        font-size: 0.5rem;
    }

    .mayoristas-stat-item--left .mayoristas-stat-label {
        font-size: 0.58rem;
    }

    .mayoristas-stat-item--left .mayoristas-stat-copy {
        width: 192px;
    }

    .mayoristas-stat-dot {
        margin-top: 4px;
    }
}

@media (max-width: 575.98px) {
    .mayoristas-brand-title {
        font-size: 1.12rem;
    }

    .mayoristas-brand-subtitle {
        font-size: 1.4rem;
    }

    .mayoristas-brand-note {
        font-size: 0.46rem;
        letter-spacing: 0.8px;
    }

    .mayoristas-card-title {
        font-size: 2rem;
    }

    .mayoristas-card-copy {
        font-size: 0.62rem;
        line-height: 1.34;
    }

    .mayoristas-card-btn {
        font-size: 0.62rem;
        padding: 8px 12px;
    }

    .mayoristas-stats {
        min-height: 176px;
    }

    .mayoristas-stats-inner {
        --stat-copy-width: 204px;
        --stat-dot-size: 16px;
        --stat-gap: 10px;
        --stat-offset-x: 8px;
        max-width: 268px;
        margin: 0 auto;
        padding: 22px 18px 24px;
    }

    .mayoristas-stat-item {
        width: 100%;
        max-width: calc(var(--stat-copy-width) + var(--stat-dot-size) + var(--stat-gap));
        grid-template-columns: var(--stat-copy-width) var(--stat-dot-size);
        justify-content: center;
        align-items: start;
        column-gap: var(--stat-gap);
        margin-left: auto;
        margin-right: auto;
    }

    .mayoristas-stat-copy,
    .mayoristas-stat-item--left .mayoristas-stat-copy,
    .mayoristas-stat-item--right .mayoristas-stat-copy {
        width: var(--stat-copy-width);
        max-width: 100%;
        text-align: left;
    }

    .mayoristas-stat-item + .mayoristas-stat-item {
        margin-top: 14px;
    }

    .mayoristas-stat-title {
        font-size: 1.3rem;
        text-align: left;
    }

    .mayoristas-stat-label {
        font-size: 0.45rem;
        letter-spacing: 0.28px;
        text-align: left;
    }

    .mayoristas-stat-item--left .mayoristas-stat-label {
        font-size: 0.5rem;
    }

    .mayoristas-stat-item--left .mayoristas-stat-copy {
        width: 170px;
    }

    .mayoristas-stat-item--left .mayoristas-stat-title,
    .mayoristas-stat-item--left .mayoristas-stat-label {
        text-align: right;
    }

    .mayoristas-stat-item--right .mayoristas-stat-copy {
        width: max-content;
        max-width: 100%;
    }

    .mayoristas-stat-item--right .mayoristas-stat-title {
        width: auto;
    }

    .mayoristas-stat-item--right .mayoristas-stat-label {
        width: 100%;
        text-align: right;
    }

    .mayoristas-stat-dot {
        justify-self: end;
        align-self: start;
        margin-top: 3px;
    }
}

/* Seccion somos una fabrica */
.somos-fabrica-section {
    background: linear-gradient(90deg, #2d68ce 0%, #245fc4 100%);
    font-family: var(--site-font-sans);
    overflow: hidden;
    position: relative;
}

.somos-fabrica-row {
    min-height: auto;
}

.somos-fabrica-copy-col {
    min-height: auto;
    padding: 16px 22px 18px 28px;
    flex: 0 0 100%;
    max-width: 100%;
}

.somos-fabrica-card {
    position: relative;
    width: 100%;
    max-width: 560px;
    margin-left: 0;
    padding: 38px 42px 34px 42px;
    aspect-ratio: 781 / 474;
    min-height: 0;
    border-radius: 0;
    border: 0;
    overflow: visible;
    isolation: isolate;
    background: none;
    box-shadow: none;
}

.somos-fabrica-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url("../../app-assets/images/card-quienes-somos.png") center / 100% 100% no-repeat;
    z-index: 0;
}

.somos-fabrica-kicker {
    font-size: 0.68rem;
    line-height: 1;
    letter-spacing: 0.8px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.92);
}

.somos-fabrica-title {
    margin: 10px 0 16px;
    font-size: clamp(1.7rem, 1.32rem + 1vw, 2.2rem);
    line-height: 0.92;
    letter-spacing: -0.8px;
    font-weight: 900;
    max-width: 500px;
}

.somos-fabrica-lead,
.somos-fabrica-copy {
    max-width: 420px;
    color: rgba(255, 255, 255, 0.96);
}

.somos-fabrica-lead {
    margin-bottom: 16px;
    font-size: 0.73rem;
    line-height: 1.38;
    font-weight: 500;
}

.somos-fabrica-copy {
    font-size: 0.73rem;
    line-height: 1.38;
    font-weight: 500;
}

.somos-fabrica-copy strong {
    font-weight: 700;
}

.somos-fabrica-icon-badge {
    position: absolute;
    top: 50%;
    right: -12px;
    transform: translateY(-50%);
    z-index: 4;
}

.somos-fabrica-icon {
    display: block;
    width: 54px;
    height: auto;
    filter: drop-shadow(0 10px 16px rgba(9, 42, 104, 0.18));
}

.somos-fabrica-image-col {
    min-height: 304px;
    display: flex;
}

.somos-fabrica-image-wrap {
    width: 100%;
    height: 100%;
    min-height: 304px;
    overflow: hidden;
    border-bottom-right-radius: 92px;
    flex: 1 1 auto;
}

.somos-fabrica-image {
    width: 100%;
    height: 100%;
    min-height: 304px;
    object-fit: cover;
    object-position: center;
    display: block;
}

@media (min-width: 992px) {
    .somos-fabrica-section {
        --header-align-offset: max(28px, calc((100vw - 960px) / 2 + 12px));
    }

    .somos-fabrica-copy-col {
        flex: 0 0 61.5%;
        max-width: 61.5%;
        padding-left: var(--header-align-offset);
        padding-right: 24px;
    }

    .somos-fabrica-image-col {
        flex: 0 0 38.5%;
        max-width: 38.5%;
    }

    .somos-fabrica-card {
        margin-left: 0;
    }
}

@media (min-width: 1200px) {
    .somos-fabrica-section {
        --header-align-offset: max(28px, calc((100vw - 1140px) / 2 + 12px));
    }
}

@media (min-width: 1400px) {
    .somos-fabrica-section {
        --header-align-offset: max(28px, calc((100vw - 1320px) / 2 + 12px));
    }
}

@media (max-width: 991.98px) {
    .somos-fabrica-row {
        min-height: auto;
    }

    .somos-fabrica-copy-col {
        min-height: auto;
        padding: 24px 20px 34px;
    }

    .somos-fabrica-card {
        max-width: min(540px, 100%);
        margin: 0 auto;
        padding: clamp(28px, 5vw, 34px) clamp(24px, 5vw, 30px) clamp(28px, 5vw, 30px);
    }

    .somos-fabrica-title {
        max-width: 100%;
        font-size: clamp(1.8rem, 5vw, 2.25rem);
    }

    .somos-fabrica-lead,
    .somos-fabrica-copy {
        max-width: 400px;
    }

    .somos-fabrica-image-col {
        min-height: 330px;
    }

    .somos-fabrica-image-wrap {
        min-height: 330px;
        border-bottom-right-radius: 72px;
    }

    .somos-fabrica-image {
        min-height: 330px;
    }

    .somos-fabrica-icon-badge-mobile {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%, -104%);
        z-index: 4;
    }

    .somos-fabrica-icon-badge-mobile .somos-fabrica-icon {
        width: 56px;
    }
}

@media (max-width: 575.98px) {
    .somos-fabrica-copy-col {
        padding: 18px 12px 28px;
    }

    .somos-fabrica-card {
        padding: 22px 20px;
        aspect-ratio: auto;
        min-height: clamp(220px, 65vw, 248px);
    }

    .somos-fabrica-kicker {
        font-size: 0.44rem;
    }

    .somos-fabrica-title {
        max-width: calc(100% - 60px);
        margin-top: 7px;
        margin-bottom: 10px;
        font-size: clamp(1.02rem, 5vw, 1.14rem);
        line-height: 0.96;
        letter-spacing: -0.38px;
    }

    .somos-fabrica-lead,
    .somos-fabrica-copy {
        max-width: calc(100% - 62px);
        font-size: clamp(0.48rem, 2vw, 0.54rem);
        line-height: 1.3;
    }

    .somos-fabrica-image-col {
        min-height: 280px;
    }

    .somos-fabrica-image-wrap {
        min-height: 280px;
        border-bottom-right-radius: 56px;
    }

    .somos-fabrica-image {
        min-height: 280px;
    }

    .somos-fabrica-icon-badge-mobile .somos-fabrica-icon {
        width: 48px;
    }
}

@media (max-width: 389.98px) {
    .somos-fabrica-copy-col {
        padding: 16px 10px 26px;
    }

    .somos-fabrica-card {
        padding: 20px 18px;
        min-height: clamp(228px, 72vw, 260px);
    }

    .somos-fabrica-kicker {
        font-size: 0.42rem;
    }

    .somos-fabrica-title {
        max-width: calc(100% - 52px);
        font-size: clamp(0.98rem, 5.3vw, 1.08rem);
    }

    .somos-fabrica-lead,
    .somos-fabrica-copy {
        max-width: calc(100% - 54px);
        font-size: clamp(0.46rem, 2.15vw, 0.5rem);
        line-height: 1.34;
    }

    .somos-fabrica-icon-badge-mobile .somos-fabrica-icon {
        width: 44px;
    }
}
  .site-action{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    font-family: inherit;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    background-color: transparent;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out, transform .15s ease-in-out;
  }

  .site-action:hover,
  .site-action:focus{
    text-decoration: none;
  }

  button.site-action{
    appearance: none;
  }

  .site-action,
  .btn-hero-primary,
  .btn-hero-secondary{
    min-width: 118px !important;
    height: 2.35rem !important;
    min-height: 2.35rem !important;
    padding: 0 1.15rem !important;
    border-radius: 999px !important;
    font-size: .78rem !important;
    line-height: 1 !important;
    box-sizing: border-box;
    white-space: nowrap !important;
  }

  .icon-box{
    width: 52px;
    height: 52px;
  }

  .service-icon-box{
    background-color: #ffffff;
  }

  .service-icon-box--orange{
    background-color: rgba(243, 108, 61, 0.10);
  }

  .service-icon-box--teal{
    background-color: rgba(31, 184, 178, 0.10);
  }

  .service-icon-box--purple{
    background-color: rgba(155, 89, 182, 0.10);
  }

  .service-card{
    flex-wrap: nowrap;
    transition: background-color .2s ease, box-shadow .2s ease, transform .2s ease;
  }

  .service-card:hover,
  .service-card:focus-within{
    background-color: #ef5a29 !important;
    box-shadow: 0 12px 24px rgba(239, 90, 41, .22) !important;
    transform: translateY(-2px);
  }

  .service-card:hover .service-title,
  .service-card:hover .service-text,
  .service-card:focus-within .service-title,
  .service-card:focus-within .service-text{
    color: #ffffff;
  }

  .service-card:hover .service-icon-box,
  .service-card:focus-within .service-icon-box{
    background-color: rgba(255, 255, 255, .18);
  }

  .service-copy{
    min-width: 0;
    flex: 1;
  }

  .service-icon-img{
    width: 28px;
    height: 28px;
    display: block;
    object-fit: contain;
    transition: filter .2s ease;
  }

  .service-card:hover .service-icon-img,
  .service-card:focus-within .service-icon-img{
    filter: brightness(0) invert(1);
  }

  .service-title{
    font-size: .82rem;
    letter-spacing: .02em;
    color: #00a7a0;
    line-height: 1.05;
    white-space: nowrap;
  }

  .service-text{
    font-size: .88rem;
    color: #8d3fb0;
    line-height: 1.2;
  }

  @media (max-width: 767.98px){
    .service-title{
      font-size: .8rem;
    }

    .service-text{
      font-size: .85rem;
    }
  }

body,
body button,
body input,
body select,
body textarea,
body optgroup,
body label,
body .btn,
body .nav-link,
body .dropdown-item,
body .form-control,
body .form-select,
body .form-check-label,
body .select2-container .select2-selection__rendered,
body .select2-container .select2-results__option,
body .select2-container .select2-search__field {
  font-family: var(--site-font-sans);
}

.doctors-platform-section {
  padding-top: clamp(3.25rem, 5vw, 4.5rem) !important;
  padding-bottom: clamp(4rem, 6vw, 5rem) !important;
}

.doctors-platform-detail {
  top: 50%;
  right: clamp(-28px, 2vw, 20px);
  bottom: auto;
  transform: translateY(-36%);
  opacity: .08;
  pointer-events: none;
}

.doctors-platform-row {
  --bs-gutter-x: clamp(1.5rem, 4vw, 4rem);
  --bs-gutter-y: 1.5rem;
  margin-bottom: clamp(2.75rem, 4vw, 4.5rem) !important;
}

.doctors-platform-copy {
  max-width: 360px;
  text-align: left;
}

.doctors-platform-title {
  margin: 0 0 1rem;
  color: #139e9d;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: -0.03em;
  white-space: nowrap;
}

.doctors-platform-lead {
  margin: 0 0 .85rem;
  color: #139e9d;
  font-size: clamp(.78rem, .95vw, .92rem);
  line-height: 1.35;
  font-weight: 600;
}

.doctors-platform-body {
  margin: 0 0 1.35rem;
  color: #52b7b3;
  font-size: clamp(.8rem, .92vw, .93rem);
  line-height: 1.55;
}

.doctors-platform-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.15rem;
  padding: .45rem 1.05rem;
  border-radius: 999px;
  border: 0;
  background: #139e9d;
  color: #ffffff;
  font-size: .75rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 10px 20px rgba(19, 158, 157, .12);
  transition: background-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.doctors-platform-btn:hover,
.doctors-platform-btn:focus {
  background: #0f8f8f;
  color: #ffffff;
  text-decoration: none;
  box-shadow: 0 14px 24px rgba(19, 158, 157, .18);
  transform: translateY(-1px);
}

.doctors-platform-media {
  width: 100%;
  max-width: clamp(360px, 38vw, 470px);
  margin-left: auto;
  margin-right: clamp(0px, 1.5vw, 18px);
}

.doctors-platform-image {
  width: 100%;
  display: block;
}

.udent-contact-section {
  padding-top: clamp(3.5rem, 5.8vw, 5.25rem) !important;
  padding-bottom: clamp(3.75rem, 6vw, 5.5rem) !important;
}

.udent-contact-section .row {
  --bs-gutter-x: clamp(2rem, 4vw, 4.5rem);
  --bs-gutter-y: 2.5rem;
}

.udent-clients-section {
  background-color: var(--udent-blue);
  padding-top: clamp(4.25rem, 6.6vw, 6.25rem);
  padding-bottom: clamp(4.25rem, 6.6vw, 6.25rem);
}

.udent-clients-section__intro {
  padding-left: 0;
}

.udent-clients-section__quote {
  margin-bottom: 1.25rem;
  color: rgba(255, 255, 255, .45);
  font-size: clamp(5.2rem, 8vw, 7rem);
  font-weight: 800;
  line-height: .58;
}

.udent-clients-section__eyebrow,
.udent-clients-section__title {
  color: #ffffff;
  line-height: 1.12;
}

.udent-clients-section__eyebrow {
  margin: 0 0 .18rem;
  font-size: clamp(1.55rem, 2.6vw, 2rem);
  font-weight: 300;
}

.udent-clients-section__title {
  margin: 0;
  font-size: clamp(1.7rem, 2.8vw, 2.25rem);
  font-weight: 800;
}

.udent-clients-section__viewport {
  width: calc(100% + 12vw);
  margin-right: -12vw;
  overflow: hidden;
  padding: 1.1rem 0 1.35rem;
}

.udent-clients-section__track {
  --udent-clients-gap: 3.35rem;
  --udent-clients-gap-half: 1.675rem;
  display: flex;
  width: max-content;
  gap: var(--udent-clients-gap);
  animation: udent-clients-marquee 34s linear infinite;
  will-change: transform;
}

.udent-clients-section__viewport:hover .udent-clients-section__track {
  animation-play-state: paused;
}

.udent-clients-section__item {
  flex: 0 0 360px;
  width: 360px;
}

.udent-clients-section__bubble {
  position: relative;
  display: flex;
  min-height: 180px;
  flex-direction: column;
  justify-content: center;
  border-radius: 1.25rem;
  background-color: #ffffff;
  padding: 2rem;
}

.udent-clients-section__bubble::after {
  position: absolute;
  bottom: -30px;
  left: 0;
  width: 52px;
  height: 52px;
  background-color: #ffffff;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  content: "";
}

.udent-clients-section__text {
  margin: 0 0 1rem;
  color: var(--udent-blue-text);
  font-size: .78rem;
  line-height: 1.75;
}

.udent-clients-section__stars {
  color: var(--udent-blue-text);
  font-size: .92rem;
  letter-spacing: 2px;
  line-height: 1;
}

.udent-clients-section__person {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-top: 1.55rem;
  margin-left: 2.7rem;
  color: #ffffff;
  font-size: .82rem;
  font-weight: 700;
}

.udent-clients-section__avatar {
  display: inline-flex;
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #ffffff;
  font-size: .82rem;
  font-weight: 800;
}

.udent-clients-section__avatar--green {
  background-color: #38d5b6;
}

.udent-clients-section__avatar--teal {
  background-color: #2fc0a8;
}

.udent-clients-section__avatar--mint {
  background-color: #66d8c7;
}

.udent-clients-section__avatar--blue {
  background-color: #4da3ff;
}

@keyframes udent-clients-marquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(calc(-50% - var(--udent-clients-gap-half)));
  }
}

@media (max-width: 991.98px) {
  .doctors-platform-copy {
    max-width: 100%;
  }

  .doctors-platform-title {
    white-space: normal;
  }

  .doctors-platform-media {
    max-width: 420px;
    margin-left: 0;
    margin-right: 0;
  }

  .udent-clients-section__viewport {
    width: calc(100% + 2rem);
    margin-right: -2rem;
  }
}

@media (max-width: 767.98px) {
  section.py-5 {
    padding-top: 2.75rem !important;
    padding-bottom: 2.75rem !important;
  }

  .udent-contact-section {
    padding-top: 3rem !important;
    padding-bottom: 3.25rem !important;
  }

  section.py-5 > .container,
  section.py-5 > .container-fluid,
  section.py-5 > .site-content-shell,
  section.py-5 > .home-section-shell,
  section.py-5 > .services-layout-shell,
  .services-hero-section > .services-layout-shell {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  .packages-content-shell,
  .services-layout-shell {
    max-width: 100% !important;
  }

  section.py-5 .mb-5 {
    margin-bottom: 2rem !important;
  }

  section.py-5 .g-4,
  section.py-5 .g-5 {
    --bs-gutter-y: 1.5rem;
  }

  section.py-5 img.img-fluid {
    max-width: 100%;
  }

  .udent-clients-section {
    padding-top: 3.35rem;
    padding-bottom: 3.35rem;
  }

  .udent-clients-section__track {
    --udent-clients-gap: 1.5rem;
    --udent-clients-gap-half: .75rem;
    animation-duration: 28s;
  }

  .udent-clients-section__item {
    flex-basis: min(82vw, 330px);
    width: min(82vw, 330px);
  }

  .udent-clients-section__bubble {
    min-height: 190px;
    padding: 1.65rem;
  }

  .udent-clients-section__person {
    margin-left: 2.2rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .udent-clients-section__track {
    animation: none;
  }
}

.udent-home-hero__text,
.udent-intro-section p,
.udent-specialties-section__subtitle,
.udent-specialties-section__text,
.udent-rehab-section__lead,
.udent-rehab-section__text,
.udent-surgery-section__text,
.udent-surgery-section__card-text,
.udent-ortho-section__lead,
.udent-ortho-section__text,
.udent-about-us-section__lead,
.udent-about-us-section__item-text,
.udent-contact-section p,
.udent-clients-section__text,
#contacto p {
  font-size: var(--udent-paragraph-size) !important;
}
