/*=============================
        VARIABLES
=============================*/

:root{

    --color-bg:#FDF3E7;

    --color-primary:#AEE6C8;

    --color-dark:#433053;

    --color-text:#3D3D3D;

    --radius:18px;

    --shadow:0 8px 18px rgba(0,0,0,.08);

    --font:'Poppins',sans-serif;

}

/*=============================
        RESET
=============================*/

*{

    margin:0;
    padding:0;
    box-sizing:border-box;

}

body{

    font-family:var(--font);
    background:var(--color-bg);

}

/*=============================
        PANTALLAS
=============================*/

.screen{

    width:100%;
    min-height:100vh;

    display:flex;
    justify-content:center;
    align-items:center;

    position:relative;

    overflow:hidden;

}

.content{

    width:100%;
    max-width:420px;
    min-height:100vh;

    padding:40px 30px;

    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;

    position:relative;

    z-index:5;

}

/*=============================
        LOGO
=============================*/

.logo{

    width:170px;

    margin-bottom:45px;

}

/*=============================
        TITULOS
=============================*/

.title{

    font-size:2.2rem;

    font-weight:500;

    color:var(--color-text);

    line-height:1.25;

    margin-bottom:55px;

}

/*=============================
        ILUSTRACIONES
=============================*/

.illustration{

    width:280px;

    margin-bottom:65px;

}

/*=============================
        BOTONES
=============================*/

.btn-primary{

    background:var(--color-primary);

    color:var(--color-dark);

    border:none;

    border-radius:18px;

    width:220px;

    height:60px;

    display:flex;
    justify-content:center;
    align-items:center;

    text-decoration:none;

    font-size:2rem;

    cursor:pointer;

    transition:.25s;

}

.btn-primary:hover{

    transform:translateY(-2px);

}

/*=============================
        DECORACIONES
=============================*/

.background-shapes{

    position:absolute;

    inset:0;

    overflow:hidden;

}

.circle{

    position:absolute;

    border-radius:50%;

    opacity:.5;

}

.circle-top{

    width:240px;
    height:240px;

    background:#FFD88C;

    right:-80px;
    top:-70px;

}

.circle-bottom{

    width:270px;
    height:270px;

    background:#FFE8BE;

    left:-110px;
    bottom:-90px;

}

.line{

    position:absolute;

    border:3px solid rgba(236,138,118,.45);

    border-radius:999px;

}

.line-left{

    width:280px;
    height:280px;

    left:-180px;
    bottom:80px;

}

.line-right{

    width:300px;
    height:300px;

    right:-170px;
    top:300px;

}

/*=============================*
* HOME
*=============================*/

.home-screen{

    background-image:url("../imagenes/fondo-home.jpg");

    background-size:cover;

    background-position:center;

    background-repeat:no-repeat;

    min-height:100vh;

}

.home-content{

    width:100%;

    max-width:1400px;

    padding:35px;

}

.home-header{

    width:100%;

    display:flex;

    justify-content:space-between;

    align-items:center;

    margin-bottom:35px;

}

.home-logo{

    width:250px;

}

.menu-btn{

    background:none;

    border:none;

    color:var(--color-dark);

    font-size:2.2rem;

    cursor:pointer;

}


.welcome-card{

    width:100%;

    background:rgba(255,255,255,.75);

    border-radius:25px;

    padding:28px;

    margin-bottom:35px;

}

.welcome-card h2{

    font-size:2rem;

    font-weight:500;

    color:var(--color-text);

    margin-bottom:8px;

}

.welcome-card p{

    font-size:1.6rem;

    color:#D76D5B;

}


.video-section{

    width:100%;

    margin-bottom:40px;

}

.video-section video{

    width:100%;

    border-radius:30px;

    display:block;

}


.cards-container{

    width:100%;

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:25px;

}

.info-card{

    display:flex;

    flex-direction:column;

    align-items:center;

    text-align:center;

    background:rgba(255,255,255,.82);

    border-radius:28px;

    padding:22px;

    height:100%;

}

.info-card img{

    width:180px;

    max-width:100%;

    height:auto;

    margin-bottom:20px;

}

.info-text{

    display:flex;

    flex-direction:column;

    align-items:center;

    flex:1;

}

.info-text h3{

    margin-bottom:15px;

}

.info-text p{

    margin-bottom:20px;

}

.btn-card{

    display:inline-flex;

    justify-content:center;

    align-items:center;

    background:var(--color-primary);

    color:var(--color-dark);

    text-decoration:none;

    border-radius:15px;

    padding:12px 28px;

    font-size:1rem;

    font-weight:500;

    transition:.25s;

}

.btn-card:hover{

    transform:translateY(-2px);

}

.phone-btn{

    position:fixed;

    right:25px;

    bottom:25px;

    width:70px;

    height:70px;

    border-radius:50%;

    background:#E3644D;

    display:flex;

    justify-content:center;

    align-items:center;

    text-decoration:none;

    color:#FFFFFF;

    font-size:2rem;

    box-shadow:0 8px 18px rgba(0,0,0,.25);

    z-index:9999;

}

.phone-btn i{

    color:#FFFFFF;

}


/*=============================*
*LOGIN*
*=============================*/

.login-content{

    justify-content:flex-start;

    padding-top:40px;

}

.back-btn{

    position:absolute;

    left:30px;

    top:45px;

    font-size:2rem;

    color:var(--color-dark);

    text-decoration:none;

}

.login-card{

    width:100%;

    background:rgba(255,248,240,.78);

    backdrop-filter:blur(8px);

    border-radius:35px;

    padding:35px 25px 40px;

    box-shadow:var(--shadow);

    text-align:left;

}

.login-title{

    font-size:2rem;

    font-weight:500;

    color:var(--color-text);

    margin-bottom:8px;

}

.login-subtitle{

    font-size:1.1rem;

    color:var(--color-text);

    margin-bottom:35px;

}

.login-card label{

    display:block;

    font-size:1rem;

    color:var(--color-text);

    margin-bottom:10px;

    margin-top:20px;

}

.input-group{

    width:100%;

    height:58px;

    background:#FFD88C;

    border-radius:20px;

    display:flex;

    align-items:center;

    padding:0 18px;

}

.input-group i{

    color:var(--color-dark);

    font-size:1.3rem;

    margin-right:14px;

}

.input-group input{

    width:100%;

    border:none;

    outline:none;

    background:transparent;

    font-family:var(--font);

    font-size:1rem;

    color:var(--color-text);

}

.forgot-password{

    display:block;

    margin-top:22px;

    margin-bottom:35px;

    text-decoration:none;

    color:#DB6E5C;

    font-size:1rem;

}

.login-card .btn-primary{

    margin:auto;

}

/*=============================
        BIENVENIDA
=============================*/

.content-scroll{

    justify-content:flex-start;

    padding-top:45px;
    padding-bottom:40px;

}

.welcome-text{

    width:100%;

    text-align:left;

    margin-bottom:45px;

}

.welcome-title{

    font-size:2.2rem;

    font-weight:500;

    color:var(--color-text);

    margin-bottom:20px;

}

.welcome-text p{

    font-size:1.05rem;

    color:var(--color-text);

    line-height:1.45;

    margin-bottom:30px;

}

.highlight{

    color:#D76D5B;

    font-weight:500;

    font-size:1.15rem;

    margin-top:10px;


}

.content-scroll .btn-primary{
    margin-top:auto;
}

/*=============================*
* TABLETS
*=============================*/

@media (max-width:768px){

    .content{

        max-width:390px;
        padding:35px 25px;

    }

    .logo{

        width:155px;
        margin-bottom:35px;

    }

    .title{

        font-size:2rem;

    }

    .illustration{

        width:240px;

    }

    .welcome-title{

        font-size:2rem;

    }

    /*=============================*
    * HOME TABLETS
    *=============================*/

    .home-logo{

        width:190px;

    }

    .cards-container{

        grid-template-columns:1fr;
        gap:20px;

    }

    .info-card{

    flex-direction:column;

    align-items:center;

    text-align:center;

    gap:18px;

}

.info-card img{

    width:180px;

    margin-bottom:0;

}

.info-text{

    align-items:center;

}

}

/*=============================*
* CELULARES
*=============================*/

@media (max-width:480px){

    .content{

        padding:30px 22px;

    }

    .logo{

        width:145px;
        margin-bottom:35px;

    }

    .title{

        font-size:1.55rem;
        margin-bottom:45px;

    }

    .illustration{

        width:240px;
        max-width:90%;
        margin-bottom:50px;

    }

    .welcome-title{

        font-size:1.9rem;

    }

    .welcome-text p{

        font-size:1rem;
        line-height:1.45;

    }

    .highlight{

        font-size:1.1rem;

    }

    .btn-primary{

        width:200px;
        height:55px;
        font-size:1.7rem;

    }

    /*=============================*
    * LOGIN
    *=============================*/

    .login-card{

        padding:28px 20px 35px;

    }

    .login-title{

        font-size:1.8rem;

    }

    .login-subtitle{

        font-size:1rem;

    }

    .input-group{

        height:55px;

    }

    .back-btn{

        left:22px;
        top:30px;

    }

    /*=============================*
    * HOME CELULARES
    *=============================*/

    .home-content{

        padding:22px;

    }

    .home-logo{

        width:165px;

    }

    .home-header{

        margin-bottom:25px;

    }

    .menu-btn{

        font-size:2rem;

    }

    .welcome-card{

        padding:22px;
        margin-bottom:25px;

    }

    .welcome-card h2{

        font-size:1.6rem;

    }

    .welcome-card p{

        font-size:1.2rem;

    }

    .video-section{

        margin-bottom:30px;

    }

    .cards-container{

        grid-template-columns:1fr;
        gap:18px;

    }

    .info-card{

        flex-direction:row;
        align-items:center;
        text-align:left;
        gap:15px;
        padding:18px;

    }

    .info-card img{

        width:120px;
        margin-bottom:0;
        flex-shrink:0;

    }

    .info-text{

        align-items:flex-start;

    }

    .info-text h3{

        font-size:1.3rem;

    }

    .info-text p{

        font-size:.95rem;

    }

    .phone-btn{

        width:65px;
        height:65px;
        right:20px;
        bottom:20px;
        font-size:1.8rem;

    }

}