@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
html{
    scroll-behavior: smooth;
}
:root{
    --color-azul: #0047ab;
    --color-blanco: #ffffff;
    --color-rosa: #db0482;
    --color-titulo: #E6F0FF;
    --color-titulo-alterno: #838689;
    --color-texto: #A0AEC0;
    --color-texto-alterno: #53ac59;
    --color-fondo-card: #ebf2f2;
    --color-fondo-secciones: rgb(13, 13, 41);
    --color-energia: rgb(4, 187, 204);
    --color-bienestar: rgb(61, 121, 217);
    --color-detalles: linear-gradient(90deg, rgb(4, 187, 204), rgb(61, 121, 217), rgb(124, 42, 232));;
    --header-height: 5rem;
    --normal-font-size: .938rem;
    --font-regular: 400;
    --font-bold: 600;
    --z-tooltip: 10;
    --z-fixed: 100;
    --font-titulo: "Poppins", sans-serif;
    --font-texto: "Inter", sans-serif;
}
@media screen and (width >= 1024px){
    :root{
        --normal-font-size: 1rem;
    }
}
body::-webkit-scrollbar {
    width: 3px;
    height: 3px;
}
body::-webkit-scrollbar-track {
    background: var(--color-fondo-principal);
    height: 1px;
}  
body::-webkit-scrollbar-thumb {
    background-color: var(--color-verde-secundario);
    border-radius: 20px;
    border: 1px solid var(--color-verde-secundario);
}
a{
    text-decoration: none;
    font-family: var(--font-texto);
    color: var(--color-blanco);
}
ul{
    list-style-type: none;
    font-family: var(--font-texto);
}
li{
    color: var(--color-texto-secundario);
}
h1{
    font-family: var(--font-titulo);
    font-weight: 400;
    font-size: clamp(1rem, 1rem + 2vw, 2rem);
}
h3{
    font-family: var(--font-titulo);
    font-weight: 400;
    font-size: clamp(1rem, 1rem + 2vw, 2rem);
}
p{
    font-family: var(--font-texto);
    color: var(--color-texto-secundario);
    font-size: clamp(.8rem, .8rem + 2vw, 1.5rem);
}

.desktop{
    display: none;
}
.container{
    max-width: 1128px;
    margin-inline: 1.5rem;
}
.header{
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: var(--color-detalles);
    /* background: linear-gradient(90deg, rgb(4, 187, 204), rgb(61, 121, 217), rgb(124, 42, 232)); */
    z-index: var(--z-fixed);
    transition: 1s;
}
.nav{
    height: var(--header-height);
}
.nav_data{
    height: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.nav_logo{
    width: 150px;
    display: inline-flex;
    align-items: center;
    column-gap: .25rem;
}
.nav_logo img{
    width: 100%;
}
.nav_toggle{
    position: relative;
    width: 32px;
    height: 32px;
}
.nav_burger,
.nav_close{
    color: var(--color-blanco);
    position: absolute;
    width: max-content;
    height: max-content;
    inset: 0;
    margin: auto;
    font-size: 1.25rem;
    cursor: pointer;
    transition: opacity .1s, transform .4s;
}
.nav_close{
    opacity: 0;
}
@media screen and (width <= 1118px){
    .nav_menu{
        position: absolute;
        left: 0;
        top: 2.5rem;
        width: 100%;
        background-color: var(--color-pantone-azul);
        backdrop-filter: blur(30px);
        height: calc(65vh - 3.5rem);
        overflow: auto;
        pointer-events: none;
        opacity: 0;
        transition: top .4s, opacity .3s;
    }
    .nav_menu::-webkit-scrollbar{
        width: 0;
    }
    .nav_list{
        /* background-color: var(--color-principal); */
        box-shadow: 0 2px 16px var(--color-verde-secundario);
        /* padding-top: 1rem; */
    }
    .inicio{
        margin-top: 5rem;
    }
}
.nav_link{
    color: var(--color-blanco);
    padding: 1.25rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: background-color .3s;
    font-size: 1rem;
}
.nav_link:hover{
    color: var(--color-fondo-principal);
    background-color: var(--color-pantone-verde);
}
.show-menu{
    opacity: 1;
    top: 5rem;
    pointer-events: initial;
}
.show-icon .nav_burger{
    opacity: 0;
    transform: rotate(90deg);
}
.show-icon .nav_close{
    opacity: 1;
    transform: rotate(90deg);
}
@media screen and (width <= 340px){
    .container{
        margin-inline: 1rem;
    }
    .nav_link{
        padding: 1rem;
    }
}

.header_desktop{
    width: 100%;
    padding: 1.2rem 1.5rem;
    position: fixed;
    z-index: var(--z-fixed);
    transition: 1s;
    /* background: transparent; */
    background: linear-gradient(90deg, rgb(4, 187, 204), rgb(61, 121, 217), rgb(124, 42, 232));
}
.container_desktop{
    margin-inline: auto;
}
.nav_desktop{
    display: flex;
    justify-content: space-around;
    align-items: center;
}

.nav_list_desktop{
    height: 100%;
    display: flex;
    column-gap: 2rem;
}
.nav_data_desktop{
    width: 100px;
}
.nav_logo_desktop{
    width: 100%;
}
.nav_logo_desktop img{
    width: 100%;
}
.nav_link_desktop{
    color: var(--color-blanco);
    padding: .5rem;
    font-size: 1.2rem;
}
.nav_link_desktop:hover{
    border-bottom: 2px solid var(--color-pantone-verde);
}
.nav_contacto a{
    background-color: var(--color-pantone-verde);
    padding: 1rem;
    border-radius: 20px;
    color: var(--color-pantone-azul);
    transition: 1s;
    position: relative;
    overflow: hidden;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 130px;
}
.nav_contacto a::before{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    z-index: -1;
    background: var(--color-pantone-azul);
    transition: 1s;
}
.nav_contacto a:hover{
    background-color: var(--color-pantone-azul);
    color: var(--color-pantone-verde);
}
.nav_contacto a:hover::before{
    width: 100%;
}
.btn-login{
    background-color: var(--color-rosa);
    border: none;
    color: var(--color-blanco);
    padding: .5rem 1rem;
    border-radius: 20px;
}
@media screen and (width >= 1118px){
    .movil{
        display: none;
    }
    .desktop{
        display: block;
    }
    /* .slogan-inicio{
        left: 50%;
    } */
}

.inicio{
    /* background: radial-gradient(circle at center, #2e2e2e 0%, #161616 30%, #080808 65%, #000000 100%);
    box-shadow: inset 0 0 80px rgba(255,255,255,0.03); */
    width: 100%;
    height: 100vh;
    padding: 0;
    margin: 0;
    overflow: hidden;
}
.video-inicio{
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}
.video-inicio video{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.titulo{
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1000px;
    height: 80vh;
    margin: auto;
    align-items: center;
    justify-content: center;
    padding: 5rem 0;
    position: absolute;
    z-index: 1;
    top: 60%;
    transform: translateY(-50%);
}
.titulo h3{
    color: var(--color-blanco);
    font-size: clamp(.2rem, .2rem + 2vw, 1.25rem);
    align-items: center;
    justify-content: center;
    display: flex;
    gap: 10px;
    background-color: #db048154;
    border: 2px solid #db0482;
    border-radius: 20px;
    padding: .5rem 1rem;
}
.titulo i{
    font-size: .5rem;
}
.titulo h1{
    font-size: clamp(2rem, 2rem + 2vw, 15rem);
    text-align: center;
    max-width: 700px;
    margin: 3rem 0;
    color: var(--color-blanco);
}
.titulo h1 span{
    color: var(--color-rosa);
}
.titulo p{
    color: var(--color-texto);
    text-align: center;
}
.btn-inicio{
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 28px;
    margin-top: 3rem;
    width: 100%;
    max-width: 800px;
    align-items: center;
    justify-content: center;
}
.btn-productos,
.btn-distribuidor{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 15px 18px;
    border-radius: 999px;
    font-weight: 600;
    transition: 0.3s ease;
    width: 100%;
    max-width: 300px;
    font-size: clamp(.5rem, .5rem + 2vw, 1.2rem);
}
.btn-productos{
    background-color: var(--color-rosa);
    color: var(--color-blanco);
    box-shadow: 0 15px 40px #db048150;
}
.btn-productos:hover{
    background-color: #db048154;
    transform: translateY(-3px);
}
.btn-distribuidor{
    border: 1px solid var(--color-blanco);
    color: var(--color-blanco);
    background-color: transparent;
}
.btn-distribuidor:hover{
    border-color: var(--color-blanco);
    transform: translateY(-3px);
}

.contadores{
    background: var(--color-detalles);
    padding: 3em 2em;
    color: white;
    text-align: center;
}
.contadores > div{
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4em 2em;
}
.contador{
    position: relative;
}
.contador i{
    font-size: clamp(2.5rem, 2.5rem + 2vw, 3rem);;
}
.contador h1{
    font-size: 3em;
    font-weight: 400;
}
.contador h3{
    font-size: clamp(1rem, 1rem + 2vw, 1.75rem);
}
.contador:not(:last-child)::before{
    content: '';
    background-color: var(--color-blanco);
    position: absolute;
    width: 2px;
    height: 3em;
    top: 50%;
    transform: translateY(-50%);
    right: -1em;
}

@media screen and (width < 900px) and (width > 501px){
    .contadores > div{
        grid-template-columns: 1fr 1fr;
    }
    .contador:not(:last-child)::before{
        display: none;
    }
}
@media screen and (width < 500px){
    .contadores > div{
        grid-template-columns: 1fr;
        row-gap: 5em;
    }
    .contador:not(:last-child)::before{
        width: 90%;
        height: 2px;
        top: initial;
        right: initial;
        bottom: -3em;
        left: 50%;
        transform: translateX(-50%);
    }
}

.ofrecemos{
    width: 100%;
    padding: 8rem 1.5rem;
}
.titulo-ofrecemos{
    width: 100%;
    max-width: 1000px;
    margin: auto;
    display: flex;
    flex-direction: column;
    text-align: center;
}
.titulo-ofrecemos h4{
    font-size: clamp(1rem, 1rem + 2vw, 1.25rem);
    font-family: var(--font-texto);
    font-weight: 500;
    color: var(--color-texto-alterno);
}
.titulo-ofrecemos h1{
    font-size: clamp(2rem, 2rem + 2vw, 5rem);
    text-align: center;
    max-width: 700px;
    margin: 3rem auto;
    color: var(--color-titulo-alterno);
}
.titulo-ofrecemos h1 span{
    color: var(--color-rosa);
}
.titulo-ofrecemos p{
    color: var(--color-texto);
}
.cards{
    width: 100%;
    max-width: 1000px;
    margin: 3rem auto;
    padding: 2rem 1rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 15px;
}
.cards .card{
    border-radius: 10px;
    border: 2px solid var(--color-fondo-card);
    max-width: 300px;
}
.card .icono{
    width: 100%;
    padding: 2rem 0;
    text-align: center;
    background: var(--color-fondo-card);
    border-radius: 10px 10px 0 0;
}
.card .icono i{
    font-size: 3rem;
}
.energia{
    color: var(--color-energia);
}
.bienestar{
    color: var(--color-bienestar);
}
.nutricion{
    color: var(--color-texto-alterno);
}
.card .detalles{
    padding: 1rem;
}
.card .tag{
    background: var(--color-fondo-card);
    padding: .5rem 1rem;
    display: flex;
    width: 100px;
    justify-content: center;
    margin: 1rem 0;
    border-radius: 20px;
    font-family: var(--font-titulo);
}
.card h1{
    font-size: clamp(1rem, 1rem + 2vw, 1.5rem);
    margin: .5rem 0;
    color: var(--color-titulo-alterno);
    font-weight: 500;
}
.card p{
    font-size: clamp(.8rem, .8rem + 2vw, 1.1rem);
    color: var(--color-texto);
}
.btn-verMas{
    background: var(--color-detalles);
    display: flex;
    padding: .5rem 1rem;
    margin: 2rem 0 .5rem 0;
    text-align: center;
    justify-content: center;
    align-items: center;
    gap: 20px;
    border-radius: 20px;
    transition: .5s;
}
.btn-verMas:hover{
    transform: translateY(-3px);
    box-shadow: 0 10px 20px var(--color-bienestar);
}
.oportunidad{
    width: 100%;
    background: linear-gradient(45deg, rgb(35, 35, 114), rgb(13, 13, 41));
    /* background: var(--color-fondo-secciones); */
    padding: 8rem 1.5rem;
}
.cards-oportunidad{
    width: 100%;
    max-width: 1100px;
    display: flex;
    flex-wrap: wrap;
    gap: 25px;
    margin: 7rem auto;
    justify-content: center;
}
.card-oportunidad{
    width: 100%;
    max-width: 350px;
    transition: 1s;
    border-radius: 20px;
}
.card-oportunidad:hover{
    /* border: 1px solid var(--color-rosa); */
    transform: translateY(-3px);
    box-shadow: 0 15px 40px #db048150;
}
.card-oportunidad .numero{
    background-color: var(--color-rosa);
    width: 50px;
    height: 50px;
    border-radius: 50%;
    padding: 1rem;
    align-items: center;
    justify-content: center;
    display: flex;
    color: var(--color-blanco);
    margin: 2rem auto;
}
.card-oportunidad .detalles{
    text-align: center;
    padding: .5rem;
}
.card-oportunidad .detalles h1{
    color: var(--color-blanco);
    font-size: clamp(1rem, 1rem + 2vw, 1.5rem);
    margin-bottom: 1rem;
}
.card-oportunidad .detalles p{
    color: var(--color-texto);
    font-size: clamp(.8rem, .8rem + 2vw, 1.1rem);
}
.ingresos{
    width: 100%;
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--color-detalles);
    border-radius: 20px;
}
.ingresos .detalles-ingresos p{
    color: var(--color-blanco);
}
.ingresos .monto-ingresos{
    color: var(--color-blanco);
    text-align: center;
}
.mxn{
    color: var(--color-texto-alterno);
}

.porque{
    width: 100%;
    padding: 8rem 1.5rem;
}
.cards-porque{
    width: 100%;
    max-width: 1150px;
    display: flex;
    flex-wrap: wrap;
    margin: 5rem auto;
    gap: 25px;
}
.card-porque{
    width: 100%;
    max-width: 550px;
    display: flex;
    gap: 15px;
    border: 2px solid var(--color-fondo-card);
    padding: 1rem;
    border-radius: 20px;
}
.card-porque .icono-por{
    background: var(--color-fondo-card);
    width: 50px;
    height: 50px;
    padding: .5rem;
    align-items: center;
    justify-content: center;
    margin: auto;
    display: flex;
    font-size: 2rem;
    border-radius: 10px;
}

.card-porque .detalles-por h1{
    font-size: clamp(1rem, 1rem + 2vw, 1.5rem);
    color: var(--color-titulo-alterno);
    font-weight: 500;
}
.card-porque .detalles-por p{
    color: var(--color-texto);
    font-size: clamp(.8rem, .8rem + 2vw, 1.1rem);
}
.certificado{
    color: var(--color-texto-alterno);
}
.respaldo{
    color: var(--color-rosa);
}
.phone{
    color: var(--color-bienestar);
}
.user{
    color: var(--color-energia);
}

.testimonios{
    width: 100%;
    padding: 8rem 1.5rem;
    background: var(--color-fondo-card);
}
.cards-testimonios{
    width: 100%;
    max-width: 1200px;
    display: flex;
    flex-wrap: wrap;
    margin: 5rem auto;
    gap: 30px;
    justify-content: center;
}
.card-testimonios{
    width: 100%;
    max-width: 550px;
    padding: 1rem;
    background: var(--color-blanco);
    border-radius: 20px;
}
.card-testimonios .estrellas{
    color: var(--color-rosa);
    margin: 1rem 0;
}
.card-testimonios .detalles-testimonios p{
    color: var(--color-titulo-alterno);
    font-size: clamp(.8rem, .8rem + 2vw, 1.1rem);
    margin: 1rem;
    font-style: italic;
}
.usuario{
    display: flex;
    gap: 10px;
    align-items: center;
}
.nombre h1{
    color: var(--color-titulo-alterno);
    font-size: clamp(1rem, 1rem + 2vw, 1.5rem);
}
.nombre p{
    color: var(--color-texto);
    font-size: clamp(.8rem, .8rem + 2vw, 1.1rem);
}
.usuarioP{
    background: var(--color-rosa);
    padding: .5rem;
    color: var(--color-blanco);
    border-radius: 50%;
}
.usuarioS{
    background: var(--color-energia);
    padding: .5rem;
    color: var(--color-blanco);
    border-radius: 50%;
}
.usuarioT{
    background: var(--color-texto-alterno);
    padding: .5rem;
    color: var(--color-blanco);
    border-radius: 50%;
}
.usuarioC{
    background: var(--color-bienestar);
    padding: .5rem;
    color: var(--color-blanco);
    border-radius: 50%;
}
.preguntas{
    width: 100%;
    padding: 8rem 1.5rem;
}
.cards-preguntas{
    width: 100%;
    max-width: 1000px;
    padding: 3rem 1.5rem;
    margin: auto;
    display: flex;
    flex-wrap: wrap;
}
.card-preguntas{
    width: 100%;
    border: 2px solid var(--color-fondo-card);
    padding: 1rem;
    margin: 1rem 0;
    border-radius: 20px;
}
.card-preguntas h1{
    color: var(--color-bienestar);
    font-size: clamp(1rem, 1rem + 2vw, 1.5rem);
}
.card-preguntas span{
    color: var(--color-rosa);
}
.card-preguntas p{
    color: var(--color-texto);
    font-size: clamp(.8rem, .8rem + 2vw, 1.1rem);
}




@media screen and (width >= 997px){
    .titulo{
        transform: translateY(-50%) translateX(2%);
    }
}
@media screen and (width >= 1115px){
    .titulo{
        transform: translateY(-50%) translateX(5%);
    }
}
@media screen and (width >= 1200px){
    .titulo{
        transform: translateY(-50%) translateX(17%);
    }
}

@media screen and (width >= 1400px){
    .titulo{
        transform: translateY(-50%) translateX(38%);
    }
}
.login-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.login-modal.is-visible {
    display: flex;
}

.login-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(13, 13, 41, 0.74);
    backdrop-filter: blur(8px);
}

.login-modal__dialog {
    position: relative;
    width: min(420px, 100%);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 22px;
    background: linear-gradient(160deg, rgba(13, 13, 41, 0.98), rgba(35, 35, 114, 0.96));
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
    padding: 2rem;
    color: var(--color-blanco);
}

.login-modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    color: var(--color-blanco);
    cursor: pointer;
    font-size: 1.25rem;
}

.login-modal__logo {
    width: 116px;
    display: block;
    margin-bottom: 1rem;
}

.login-modal h2 {
    color: var(--color-blanco);
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.login-form {
    display: grid;
    gap: 1rem;
}

.login-form label {
    display: grid;
    gap: 0.45rem;
    font-family: var(--font-texto);
    color: var(--color-texto);
}

.login-form input {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-blanco);
    outline: none;
    padding: 0.9rem 1rem;
    font-size: 1rem;
}

.login-form input:focus {
    border-color: var(--color-rosa);
    box-shadow: 0 0 0 3px rgba(219, 4, 130, 0.18);
}

.login-form button[type="submit"] {
    border: 0;
    border-radius: 999px;
    background: var(--color-rosa);
    color: var(--color-blanco);
    cursor: pointer;
    font-weight: 800;
    padding: 0.95rem 1rem;
}

.login-message {
    min-height: 1.2rem;
    font-size: 0.9rem;
}

.login-message.is-error {
    color: #ffb4d9;
}

.login-message.is-ok {
    color: #9ff0c5;
}

.office-body {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 270px 1fr;
    background: #f6f8fb;
    color: #1f2937;
}

.office-sidebar {
    min-height: 100vh;
    background: linear-gradient(180deg, rgb(13, 13, 41), rgb(35, 35, 114));
    padding: 1.4rem;
}

.office-sidebar img {
    width: 140px;
    display: block;
    margin-bottom: 2rem;
}

.office-sidebar nav {
    display: grid;
    gap: 0.65rem;
}

.office-sidebar button {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: var(--color-blanco);
    cursor: pointer;
    font-weight: 700;
    padding: 0.85rem 1rem;
    text-align: left;
}

.office-sidebar button.is-active,
.office-sidebar button:hover {
    background: rgba(255, 255, 255, 0.12);
}

.office-main {
    padding: 1.5rem;
}

.office-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(13, 13, 41, 0.08);
    padding: 1.2rem;
}

.office-header span {
    color: var(--color-rosa);
    font-family: var(--font-texto);
    font-weight: 800;
}

.office-header h1 {
    color: #1f2937;
    font-size: 1.6rem;
    font-weight: 800;
}

.office-header button {
    border: 0;
    border-radius: 999px;
    background: var(--color-rosa);
    color: #ffffff;
    cursor: pointer;
    font-weight: 800;
    padding: 0.8rem 1rem;
}

.office-panel {
    margin-top: 1.5rem;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(13, 13, 41, 0.08);
    padding: 1.4rem;
}

.office-panel h2 {
    color: #1f2937;
    margin-bottom: 0.5rem;
}

.office-panel p {
    color: #6b7280;
    font-size: 1rem;
}

@media screen and (width < 820px) {
    .office-body {
        grid-template-columns: 1fr;
    }

    .office-sidebar {
        min-height: auto;
    }

    .office-header {
        align-items: flex-start;
        flex-direction: column;
    }
}

.office-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.office-panel-header span {
    color: var(--color-rosa);
    font-family: var(--font-texto);
    font-weight: 800;
    font-size: 0.9rem;
}

.office-panel-header h2 {
    margin: 0;
}

.office-panel-header button,
.office-form button[type="submit"] {
    border: 0;
    border-radius: 999px;
    background: var(--color-rosa);
    color: #ffffff;
    cursor: pointer;
    font-weight: 800;
    padding: 0.8rem 1rem;
}

.office-table-wrap {
    overflow-x: auto;
}

.office-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 760px;
    font-family: var(--font-texto);
}

.office-table th,
.office-table td {
    border-bottom: 1px solid #e5e7eb;
    padding: 0.85rem;
    text-align: left;
    font-size: 0.95rem;
}

.office-table th {
    background: #f8fafc;
    color: #475569;
    font-weight: 800;
}

.office-tag {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(219, 4, 130, 0.1);
    color: var(--color-rosa);
    font-weight: 800;
    padding: 0.35rem 0.65rem;
}

.office-actions {
    display: flex;
    gap: 0.5rem;
}

.office-actions button {
    border: 0;
    border-radius: 10px;
    background: rgb(61, 121, 217);
    color: #ffffff;
    cursor: pointer;
    font-weight: 800;
    padding: 0.55rem 0.75rem;
}

.office-actions button.is-danger {
    background: #dc2626;
}

.office-actions button:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.office-empty {
    color: #64748b;
    text-align: center !important;
    padding: 1.2rem !important;
}

.office-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.office-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(13, 13, 41, 0.72);
    backdrop-filter: blur(7px);
}

.office-modal__dialog {
    position: relative;
    width: min(520px, 100%);
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.3);
    padding: 1.4rem;
}

.office-modal__dialog h2 {
    color: #1f2937;
    font-weight: 800;
    margin-bottom: 1rem;
}

.office-modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: #f1f5f9;
    color: #334155;
    cursor: pointer;
    font-size: 1.25rem;
}

.office-form {
    display: grid;
    gap: 0.9rem;
}

.office-form label {
    display: grid;
    gap: 0.4rem;
    color: #475569;
    font-family: var(--font-texto);
    font-weight: 700;
}

.office-form input,
.office-form select {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    outline: none;
    padding: 0.8rem 0.9rem;
    font-size: 1rem;
}

.office-form input:focus,
.office-form select:focus {
    border-color: var(--color-rosa);
    box-shadow: 0 0 0 3px rgba(219, 4, 130, 0.12);
}

.office-form small {
    color: #64748b;
    font-weight: 500;
}

.office-message {
    min-height: 1.2rem;
    font-size: 0.92rem;
}

.office-message.is-error {
    color: #dc2626;
}

.office-message.is-ok {
    color: #16a34a;
}

@media screen and (width < 720px) {
    .office-panel-header {
        align-items: flex-start;
        flex-direction: column;
    }
}

.dashboard-module {
    display: grid;
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.dashboard-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(13, 13, 41, 0.08);
    padding: 1.4rem;
}

.dashboard-hero span,
.dashboard-summary__header h3 i {
    color: var(--color-rosa);
}

.dashboard-hero h2 {
    color: #1f2937;
    font-size: clamp(1.6rem, 2vw, 2.35rem);
    font-weight: 800;
    margin: 0.35rem 0;
}

.dashboard-hero p {
    color: #64748b;
    font-size: 1rem;
}

.dashboard-hero button,
.referral-link-box button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    border: 0;
    border-radius: 999px;
    background: var(--color-rosa);
    color: #ffffff;
    cursor: pointer;
    font-weight: 800;
    padding: 0.8rem 1rem;
    white-space: nowrap;
}

.dashboard-summary {
    border-radius: 18px;
    background: #fff7d8;
    border: 1px solid #fde68a;
    padding: 1.4rem;
}

.dashboard-summary__header h3 {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    color: #1f2937;
    font-size: 1.1rem;
    font-weight: 800;
    margin-bottom: 1rem;
}

.dashboard-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.dashboard-kpis article {
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 10px 24px rgba(13, 13, 41, 0.08);
    padding: 1rem;
    text-align: center;
}

.dashboard-kpis span {
    display: block;
    color: #64748b;
    font-family: var(--font-texto);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-kpis strong {
    display: block;
    color: #1f2937;
    font-family: var(--font-titulo);
    font-size: 1.45rem;
    font-weight: 800;
    margin-top: 0.5rem;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.dashboard-card {
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(13, 13, 41, 0.08);
    padding: 1.2rem;
}

.dashboard-card__icon {
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: #fff7d8;
    color: var(--color-rosa);
    font-size: 1.3rem;
    margin-bottom: 0.85rem;
}

.dashboard-card h3 {
    color: #1f2937;
    font-size: 1.1rem;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.dashboard-card p {
    color: #64748b;
    font-size: 0.95rem;
}

.referral-card {
    grid-column: span 3;
}

.referral-link-box {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.75rem;
    margin-top: 1rem;
}

.referral-link-box input {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 999px;
    background: #f8fafc;
    color: #334155;
    padding: 0.85rem 1rem;
    font-size: 0.95rem;
}

.referral-card small {
    display: block;
    min-height: 1.2rem;
    color: #16a34a;
    font-family: var(--font-texto);
    font-weight: 700;
    margin-top: 0.5rem;
}

.registro-body {
    min-height: 100vh;
    background: linear-gradient(135deg, rgb(13, 13, 41), rgb(35, 35, 114));
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.registro-shell {
    width: min(480px, 100%);
}

.registro-panel {
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.28);
    padding: 2rem;
}

.registro-panel img {
    width: 128px;
    display: block;
    margin-bottom: 1rem;
}

.registro-panel > span {
    color: var(--color-rosa);
    font-family: var(--font-texto);
    font-weight: 800;
}

.registro-panel h1 {
    color: #1f2937;
    font-size: 2rem;
    font-weight: 800;
    margin: 0.55rem 0;
}

.registro-panel p {
    color: #64748b;
    font-size: 1rem;
}

.registro-form {
    display: grid;
    gap: 0.9rem;
    margin-top: 1.3rem;
}

.registro-form label {
    display: grid;
    gap: 0.4rem;
    color: #475569;
    font-family: var(--font-texto);
    font-weight: 800;
}

.registro-form input {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 14px;
    outline: none;
    padding: 0.85rem 1rem;
    font-size: 1rem;
}

.registro-form input:focus {
    border-color: var(--color-rosa);
    box-shadow: 0 0 0 3px rgba(219, 4, 130, 0.12);
}

.registro-form button {
    border: 0;
    border-radius: 999px;
    background: var(--color-rosa);
    color: #ffffff;
    cursor: pointer;
    font-weight: 800;
    padding: 0.95rem 1rem;
}

.registro-message {
    min-height: 1.2rem;
    font-size: 0.92rem !important;
}

.registro-message.is-error {
    color: #dc2626;
}

.registro-message.is-ok {
    color: #16a34a;
}

@media screen and (width < 980px) {
    .dashboard-kpis,
    .dashboard-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .referral-card {
        grid-column: span 2;
    }
}

@media screen and (width < 680px) {
    .dashboard-hero,
    .office-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .dashboard-kpis,
    .dashboard-grid,
    .referral-link-box {
        grid-template-columns: 1fr;
    }

    .referral-card {
        grid-column: span 1;
    }
}

.dashboard-finance {
    gap: 1.25rem;
}

.dashboard-hero-compact {
    margin-bottom: 0;
}

.finance-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.finance-kpi {
    border: 1px solid #dbe3ef;
    border-top: 4px solid #1f73d8;
    border-radius: 12px;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
    padding: 1rem;
}

.finance-kpi span,
.finance-panel h3,
.withdraw-form span {
    color: #556985;
    font-family: var(--font-texto);
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.03em;
}

.finance-kpi strong {
    display: block;
    color: #050b28;
    font-family: var(--font-titulo);
    font-size: 1.8rem;
    font-weight: 900;
    line-height: 1.1;
    margin-top: 0.45rem;
}

.finance-kpi small {
    color: #4fbe76;
    font-family: var(--font-texto);
    font-weight: 700;
}

.finance-kpi.kpi-pink { border-top-color: #e22b8f; }
.finance-kpi.kpi-green { border-top-color: #51b878; }
.finance-kpi.kpi-orange { border-top-color: #ff8a00; }
.finance-kpi.kpi-orange small { color: #ff7300; }
.finance-kpi .kpi-status {
    display: inline-flex;
    width: auto;
    border-radius: 999px;
    background: #fff0d9;
    color: #ff7300;
    font-size: 0.9rem;
    padding: 0.35rem 0.7rem;
}

.dashboard-two-col {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.dashboard-wide-left {
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.85fr);
}

.dashboard-bottom-grid {
    grid-template-columns: minmax(0, 1fr) minmax(340px, 1fr);
}

.finance-panel {
    border: 1px solid #dbe3ef;
    border-radius: 12px;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
    padding: 1.2rem;
}

.finance-panel h3 {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1rem;
}

.finance-panel h3 i {
    font-size: 0.55rem;
}

.dot-blue { color: #1f73d8; }
.dot-green { color: #51b878; }
.dot-pink { color: #e22b8f; }

.bonus-list div,
.status-list div,
.commission-list div,
.referrals-list div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    border-bottom: 1px solid #dbe3ef;
    padding: 0.64rem 0;
    font-family: var(--font-texto);
}

.bonus-list div:last-child,
.status-list div:last-child,
.commission-list div:last-child,
.referrals-list div:last-child {
    border-bottom: 0;
}

.bonus-list span,
.status-list span {
    color: #49617c;
}

.bonus-list strong,
.level-row strong {
    color: #050b28;
    font-weight: 900;
}

.bonus-list .bonus-total strong,
.commission-list b,
.referrals-list b {
    color: #4fbe76;
}

.pill {
    border-radius: 999px;
    padding: 0.25rem 0.65rem;
    font-size: 0.8rem;
    font-weight: 900;
}

.pill-blue { background: #e7f0ff; color: #1f73d8; }
.pill-green { background: #e7f8ed; color: #249b51; }
.pill-orange { background: #fff0d9; color: #ff7300; }
.pill-pink { background: #ffe9f5; color: #e22b8f; }

.level-bonus-list {
    display: grid;
    gap: 0.75rem;
}

.level-row {
    display: grid;
    grid-template-columns: 68px minmax(120px, 1fr) 88px 58px 74px;
    align-items: center;
    gap: 0.75rem;
    font-family: var(--font-texto);
    font-size: 0.86rem;
}

.level-label {
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 0.28rem 0.45rem;
    text-align: center;
}

.level-1 { background: #e7f0ff; color: #1f73d8; }
.level-2 { background: #e7f8ed; color: #249b51; }
.level-3 { background: #ffe9f5; color: #e22b8f; }
.level-4 { background: #fff0d9; color: #ff7300; }
.level-5 { background: #f4e7ff; color: #9c27b0; }

.level-track {
    height: 6px;
    overflow: hidden;
    border-radius: 999px;
    background: #dfe6ee;
}

.level-track i {
    display: block;
    height: 100%;
    border-radius: inherit;
}

.finance-note {
    border-top: 1px solid #dbe3ef;
    color: #49617c !important;
    font-size: 0.85rem !important;
    margin-top: 0.9rem;
    padding-top: 0.75rem;
}

.commission-list div,
.referrals-list div {
    justify-content: flex-start;
}

.commission-list i[class$='-bg'] {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    flex: 0 0 auto;
}

.dot-blue-bg { background: #1f73d8; }
.dot-green-bg { background: #51b878; }
.dot-pink-bg { background: #e22b8f; }
.dot-orange-bg { background: #ff8a00; }
.dot-purple-bg { background: #9c27b0; }

.commission-list span,
.referrals-list span {
    display: grid;
    gap: 0.1rem;
    flex: 1;
}

.commission-list small,
.referrals-list small {
    color: #526987;
    font-size: 0.8rem;
}

.ghost-action {
    width: 100%;
    border: 1px solid #dbe3ef;
    border-radius: 10px;
    background: #f8fafc;
    color: #1264d8;
    cursor: pointer;
    font-weight: 800;
    margin-top: 0.9rem;
    padding: 0.75rem 1rem;
}

.referrals-list em {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    flex: 0 0 auto;
    font-style: normal;
    font-size: 0.8rem;
    font-weight: 900;
}

.avatar-blue { background: #e7f0ff; color: #1f73d8; }
.avatar-green { background: #e7f8ed; color: #249b51; }
.avatar-pink { background: #ffe9f5; color: #e22b8f; }
.avatar-orange { background: #fff0d9; color: #ff7300; }
.referrals-list .warning { color: #ff7300; }

.withdraw-amount {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 0.2rem;
}

.withdraw-amount strong {
    color: #050b28;
    font-family: var(--font-titulo);
    font-size: 2.5rem;
    font-weight: 900;
    line-height: 1;
}

.withdraw-amount span {
    color: #49617c;
    font-family: var(--font-texto);
}

.withdraw-panel p {
    color: #49617c;
    font-size: 0.95rem;
    margin-bottom: 1rem;
}

.withdraw-form {
    display: grid;
    gap: 0.85rem;
}

.withdraw-form label {
    display: grid;
    gap: 0.45rem;
}

.withdraw-form select,
.withdraw-form input {
    width: 100%;
    border: 1px solid #d8e1ed;
    border-radius: 10px;
    outline: none;
    padding: 0.85rem 1rem;
    font-size: 1rem;
}

.withdraw-form button {
    border: 0;
    border-radius: 10px;
    background: #2474d8;
    color: #ffffff;
    cursor: pointer;
    font-weight: 900;
    padding: 0.95rem 1rem;
}

.withdraw-panel > small {
    display: block;
    color: #526987;
    font-family: var(--font-texto);
    font-size: 0.8rem;
    margin-top: 0.85rem;
    text-align: center;
}

@media screen and (width < 1080px) {
    .finance-kpis,
    .dashboard-two-col,
    .dashboard-wide-left,
    .dashboard-bottom-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media screen and (width < 760px) {
    .finance-kpis,
    .dashboard-two-col,
    .dashboard-wide-left,
    .dashboard-bottom-grid {
        grid-template-columns: 1fr;
    }

    .level-row {
        grid-template-columns: 70px 1fr;
        gap: 0.5rem;
    }

    .level-row > span:not(.level-label),
    .level-row strong {
        justify-self: end;
    }
}

/* Corrección de layout del dashboard financiero */
.office-body {
    grid-template-columns: 270px minmax(0, 1fr);
}

.office-main {
    min-width: 0;
    overflow-x: hidden;
}

.dashboard-module.dashboard-finance {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
}

.dashboard-finance > * {
    width: 100%;
    min-width: 0;
}

.dashboard-finance > .referral-card {
    grid-column: auto;
}

.dashboard-finance .finance-kpis,
.dashboard-finance .dashboard-two-col,
.dashboard-finance .dashboard-wide-left,
.dashboard-finance .dashboard-bottom-grid {
    min-width: 0;
}

.dashboard-finance .finance-panel,
.dashboard-finance .finance-kpi {
    min-width: 0;
}

/* Organigrama de Mi Red */
.network-tree-shell {
    width: 100%;
    margin-top: 1.2rem;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 1.2rem 0.5rem 1.8rem;
}

.network-tree {
    min-width: 880px;
    display: grid;
    gap: 2.2rem;
    font-family: var(--font-texto);
}

.network-level {
    position: relative;
    display: grid;
    gap: 0.9rem;
    justify-items: center;
}

.network-level:not(:first-child)::before {
    content: '';
    position: absolute;
    top: -1.65rem;
    left: 50%;
    width: min(78%, 980px);
    height: 1px;
    background: #1f2937;
    transform: translateX(-50%);
}

.network-level-label {
    border-radius: 999px;
    background: #eef2ff;
    color: #334155;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    padding: 0.32rem 0.75rem;
}

.network-level-nodes {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    justify-content: center;
    gap: 1.15rem;
}

.network-node {
    position: relative;
    width: 190px;
    height: 82px;
    display: grid;
    grid-template-columns: 38px 1fr;
    grid-template-rows: 1fr auto;
    column-gap: 0.65rem;
    align-items: center;
    border: 3px solid #111827;
    border-radius: 0;
    background: #ffffff;
    color: #111827;
    padding: 0.72rem;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.07);
}

.network-level:not(:first-child) .network-node::before {
    content: '';
    position: absolute;
    top: -1.18rem;
    left: 50%;
    width: 2px;
    height: 1.18rem;
    background: #111827;
    transform: translateX(-50%);
}

.network-node span {
    width: 38px;
    height: 38px;
    grid-row: 1 / span 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #e7f0ff;
    color: #1f73d8;
    font-weight: 900;
}

.network-node strong {
    overflow: hidden;
    color: #0f172a;
    font-size: 0.88rem;
    font-weight: 900;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.network-node small {
    overflow: hidden;
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.network-node.is-root {
    width: 320px;
    border-width: 4px;
}

.network-node.is-root span {
    background: #ffe9f5;
    color: var(--color-rosa);
}

.network-empty {
    width: max-content;
    min-width: 320px;
    margin: 1rem auto 0;
    border: 1px dashed #cbd5e1;
    border-radius: 12px;
    background: #f8fafc;
    color: #64748b !important;
    font-size: 0.95rem !important;
    font-weight: 800;
    padding: 0.95rem 1.2rem;
    text-align: center;
}

@media screen and (width < 760px) {
    .network-tree {
        min-width: 720px;
    }

    .network-node {
        width: 160px;
        height: 78px;
    }

    .network-node.is-root {
        width: 260px;
    }
}

/* Paleta Manik Evolution aplicada a oficina virtual */
:root {
    --manik-primary: #0047AB;
    --manik-cta: #E8006E;
    --manik-detail: #5DB89A;
    --manik-white: #FFFFFF;
    --manik-dark: #1A1A2E;
    --manik-soft-blue: #EAF2FF;
    --manik-soft-pink: #FFE8F2;
    --manik-soft-green: #EAF8F3;
    --manik-border: #D8E4F5;
}

.office-body {
    background: #F4F7FB;
    color: var(--manik-dark);
}

.office-sidebar {
    background: linear-gradient(180deg, var(--manik-dark), #102D68 58%, var(--manik-primary));
}

.office-sidebar button.is-active,
.office-sidebar button:hover {
    background: rgba(255, 255, 255, 0.14);
    box-shadow: inset 3px 0 0 var(--manik-detail);
}

.office-header,
.dashboard-hero,
.finance-panel,
.finance-kpi,
.office-panel {
    border: 1px solid var(--manik-border);
    box-shadow: 0 16px 36px rgba(26, 26, 46, 0.08);
}

.office-header span,
.dashboard-hero span,
.office-panel-header span {
    color: var(--manik-cta);
}

.office-header h1,
.dashboard-hero h2,
.office-panel h2,
.finance-kpi strong,
.withdraw-amount strong,
.bonus-list strong,
.level-row strong {
    color: var(--manik-dark);
}

.office-header button,
.dashboard-hero button,
.referral-link-box button,
.office-panel-header button,
.office-form button[type="submit"] {
    background: var(--manik-cta);
    color: var(--manik-white);
    box-shadow: 0 10px 24px rgba(232, 0, 110, 0.18);
}

.finance-kpi {
    border-top-color: var(--manik-primary);
}

.finance-kpi.kpi-pink {
    border-top-color: var(--manik-cta);
}

.finance-kpi.kpi-green {
    border-top-color: var(--manik-detail);
}

.finance-kpi.kpi-orange {
    border-top-color: var(--manik-primary);
}

.finance-kpi span,
.finance-panel h3,
.withdraw-form span {
    color: #52657E;
}

.finance-kpi small,
.bonus-list .bonus-total strong,
.commission-list b,
.referrals-list b {
    color: var(--manik-detail);
}

.finance-kpi.kpi-orange small {
    color: var(--manik-cta);
}

.finance-kpi .kpi-status,
.pill-orange {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.dot-blue,
.dot-green,
.dot-pink {
    color: var(--manik-detail);
}

.pill-blue,
.level-1 {
    background: var(--manik-soft-blue);
    color: var(--manik-primary);
}

.pill-green,
.level-2 {
    background: var(--manik-soft-green);
    color: #287E65;
}

.pill-pink,
.level-3,
.level-5 {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.level-4 {
    background: var(--manik-soft-blue);
    color: var(--manik-primary);
}

.withdraw-form button,
.ghost-action {
    background: var(--manik-primary);
    color: var(--manik-white);
    border-color: var(--manik-primary);
}

.ghost-action {
    background: #F7FAFF;
    color: var(--manik-primary);
}

.withdraw-form select:focus,
.withdraw-form input:focus,
.referral-link-box input:focus,
.office-form input:focus,
.office-form select:focus {
    border-color: var(--manik-primary);
    box-shadow: 0 0 0 3px rgba(0, 71, 171, 0.12);
}

.network-tree-shell {
    border: 1px solid var(--manik-border);
    border-radius: 16px;
    background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
    padding: 1.5rem 1rem 2rem;
}

.network-level-label {
    background: var(--manik-soft-blue);
    color: var(--manik-primary);
    box-shadow: 0 8px 18px rgba(0, 71, 171, 0.08);
}

.network-level:not(:first-child)::before,
.network-level:not(:first-child) .network-node::before {
    background: var(--manik-primary);
}

.network-node {
    border: 2px solid var(--manik-primary);
    border-radius: 10px;
    background: var(--manik-white);
    box-shadow: 0 14px 28px rgba(0, 71, 171, 0.10);
}

.network-node.is-root {
    border-color: var(--manik-dark);
    background: linear-gradient(90deg, #FFFFFF, #F7FAFF);
}

.network-node span {
    background: var(--manik-soft-green);
    color: #287E65;
}

.network-node.is-root span {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.network-node strong {
    color: var(--manik-dark);
}

.network-node small {
    color: #52657E;
}

.network-empty {
    border-color: var(--manik-border);
    background: var(--manik-soft-blue);
    color: #52657E !important;
}

/* Uso semantico de paleta Manik Evolution */
.office-sidebar {
    background: linear-gradient(180deg, var(--manik-dark), #121B3F 62%, var(--manik-dark));
}

.office-header,
.dashboard-hero {
    background: linear-gradient(135deg, var(--manik-dark), #102D68 72%, var(--manik-primary));
    border-color: rgba(255, 255, 255, 0.12);
}

.office-header span,
.dashboard-hero span {
    color: var(--manik-detail);
}

.office-header h1,
.dashboard-hero h2,
.dashboard-hero p {
    color: var(--manik-white);
}

.office-header button,
.dashboard-hero button,
.referral-link-box button,
.withdraw-form button,
.office-form button[type="submit"] {
    background: var(--manik-cta);
    color: var(--manik-white);
    box-shadow: 0 12px 26px rgba(232, 0, 110, 0.24);
}

.office-panel-header button,
.ghost-action,
.office-actions button {
    background: var(--manik-primary);
    color: var(--manik-white);
    border-color: var(--manik-primary);
}

.office-panel h2,
.office-panel-header h2,
.finance-panel h3,
.finance-kpi span,
.withdraw-form span,
.referral-card h3 {
    color: var(--manik-primary);
}

.finance-kpi {
    border-top-color: var(--manik-primary);
}

.finance-kpi strong,
.withdraw-amount strong,
.bonus-list strong,
.level-row strong,
.bonus-list .bonus-total strong,
.commission-list b,
.referrals-list b {
    color: var(--manik-cta);
}

.finance-kpi small,
.finance-note,
.withdraw-panel p,
.network-node small {
    color: #52657E !important;
}

.finance-kpi.kpi-green {
    border-top-color: var(--manik-detail);
}

.finance-kpi.kpi-pink,
.finance-kpi.kpi-orange {
    border-top-color: var(--manik-cta);
}

.finance-kpi .kpi-status,
.office-tag,
.pill,
.level-label {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.dot-blue,
.dot-green,
.dot-pink,
.dashboard-summary__header h3 i,
.finance-panel h3 i,
.dashboard-card__icon,
.office-sidebar button i {
    color: var(--manik-detail);
}

.pill-green,
.level-2 {
    background: var(--manik-soft-green);
    color: #287E65;
}

.pill-blue,
.level-1,
.level-4 {
    background: var(--manik-soft-blue);
    color: var(--manik-primary);
}

.network-tree-shell,
.finance-panel,
.finance-kpi,
.office-panel {
    background: var(--manik-white);
}

.network-level-label {
    background: var(--manik-primary);
    color: var(--manik-white);
}

.network-node {
    border-color: var(--manik-primary);
}

.network-node.is-root {
    border-color: var(--manik-dark);
}

.network-node span {
    background: var(--manik-soft-green);
    color: #287E65;
}

.network-node.is-root span {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.network-empty {
    background: #F7FAFF;
    color: var(--manik-primary) !important;
}

.referral-card {
    border-top: 4px solid var(--manik-primary);
}

/* Tipografias globales de la oficina virtual */
h1, h2, h3, h4, h5, h6,
.office-header h1,
.dashboard-hero h2,
.finance-kpi strong,
.withdraw-amount strong,
.network-node strong {
    font-family: var(--font-titulo);
}

body,
button,
input,
select,
textarea,
p,
span,
small,
label,
table,
.office-sidebar,
.office-panel,
.finance-panel,
.network-tree-shell {
    font-family: var(--font-texto);
}

/* Pulido visual de Mi Red */
.network-tree-shell {
    border-color: #CFE0F7;
    background: linear-gradient(180deg, #FFFFFF 0%, #F5F9FF 100%);
}

.network-tree {
    gap: 2rem;
}

.network-level-label {
    min-width: 84px;
    text-align: center;
    background: linear-gradient(135deg, var(--manik-primary), #0B5ED7);
    color: var(--manik-white);
    box-shadow: 0 10px 20px rgba(0, 71, 171, 0.18);
}

.network-level-nodes {
    align-items: center;
}

.network-node {
    width: 210px;
    height: 96px;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    justify-items: center;
    align-content: center;
    gap: 0.28rem;
    border: 2px solid #0B5ED7;
    border-radius: 14px;
    background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
    padding: 0.85rem;
    text-align: center;
    box-shadow: 0 16px 34px rgba(0, 71, 171, 0.12);
}

.network-node.is-root {
    width: 320px;
    height: 104px;
    border-color: var(--manik-primary);
    background: linear-gradient(135deg, #FFFFFF 0%, #EEF5FF 100%);
    box-shadow: 0 18px 38px rgba(0, 71, 171, 0.15);
}

.network-node span {
    width: 40px;
    height: 40px;
    grid-row: auto;
    margin: 0 auto 0.1rem;
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.network-node.is-root span {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.network-node strong {
    width: 100%;
    color: var(--manik-dark);
    font-size: 0.95rem;
    line-height: 1.15;
    text-align: center;
}

.network-node small {
    width: 100%;
    color: #52657E !important;
    font-size: 0.76rem;
    text-align: center;
}

.network-empty {
    width: min(320px, 100%);
    min-width: 0;
    border: 1px solid #CFE0F7;
    border-radius: 14px;
    background: #FFFFFF;
    color: var(--manik-primary) !important;
    box-shadow: 0 12px 26px rgba(0, 71, 171, 0.08);
}

.registro-form input[readonly] {
    background: #F3F7FF;
    border-color: #CFE0F7;
    color: var(--manik-primary);
    cursor: not-allowed;
    font-weight: 800;
}

/* Organigrama ligado por patrocinador */
.network-tree-linked {
    display: grid;
    justify-items: center;
    gap: 1rem;
    min-width: 960px;
}

.network-org-chart,
.network-org-chart ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.network-org-chart {
    width: max-content;
    min-width: 100%;
    display: flex;
    justify-content: center;
    padding-top: 0.6rem;
}

.network-branch {
    position: relative;
    display: grid;
    justify-items: center;
    padding: 1.55rem 0.75rem 0;
}

.network-branch.is-root-branch {
    padding-top: 0;
}

.network-branch > ul {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 1.35rem;
    padding-top: 2.1rem;
}

.network-branch > ul::before {
    content: '';
    position: absolute;
    top: 1.05rem;
    left: 50%;
    width: 2px;
    height: 1.05rem;
    background: var(--manik-primary);
    transform: translateX(-50%);
}

.network-branch > ul > .network-branch::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--manik-primary);
}

.network-branch > ul > .network-branch:first-child::before {
    left: 50%;
}

.network-branch > ul > .network-branch:last-child::before {
    right: 50%;
}

.network-branch > ul > .network-branch:only-child::before {
    display: none;
}

.network-branch > ul > .network-branch::after {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    width: 2px;
    height: 1.55rem;
    background: var(--manik-primary);
    transform: translateX(-50%);
}

.network-branch.is-root-branch > .network-node::before,
.network-tree-linked .network-level::before,
.network-tree-linked .network-level:not(:first-child)::before,
.network-tree-linked .network-node::before {
    display: none;
}

.network-tree-linked .network-node {
    position: relative;
    z-index: 1;
}

.network-tree-linked .network-node small {
    white-space: nowrap;
}

.network-tree-linked .network-empty {
    margin-top: 1.2rem;
}

@media screen and (width < 760px) {
    .network-tree-linked {
        min-width: 760px;
    }

    .network-branch > ul {
        gap: 0.9rem;
    }
}

.registro-form select {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 14px;
    outline: none;
    padding: 0.85rem 1rem;
    font-size: 1rem;
    background: #ffffff;
    color: #1f2937;
}

.registro-form select:focus {
    border-color: var(--manik-primary);
    box-shadow: 0 0 0 3px rgba(0, 71, 171, 0.12);
}

/* Activacion de afiliado */
.activation-panel {
    display: grid;
    gap: 1rem;
    border: 1px solid #CFE0F7;
    border-radius: 8px;
    background: #FFFFFF;
    box-shadow: 0 16px 36px rgba(26, 26, 46, 0.08);
    padding: 1.2rem;
}

.activation-status {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.activation-status span,
.activation-form label > span {
    color: #52657E;
    font-size: 0.82rem;
    font-weight: 900;
}

.activation-status h3 {
    color: var(--manik-primary);
    font-size: 1.25rem;
    font-weight: 900;
    margin-top: 0.18rem;
}

.activation-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.5rem;
}

.activation-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 900;
    padding: 0.38rem 0.7rem;
}

.activation-badge.is-off {
    background: #FEE2E2;
    color: #B91C1C;
}

.activation-badge.is-on,
.activation-badge.is-product {
    background: var(--manik-soft-green);
    color: #287E65;
}

.activation-badge.is-gencell {
    background: var(--manik-soft-blue);
    color: var(--manik-primary);
}

.activation-badge.is-neutral {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.activation-form {
    display: grid;
    gap: 1rem;
}

.activation-form.is-complete {
    border-top: 1px solid #E7EEF8;
    padding-top: 1rem;
}

.activation-options {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
}

.activation-option {
    min-height: 82px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.65rem;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
    cursor: pointer;
    padding: 0.85rem;
}

.activation-option input {
    accent-color: var(--manik-primary);
}

.activation-option span {
    color: var(--manik-dark);
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1.25;
}

.activation-option b {
    display: block;
    color: var(--manik-cta);
    font-size: 1.05rem;
}

.activation-products {
    display: grid;
    gap: 0.75rem;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    background: #F8FBFF;
    padding: 0.9rem;
}

.activation-products-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    color: var(--manik-dark);
    font-weight: 900;
}

.activation-products-header strong,
.activation-product-row b {
    color: var(--manik-cta);
}

.activation-products-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0.55rem;
    max-height: 260px;
    overflow: auto;
    padding-right: 0.25rem;
}

.activation-product-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.35rem 0.7rem;
    border: 1px solid #E7EEF8;
    border-radius: 8px;
    background: #FFFFFF;
    padding: 0.65rem;
}

.activation-product-row span {
    overflow: hidden;
    color: var(--manik-dark);
    font-size: 0.88rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.activation-product-row small,
.activation-products small {
    color: #52657E;
    font-size: 0.78rem;
    font-weight: 800;
}

.activation-product-controls {
    display: grid;
    grid-template-columns: 30px 30px 30px;
    align-items: center;
    justify-items: center;
    gap: 0.25rem;
}

.activation-product-controls button {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    background: #F7FAFF;
    color: var(--manik-primary);
    cursor: pointer;
}

.activation-product-controls strong {
    color: var(--manik-dark);
    font-weight: 900;
}

.activation-payment {
    display: grid;
    grid-template-columns: minmax(180px, 260px) auto;
    align-items: end;
    gap: 0.85rem;
}

.activation-payment label {
    display: grid;
    gap: 0.4rem;
}

.activation-payment input {
    width: 100%;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    outline: none;
    padding: 0.85rem 1rem;
}

.activation-payment input:focus {
    border-color: var(--manik-primary);
    box-shadow: 0 0 0 3px rgba(0, 71, 171, 0.12);
}

.activation-payment button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    min-height: 46px;
    border: 0;
    border-radius: 8px;
    background: var(--manik-cta);
    color: var(--manik-white);
    cursor: pointer;
    font-weight: 900;
    padding: 0.85rem 1.1rem;
}

.activation-payment button:disabled {
    opacity: 0.65;
    cursor: wait;
}

.activation-message {
    min-height: 1.1rem;
    font-size: 0.9rem !important;
    font-weight: 800;
}

.activation-message.is-ok {
    color: #287E65 !important;
}

.activation-message.is-error {
    color: #DC2626 !important;
}

.member-upgrade-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid var(--manik-border);
    border-left: 4px solid var(--manik-detail);
    border-radius: 10px;
    background: #FFFFFF;
    box-shadow: 0 12px 28px rgba(26, 26, 46, 0.06);
    padding: 1rem 1.1rem;
}

.member-upgrade-panel div {
    display: grid;
    gap: 0.2rem;
}

.member-upgrade-panel span {
    color: var(--manik-cta);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.member-upgrade-panel strong {
    color: var(--manik-dark);
    font-family: var(--font-titulo);
}

.member-upgrade-panel button,
.primary-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    border: 0;
    border-radius: 999px;
    background: var(--manik-cta);
    color: var(--manik-white);
    cursor: pointer;
    font-weight: 900;
    padding: 0.82rem 1rem;
}

.modal-copy {
    color: #52657E;
    font-family: var(--font-texto);
    line-height: 1.55;
    margin-bottom: 1rem;
}

.modal-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.7rem;
}

.modal-actions .ghost-action {
    margin-top: 0;
}

.registro-legal-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    border: 1px solid #CFE0F7;
    border-radius: 12px;
    background: #F7FAFF;
    color: var(--manik-primary);
    padding: 0.8rem 0.9rem;
}

.registro-legal-box strong {
    font-size: 0.9rem;
}

.registro-legal-box a,
.registro-privacy-link {
    color: var(--manik-primary);
    font-weight: 900;
    text-decoration: none;
}

.registro-privacy-link {
    display: inline-flex;
    justify-content: center;
    font-size: 0.9rem;
}

.commission-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.commission-summary-grid article,
.stats-global-grid article,
.stats-period-grid article {
    border: 1px solid var(--manik-border);
    border-radius: 8px;
    background: #F7FAFF;
    padding: 0.9rem;
}

.commission-summary-grid span {
    display: block;
    color: var(--manik-primary);
    font-size: 0.8rem;
    font-weight: 900;
    text-transform: uppercase;
}

.commission-summary-grid strong {
    color: var(--manik-cta);
    font-family: var(--font-titulo);
    font-size: 1.45rem;
}

.stats-global-grid,
.stats-period-grid {
    display: grid;
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.stats-global-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.stats-period-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.stats-global-grid span,
.stats-period-grid span {
    display: block;
    color: var(--manik-primary);
    font-size: 0.8rem;
    font-weight: 900;
    text-transform: uppercase;
}

.stats-global-grid strong,
.stats-period-grid strong {
    color: var(--manik-cta);
    font-family: var(--font-titulo);
    font-size: 1.55rem;
}

.stats-period-grid small {
    display: block;
    color: #52657E;
    font-weight: 800;
    margin-top: 0.25rem;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.25rem 0.55rem;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.status-pendiente {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

.status-pagada,
.status-procesado {
    background: var(--manik-soft-green);
    color: #287E65;
}

.status-rechazado {
    background: #FEE2E2;
    color: #B91C1C;
}

@media screen and (width < 760px) {
    .commission-summary-grid,
    .stats-global-grid,
    .stats-period-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.network-node.is-not-qualified {
    border-color: #CBD5E1;
    background: linear-gradient(180deg, #FFFFFF, #F8FAFC);
}

.network-node.is-not-qualified span {
    background: #F1F5F9;
    color: #64748B;
}

.network-node.is-gencell {
    border-color: var(--manik-primary);
}

.network-node.is-gencell span {
    background: var(--manik-soft-blue);
    color: var(--manik-primary);
}

.network-node.is-product {
    border-color: var(--manik-detail);
}

.network-node.is-product span {
    background: var(--manik-soft-green);
    color: #287E65;
}

.network-node.is-client-evo {
    border-color: var(--manik-cta);
}

.network-node.is-client-evo span {
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
}

@media screen and (width < 900px) {
    .activation-status {
        flex-direction: column;
    }

    .activation-badges {
        justify-content: flex-start;
    }

    .activation-options {
        grid-template-columns: 1fr;
    }
}

@media screen and (width < 560px) {
    .activation-payment {
        grid-template-columns: 1fr;
    }
}

/* Tienda en linea */
.shop-module {
    overflow: visible;
}

.shop-header {
    align-items: flex-start;
}

.shop-cart-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border: 1px solid #CFE0F7;
    border-radius: 999px;
    background: #F7FAFF;
    color: var(--manik-primary);
    font-size: 0.9rem;
    font-weight: 800;
    padding: 0.55rem 0.85rem;
    white-space: nowrap;
}

.shop-cart-pill i,
.shop-cart-pill strong {
    color: var(--manik-cta);
}

.shop-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    align-items: start;
    gap: 1.2rem;
}

.shop-catalog {
    min-width: 0;
}

.shop-featured-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.shop-product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 1rem;
}

.shop-product {
    position: relative;
    min-width: 0;
    display: grid;
    gap: 0.85rem;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    background: linear-gradient(180deg, #FFFFFF 0%, #F8FBFF 100%);
    box-shadow: 0 12px 26px rgba(0, 71, 171, 0.08);
    padding: 1rem;
}

.shop-product-featured {
    grid-template-columns: minmax(150px, 44%) minmax(0, 1fr);
    align-items: center;
    min-height: 280px;
    border-color: #BFD6F5;
    background: linear-gradient(135deg, #FFFFFF 0%, #EEF5FF 100%);
}

.shop-badge {
    position: absolute;
    top: 0.85rem;
    left: 0.85rem;
    z-index: 1;
    border-radius: 999px;
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
    font-size: 0.76rem;
    font-weight: 900;
    padding: 0.32rem 0.65rem;
}

.shop-product-media {
    width: 100%;
    height: 174px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: #FFFFFF;
    overflow: hidden;
}

.shop-product-featured .shop-product-media {
    height: 240px;
    background: rgba(255, 255, 255, 0.78);
}

.shop-product-media img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.shop-product-info {
    display: grid;
    align-content: start;
    gap: 0.5rem;
    min-width: 0;
}

.shop-product-info small,
.shop-section-title span,
.shop-cart small {
    color: #52657E;
    font-size: 0.82rem;
    font-weight: 800;
}

.shop-product-info h3,
.shop-section-title h3,
.shop-cart h3 {
    color: var(--manik-primary);
    font-size: 1.05rem;
    font-weight: 900;
    line-height: 1.18;
}

.shop-product-featured .shop-product-info h3 {
    color: var(--manik-dark);
    font-size: 1.45rem;
}

.shop-product-info p {
    color: #52657E !important;
    font-size: 0.92rem !important;
    line-height: 1.45;
}

.shop-price {
    display: grid;
    gap: 0.15rem;
    border: 1px solid #E7EEF8;
    border-radius: 8px;
    background: #FFFFFF;
    padding: 0.65rem;
}

.shop-price span {
    color: #52657E;
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.shop-price strong {
    color: var(--manik-cta);
    font-size: 1.25rem;
    font-weight: 900;
}

.shop-price small {
    color: #287E65;
    font-size: 0.82rem;
    font-weight: 900;
}

.shop-product-info button,
.shop-checkout {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: 100%;
    border: 0;
    border-radius: 8px;
    background: var(--manik-cta);
    color: var(--manik-white);
    cursor: pointer;
    font-weight: 900;
    padding: 0.78rem 0.85rem;
}

.shop-product-info button:hover,
.shop-checkout:hover:not(:disabled) {
    filter: brightness(0.96);
}

.shop-section-title {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin: 1.45rem 0 0.85rem;
}

.shop-cart {
    position: sticky;
    top: 1rem;
    display: grid;
    gap: 0.9rem;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    background: #FFFFFF;
    box-shadow: 0 12px 26px rgba(26, 26, 46, 0.08);
    padding: 1rem;
}

.shop-cart h3 {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.shop-cart h3 i {
    color: var(--manik-detail);
}

.shop-cart-items {
    display: grid;
    gap: 0.55rem;
}

.shop-empty {
    border: 1px dashed #CFE0F7;
    border-radius: 8px;
    background: #F7FAFF;
    color: #52657E !important;
    font-size: 0.9rem !important;
    padding: 0.85rem;
}

.shop-cart-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    gap: 0.75rem;
    border-bottom: 1px solid #E7EEF8;
    color: var(--manik-dark);
    font-size: 0.9rem;
    font-weight: 800;
    padding-bottom: 0.55rem;
}

.shop-cart-product {
    min-width: 0;
    display: grid;
    gap: 0.15rem;
}

.shop-cart-product span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.shop-cart-product small {
    color: #52657E;
    font-size: 0.78rem;
}

/* Scroll independiente en oficina virtual */
body.office-body {
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
}

.office-body .office-sidebar,
.office-body .office-main {
    height: 100vh;
    min-height: 0;
    overscroll-behavior: contain;
}

.office-body .office-sidebar {
    overflow-y: auto;
}

.office-body .office-main {
    overflow-x: hidden;
    overflow-y: auto;
}

.office-body .office-sidebar::-webkit-scrollbar,
.office-body .office-main::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

.office-body .office-sidebar::-webkit-scrollbar-thumb,
.office-body .office-main::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(0, 71, 171, 0.28);
}

@media screen and (width < 820px) {
    body.office-body {
        height: auto;
        min-height: 100vh;
        overflow: auto;
    }

    .office-body .office-sidebar,
    .office-body .office-main {
        height: auto;
        min-height: auto;
        overflow: visible;
    }
}

.shop-cart-controls {
    display: grid;
    grid-template-columns: 32px 32px 32px 32px;
    align-items: center;
    gap: 0.35rem;
}

.shop-cart-controls button {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #D8E4F5;
    border-radius: 8px;
    background: #F7FAFF;
    color: var(--manik-primary);
    cursor: pointer;
}

.shop-cart-controls button.is-danger {
    background: #FEE2E2;
    border-color: #FECACA;
    color: #B91C1C;
}

.shop-cart-controls strong {
    color: var(--manik-dark);
    text-align: center;
}

.shop-cart-row b {
    color: var(--manik-cta);
    justify-self: end;
}

.shop-cart-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid #E7EEF8;
    border-bottom: 1px solid #E7EEF8;
    padding: 0.75rem 0;
}

.shop-cart-total span {
    color: #52657E;
    font-weight: 900;
}

.shop-cart-total strong {
    color: var(--manik-cta);
    font-size: 1.25rem;
    font-weight: 900;
}

.shop-checkout:disabled {
    background: #B9C6D8;
    cursor: not-allowed;
    box-shadow: none;
}

@media screen and (width >= 1450px) {
    .shop-product-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media screen and (width < 1180px) {
    .shop-layout {
        grid-template-columns: 1fr;
    }

    .shop-cart {
        position: static;
    }
}

@media screen and (width < 900px) {
    .shop-featured-grid {
        grid-template-columns: 1fr;
    }

    .shop-product-featured {
        min-height: 0;
    }
}

@media screen and (width < 620px) {
    .shop-header,
    .shop-section-title {
        align-items: flex-start;
        flex-direction: column;
    }

    .shop-product-featured {
        grid-template-columns: 1fr;
    }

    .shop-product-featured .shop-product-media {
        height: 220px;
    }

    .shop-product-grid {
        grid-template-columns: 1fr;
    }
}

/* Capa premium Manik Evolution */
body.office-body {
    background:
        linear-gradient(180deg, #F7FAFF 0%, #EEF4FB 46%, #F8FAFC 100%);
}

.office-body .office-sidebar {
    position: relative;
    background:
        linear-gradient(180deg, rgba(18, 27, 63, 0.96), rgba(13, 13, 41, 0.98) 54%, rgba(0, 71, 171, 0.94));
    border-right: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 18px 0 40px rgba(18, 27, 63, 0.16);
}

.office-body .office-sidebar::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.08), transparent 18%),
        linear-gradient(180deg, rgba(91, 210, 182, 0.14), transparent 24%);
}

.office-sidebar img,
.office-sidebar nav {
    position: relative;
    z-index: 1;
}

.office-sidebar img {
    width: 150px;
    display: block;
    margin: 0 auto 2rem;
    filter: drop-shadow(0 12px 22px rgba(0, 0, 0, 0.18));
}

.office-sidebar button {
    position: relative;
    min-height: 44px;
    border: 1px solid transparent;
    border-radius: 10px;
    color: rgba(255, 255, 255, 0.88);
    transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.office-sidebar button:hover,
.office-sidebar button.is-active {
    transform: translateX(2px);
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.office-sidebar button:disabled {
    cursor: not-allowed;
    opacity: 0.42;
    transform: none;
}

.office-sidebar button.is-active::after {
    content: '';
    position: absolute;
    top: 10px;
    bottom: 10px;
    left: -1px;
    width: 3px;
    border-radius: 999px;
    background: var(--manik-detail);
    box-shadow: 0 0 18px rgba(91, 210, 182, 0.58);
}

.office-main {
    padding: 1.65rem;
}

.office-header,
.dashboard-hero {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 12px;
    box-shadow: 0 20px 52px rgba(18, 27, 63, 0.16);
}

.office-header::after,
.dashboard-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(115deg, rgba(255, 255, 255, 0.14), transparent 32%),
        linear-gradient(270deg, rgba(91, 210, 182, 0.10), transparent 40%);
}

.office-header > *,
.dashboard-hero > * {
    position: relative;
    z-index: 1;
}

.office-header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.office-header-actions button {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.office-header-actions button.is-verified {
    background: #28A173;
}

.office-panel,
.finance-panel,
.finance-kpi,
.activation-panel,
.member-upgrade-panel,
.shop-cart,
.shop-product {
    border-color: rgba(207, 224, 247, 0.92);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow:
        0 18px 42px rgba(18, 27, 63, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.finance-kpi {
    position: relative;
    overflow: hidden;
    transition: transform 180ms ease, box-shadow 180ms ease;
}

.finance-kpi::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(125deg, rgba(255, 255, 255, 0.72), transparent 34%);
}

.finance-kpi:hover,
.shop-product:hover,
.finance-panel:hover {
    transform: translateY(-2px);
    box-shadow:
        0 24px 58px rgba(18, 27, 63, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.finance-kpi > *,
.shop-product > *,
.finance-panel > * {
    position: relative;
    z-index: 1;
}

.finance-kpi span,
.finance-panel h3,
.office-panel-header h2,
.shop-section-title h3 {
    letter-spacing: 0;
}

.finance-kpi strong,
.withdraw-amount strong,
.bonus-list strong,
.commission-summary-grid strong,
.stats-global-grid strong,
.stats-period-grid strong {
    text-shadow: 0 8px 20px rgba(232, 0, 110, 0.10);
}

.office-table-wrap {
    border: 1px solid #D8E4F5;
    border-radius: 10px;
    background: #FFFFFF;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.office-table thead {
    background: #F3F7FF;
}

.office-table th {
    color: var(--manik-primary);
    font-size: 0.78rem;
    text-transform: uppercase;
}

.office-table tbody tr {
    transition: background 160ms ease;
}

.office-table tbody tr:hover {
    background: #F8FBFF;
}

.activation-option,
.activation-product-row,
.shop-empty,
.referral-link-box input,
.withdraw-form input,
.withdraw-form select,
.office-form input,
.office-form select {
    border-radius: 10px;
}

.activation-option,
.activation-product-row {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.dashboard-hero button,
.office-header button,
.member-upgrade-panel button,
.primary-action,
.shop-checkout,
.withdraw-form button,
.referral-link-box button {
    transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.dashboard-hero button:hover,
.office-header button:hover,
.member-upgrade-panel button:hover,
.primary-action:hover,
.shop-checkout:not(:disabled):hover,
.withdraw-form button:hover,
.referral-link-box button:hover {
    transform: translateY(-1px);
    filter: saturate(1.04);
    box-shadow: 0 16px 32px rgba(232, 0, 110, 0.26);
}

.status-badge,
.activation-badge,
.pill {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}

.network-node {
    border-radius: 10px;
    box-shadow: 0 18px 36px rgba(0, 71, 171, 0.12);
}

.shop-product-media {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(247, 250, 255, 0.96));
}

.shop-product-media img {
    filter: drop-shadow(0 18px 24px rgba(18, 27, 63, 0.14));
}

@media screen and (width < 820px) {
    .office-main {
        padding: 1rem;
    }

    .office-body .office-sidebar {
        box-shadow: 0 16px 34px rgba(18, 27, 63, 0.16);
    }
}

.account-module > p {
    max-width: 720px;
}

.account-form {
    margin-top: 1.2rem;
}

.account-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.account-profile-photo {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    align-items: center;
    gap: 1rem;
    border: 1px solid #CFE0F7;
    border-radius: 10px;
    background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
    padding: 1rem;
}

.account-beneficiaries {
    display: grid;
    gap: 0.85rem;
    border: 1px solid #CFE0F7;
    border-radius: 10px;
    background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
    padding: 1rem;
}

.account-beneficiaries > div {
    display: grid;
    gap: 0.15rem;
}

.account-beneficiaries > div span {
    color: var(--manik-cta);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.account-beneficiaries > div strong {
    color: var(--manik-primary);
    font-family: var(--font-titulo);
    font-size: 1.1rem;
}

.account-beneficiaries p {
    color: #52657E !important;
    font-size: 0.92rem !important;
    line-height: 1.45;
}

.beneficiary-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 110px;
    gap: 0.75rem;
}

.profile-photo-preview {
    width: 96px;
    height: 96px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 2px solid #DDEBFF;
    border-radius: 50%;
    background: var(--manik-soft-pink);
    color: var(--manik-cta);
    font-weight: 900;
}

.profile-photo-preview img,
.profile-avatar,
.network-node .node-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.profile-avatar {
    width: 36px;
    height: 36px;
    display: inline-block;
    border-radius: 50%;
    flex: 0 0 auto;
}

.network-node .node-photo {
    overflow: hidden;
    padding: 0;
}

.account-form .primary-action {
    width: fit-content;
    min-width: 220px;
}

@media screen and (width < 760px) {
    .account-grid,
    .account-profile-photo,
    .beneficiary-grid {
        grid-template-columns: 1fr;
    }

    .account-form .primary-action {
        width: 100%;
    }
}

/* Landing premium pre-login */
body.landing-premium {
    background: #F6F9FC;
    color: #111827;
}

.landing-premium .header,
.landing-premium .header_desktop {
    background: var(--color-detalles);
    backdrop-filter: blur(18px);
    border-bottom: 0;
    box-shadow: 0 14px 40px rgba(11, 26, 61, 0.12);
}

.landing-premium .nav_link_desktop,
.landing-premium .nav_link {
    font-weight: 700;
}

.landing-premium .nav_contacto .btn-login,
.landing-premium .login .btn-login,
.landing-premium .btn-login {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    border: 0;
    border-radius: 999px;
    background: #E8006E;
    color: #FFFFFF;
    cursor: pointer;
    font-family: var(--font-texto);
    font-weight: 900;
    padding: 0.8rem 1.15rem;
    box-shadow: 0 16px 32px rgba(232, 0, 110, 0.24);
}

.landing-premium .nav_logo img,
.landing-premium .nav_logo_desktop img {
    filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.18));
}

.landing-shell {
    width: min(1180px, calc(100% - 2rem));
    margin-inline: auto;
}

.landing-hero {
    position: relative;
    min-height: 100vh;
    height: auto;
    display: flex;
    align-items: center;
    overflow: hidden;
    padding: 8rem 0 4.5rem;
    background: #0B1A3D;
}

.landing-gencell-cover {
    min-height: 760px;
    padding: 5.5rem 0;
}

.landing-hero .video-inicio {
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: 0.34;
}

.landing-hero__shade {
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        linear-gradient(90deg, rgba(5, 12, 31, 0.96) 0%, rgba(11, 26, 61, 0.84) 42%, rgba(0, 71, 171, 0.34) 100%),
        radial-gradient(circle at 74% 42%, rgba(91, 210, 182, 0.32), transparent 32%);
}

.landing-hero__grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(360px, 1.1fr);
    align-items: center;
    gap: 2.5rem;
}

.landing-hero__copy {
    display: grid;
    gap: 1.2rem;
}

.landing-kicker {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border: 1px solid rgba(91, 210, 182, 0.38);
    border-radius: 999px;
    background: rgba(91, 210, 182, 0.14);
    color: #5BD2B6;
    font-family: var(--font-texto);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0;
    padding: 0.48rem 0.75rem;
    text-transform: uppercase;
}

.landing-kicker::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #5BD2B6;
}

.landing-hero h1,
.section-copy h2,
.section-heading h2 {
    color: #FFFFFF;
    font-family: var(--font-titulo);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.02;
}

.landing-hero h1 {
    max-width: 640px;
    font-size: clamp(3rem, 8vw, 6.8rem);
}

.landing-hero p,
.section-copy p,
.section-heading p {
    color: rgba(255, 255, 255, 0.76);
    font-size: 1.05rem;
    line-height: 1.65;
}

.landing-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.85rem;
}

.landing-premium .btn-productos,
.landing-premium .btn-distribuidor,
.landing-primary-button {
    width: auto;
    min-width: 180px;
    max-width: none;
    border-radius: 999px;
    font-size: 0.95rem;
    padding: 0.95rem 1.2rem;
}

.landing-premium .btn-productos,
.landing-primary-button {
    background: #E8006E;
    color: #FFFFFF;
    box-shadow: 0 18px 42px rgba(232, 0, 110, 0.28);
}

.landing-premium .btn-distribuidor {
    border: 1px solid rgba(255, 255, 255, 0.38);
    background: rgba(255, 255, 255, 0.08);
    color: #FFFFFF;
}

.landing-proof {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.7rem;
    margin-top: 0.5rem;
}

.landing-proof article {
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.08);
    padding: 0.9rem;
}

.landing-proof strong {
    display: block;
    color: #FFFFFF;
    font-family: var(--font-titulo);
    font-size: 1.55rem;
    font-weight: 900;
}

.landing-proof span {
    color: rgba(255, 255, 255, 0.7);
    font-family: var(--font-texto);
    font-size: 0.82rem;
    font-weight: 700;
}

.gencell-stage {
    position: relative;
    min-height: 620px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gencell-stage__halo {
    position: absolute;
    width: min(560px, 90%);
    aspect-ratio: 1;
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(255, 255, 255, 0.34), rgba(91, 210, 182, 0.18) 38%, rgba(232, 0, 110, 0.12) 62%, transparent 72%);
    filter: blur(3px);
}

.gencell-stage img {
    position: relative;
    z-index: 1;
    object-fit: contain;
    filter: drop-shadow(0 34px 36px rgba(0, 0, 0, 0.38));
}

.gencell-stage__main {
    width: min(470px, 72%);
}

.gencell-stage__support {
    position: absolute !important;
    right: 2%;
    bottom: 8%;
    width: min(280px, 42%);
}

.gencell-stage__badge {
    position: absolute;
    z-index: 3;
    left: 3%;
    bottom: 15%;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 24px 54px rgba(11, 26, 61, 0.24);
    padding: 0.9rem 1rem;
}

.gencell-stage__badge span {
    display: block;
    color: #E8006E;
    font-family: var(--font-texto);
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.gencell-stage__badge strong {
    color: #0B1A3D;
    font-family: var(--font-titulo);
    font-size: 1.05rem;
}

.landing-band {
    padding: 6rem 0;
}

.gencell-spotlight {
    background: linear-gradient(180deg, #FFFFFF 0%, #F3F8FF 100%);
}

.gencell-spotlight__grid,
.business-grid,
.faq-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
    align-items: center;
    gap: 2rem;
}

.spotlight-products {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.spotlight-products article,
.product-showcase__card,
.business-steps article,
.value-grid article,
.testimonial-grid article,
.faq-list article {
    border: 1px solid #D7E5F7;
    border-radius: 10px;
    background: #FFFFFF;
    box-shadow: 0 22px 54px rgba(11, 26, 61, 0.08);
}

.spotlight-products article {
    min-height: 370px;
    display: grid;
    align-content: end;
    justify-items: center;
    gap: 0.5rem;
    padding: 1.2rem;
}

.spotlight-products article.is-featured {
    transform: translateY(-1rem);
    border-color: rgba(232, 0, 110, 0.32);
    box-shadow: 0 28px 62px rgba(232, 0, 110, 0.12);
}

.spotlight-products img {
    width: 100%;
    height: 250px;
    object-fit: contain;
    filter: drop-shadow(0 22px 24px rgba(11, 26, 61, 0.16));
}

.spotlight-products span {
    color: #52657E;
    font-family: var(--font-texto);
    font-weight: 900;
}

.spotlight-products strong {
    color: #E8006E;
    font-family: var(--font-titulo);
    font-size: 1.6rem;
    font-weight: 900;
}

.gencell-spotlight .section-copy h2,
.product-line .section-heading h2,
.why-section .section-heading h2,
.faq-section .section-copy h2 {
    color: #0B1A3D;
}

.gencell-spotlight .section-copy p,
.product-line .section-heading p,
.why-section .section-heading p,
.faq-section .section-copy p {
    color: #52657E;
}

.premium-list {
    display: grid;
    gap: 0.7rem;
    margin: 1.2rem 0;
}

.premium-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    color: #263B58;
    font-family: var(--font-texto);
    font-weight: 800;
    line-height: 1.4;
}

.premium-list i {
    color: #28A173;
    margin-top: 0.1rem;
}

.product-line,
.faq-section {
    background: #F6F9FC;
}

.section-heading {
    max-width: 760px;
    display: grid;
    gap: 1rem;
    margin: 0 auto 2rem;
    text-align: center;
}

.section-heading .landing-kicker {
    margin-inline: auto;
}

.product-showcase {
    display: grid;
    grid-template-columns: 1.15fr repeat(2, minmax(0, 0.85fr));
    gap: 1rem;
}

.product-showcase__card {
    min-height: 260px;
    display: grid;
    align-content: space-between;
    gap: 1rem;
    padding: 1rem;
}

.product-showcase__card--hero {
    grid-row: span 2;
    background: linear-gradient(145deg, #FFFFFF 0%, #EAF3FF 100%);
}

.product-showcase__card img {
    width: 100%;
    height: 170px;
    object-fit: contain;
    filter: drop-shadow(0 18px 24px rgba(11, 26, 61, 0.14));
}

.product-showcase__card--hero img {
    height: 360px;
}

.product-showcase__card span,
.business-steps span {
    color: #E8006E;
    font-family: var(--font-texto);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.product-showcase__card h3,
.business-steps h3,
.value-grid h3,
.faq-list h3 {
    color: #0B1A3D;
    font-family: var(--font-titulo);
    font-size: 1.2rem;
    font-weight: 900;
}

.product-showcase__card p,
.business-steps p,
.value-grid p,
.testimonial-grid p,
.faq-list p {
    color: #52657E;
    font-size: 0.95rem;
    line-height: 1.55;
}

.business-section {
    background:
        linear-gradient(135deg, rgba(11, 26, 61, 0.96), rgba(0, 71, 171, 0.92)),
        url('../img/fondo productos 2.jpeg') center / cover;
}

.business-steps {
    display: grid;
    gap: 1rem;
}

.business-steps article {
    background: rgba(255, 255, 255, 0.96);
    padding: 1.1rem;
}

.why-section {
    background: #FFFFFF;
}

.value-grid,
.testimonial-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.value-grid article {
    padding: 1.15rem;
}

.value-grid i {
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: #EAF7F4;
    color: #28A173;
    font-size: 1.45rem;
    margin-bottom: 1rem;
}

.testimonials-section {
    background: linear-gradient(180deg, #0B1A3D 0%, #10285C 100%);
}

.testimonial-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.testimonial-grid article {
    background: rgba(255, 255, 255, 0.96);
    padding: 1.2rem;
}

.testimonial-grid .estrellas {
    color: #E8006E;
    margin-bottom: 0.75rem;
}

.testimonial-grid strong {
    display: block;
    color: #0B1A3D;
    font-family: var(--font-titulo);
    margin-top: 1rem;
}

.faq-list {
    display: grid;
    gap: 1rem;
}

.faq-list article {
    padding: 1rem;
}

.faq-list h3 span {
    color: #E8006E;
}

@media screen and (width < 1020px) {
    .landing-hero__grid,
    .gencell-spotlight__grid,
    .business-grid,
    .faq-grid {
        grid-template-columns: 1fr;
    }

    .landing-hero {
        padding-top: 7rem;
    }

    .gencell-stage {
        min-height: 460px;
        order: -1;
    }

    .product-showcase,
    .value-grid,
    .testimonial-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media screen and (width < 720px) {
    .landing-hero {
        padding-top: 7rem;
    }

    .landing-hero h1 {
        font-size: clamp(2.65rem, 14vw, 4rem);
    }

    .landing-proof,
    .spotlight-products,
    .product-showcase,
    .value-grid,
    .testimonial-grid {
        grid-template-columns: 1fr;
    }

    .spotlight-products article.is-featured {
        transform: none;
    }

    .gencell-stage {
        min-height: 390px;
    }

    .gencell-stage__main {
        width: min(350px, 76%);
    }

    .gencell-stage__support {
        right: 0;
        bottom: 4%;
        width: min(190px, 42%);
    }

    .gencell-stage__badge {
        left: 0;
        bottom: 6%;
    }

    .landing-actions .btn-productos,
    .landing-actions .btn-distribuidor,
    .landing-actions .landing-primary-button {
        width: 100%;
    }

    .product-showcase__card--hero {
        grid-row: auto;
    }

    .product-showcase__card--hero img {
        height: 260px;
    }
}

.landing-premium .inicio:not(.landing-hero) .btn-productos,
.landing-premium .inicio:not(.landing-hero) .btn-distribuidor {
    width: 100%;
    max-width: 300px;
    padding: 15px 18px;
    font-size: clamp(.5rem, .5rem + 2vw, 1.2rem);
}

.landing-premium .inicio:not(.landing-hero) .btn-productos {
    background-color: var(--color-rosa);
    color: var(--color-blanco);
    box-shadow: 0 15px 40px #db048150;
}

.landing-premium .inicio:not(.landing-hero) .btn-distribuidor {
    border: 1px solid var(--color-blanco);
    background-color: transparent;
    color: var(--color-blanco);
}

.finance-kpi .kpi-status.is-active {
    background: #e9f8f1;
    color: #00845f;
}

.network-node.is-draggable {
    cursor: grab;
    transition: transform 160ms ease, box-shadow 160ms ease, outline-color 160ms ease;
}

.network-node.is-draggable:active,
.network-node.is-dragging {
    cursor: grabbing;
}

.network-node.is-dragging {
    opacity: 0.58;
    transform: scale(0.98);
}

.network-node.is-drop-target {
    outline: 3px solid var(--manik-cta);
    outline-offset: 7px;
    transform: translateY(-2px);
    box-shadow: 0 22px 46px rgba(232, 0, 110, 0.18);
}

.network-contact-card {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 12px);
    z-index: 20;
    width: 270px;
    display: grid;
    gap: 0;
    border: 1px solid #CFE0F7;
    border-radius: 12px;
    background: #FFFFFF;
    box-shadow: 0 22px 46px rgba(18, 27, 63, 0.18);
    opacity: 0;
    padding: 0.8rem;
    pointer-events: none;
    text-align: left;
    transform: translateX(-50%) translateY(6px);
    transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
    visibility: hidden;
}

.network-contact-card::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -7px;
    width: 14px;
    height: 14px;
    border-right: 1px solid #CFE0F7;
    border-bottom: 1px solid #CFE0F7;
    background: #FFFFFF;
    transform: translateX(-50%) rotate(45deg);
}

.network-node:hover .network-contact-card,
.network-node:focus-within .network-contact-card {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    visibility: visible;
}

.network-contact-card div {
    display: grid;
    gap: 0.12rem;
    border-bottom: 1px solid #E5EEF9;
    padding: 0.42rem 0;
}

.network-contact-card div:first-child {
    padding-top: 0;
}

.network-contact-card div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.network-node .network-contact-card span {
    width: auto;
    height: auto;
    display: block;
    grid-row: auto;
    margin: 0;
    border-radius: 0;
    background: transparent;
    color: #52657E;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.network-node .network-contact-card strong {
    width: 100%;
    color: var(--manik-dark);
    font-family: var(--font-texto);
    font-size: 0.86rem;
    font-weight: 800;
    line-height: 1.25;
    overflow-wrap: anywhere;
    text-align: left;
    white-space: normal;
}
