*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{

    --primary:#F58A5C;
    --primary-dark:#E96B43;

    --secondary:#FFD89C;

    --background:#FFF9F4;

    --card:#FFFFFF;

    --text:#433E3C;

    --text-light:#8B7F79;

    --shadow:0 18px 45px rgba(245,138,92,.15);

}

body{

    font-family:'Inter',sans-serif;

    background:
    linear-gradient(
        180deg,
        #FFF9F4 0%,
        #FFF3E6 100%
    );

    color:var(--text);

    min-height:100vh;

}

/* =========================
   ONBOARDING
========================= */

.onboarding-card{

    width:100%;

    min-height:100vh;

    display:flex;

    flex-direction:column;

    background:
    linear-gradient(
        180deg,
        #FFF9F5 0%,
        #FFF3EA 100%
    );

}

.top-section{

    height:210px;

    background:
    linear-gradient(
        135deg,
        #FFD8A7,
        #F7A96B
    );

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

    border-bottom-left-radius:55% 28%;
    border-bottom-right-radius:55% 28%;

}

.logo-area img{

    height:80px;

}

.content-section{

    flex:1;

    display:flex;

    flex-direction:column;

    justify-content:center;

    align-items:center;

    padding:70px 30px;

}

.content-section h1{

    max-width:720px;

    color:#463F3C;

    font-size:clamp(2rem,4vw,3.4rem);

    font-weight:800;

    line-height:1.25;

    margin-bottom:60px;

}

.image-area{

    margin-bottom:60px;

}

.image-area img{

    width:100%;

    max-width:380px;

    animation:float 5s ease-in-out infinite;

}

.btn-continuar{
    display:inline-flex;

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

    padding:16px 40px;

    border-radius:50px;

    text-decoration:none;

    color:white;

    font-weight:600;

    background:
    linear-gradient(
        135deg,
        #2563eb,
        #1d4ed8
    );

    box-shadow:
        0 10px 25px rgba(37,99,235,.25);

    transition:.3s;
}

.btn-continuar{

    display:inline-flex;

    justify-content:center;

    align-items:center;

    min-width:220px;

    padding:18px 45px;

    border-radius:40px;

    text-decoration:none;

    color:white;

    font-weight:700;

    letter-spacing:.4px;

    background:
    linear-gradient(
        135deg,
        #F58A5C,
        #F4A261
    );

    box-shadow:
    0 15px 35px rgba(245,138,92,.35);

    transition:.35s;

}

.btn-continuar:hover{

    transform:translateY(-4px);

    box-shadow:
    0 22px 45px rgba(245,138,92,.45);

}


/* =========================
   HEADER
========================= */

.header{

    position:fixed;

    top:0;
    left:0;

    width:100%;
    height:85px;

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

    padding:0 35px;

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

    backdrop-filter:blur(18px);

    box-shadow:
    0 5px 20px rgba(0,0,0,.04);

    z-index:999;
}

.logo{
    display:flex;
    align-items:center;
}

.logo img{
    height:55px;
    display:block;
}

/* =========================
   BOTÓN HAMBURGUESA
========================= */

.menu-btn{

    width:52px;
    height:52px;

    border:none;

    border-radius:18px;

    background:#FFF4EB;

    color:var(--primary);

    font-size:1.3rem;

    cursor:pointer;

    transition:.3s;

}

.menu-btn:hover{

    background:var(--primary);

    color:white;

}

/* =========================
   MENÚ DESPLEGABLE
========================= */

.menu-dropdown{
    position:fixed;

    top:85px;
    right:40px;

    width:250px;

    background:white;

    border-radius:20px;

    box-shadow:
        0 20px 40px rgba(0,0,0,.12);

    overflow:hidden;

    display:none;

    z-index:10000;
}

.menu-dropdown.active{
    display:block;
}

.menu-dropdown a{
    display:block;

    padding:16px 22px;

    text-decoration:none;

    color:#1e293b;

    font-weight:500;

    transition:.25s;
}

.menu-dropdown a:hover{
    background:#f8fafc;
    color:#2563eb;
}

/* =========================
   HERO
========================= */

.hero{

    width:92%;

    max-width:1200px;

    margin:95px auto 0;

    min-height:620px;

    border-radius:40px;

    background:
    linear-gradient(
        135deg,
        #F7B267,
        #F58A5C
    );

    box-shadow:
    0 30px 60px rgba(245,138,92,.25);

}

.hero-overlay{
    width:100%;
    height:100%;

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

    padding:60px;
}

.hero-content{
    text-align:center;
    color:white;

    width:100%;
    max-width:900px;
}

.hero-tag{
    display:inline-block;

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

    border:1px solid rgba(255,255,255,.2);

    padding:10px 18px;

    border-radius:50px;

    margin-bottom:20px;

    font-size:.9rem;
}

.hero h1{
    font-size:clamp(2rem,5vw,4rem);
    font-weight:800;
    margin-bottom:20px;
}

.hero p{
    max-width:700px;
    margin:auto;

    line-height:1.8;
    font-size:1.1rem;

    opacity:.95;
}

/* =========================
   PLAY BUTTON
========================= */

.play-button{
    width:90px;
    height:90px;

    border:none;
    border-radius:50%;

    margin-top:35px;

    background:white;

    color:var(--primary);

    cursor:pointer;

    font-size:1.8rem;

    box-shadow:
        0 15px 40px rgba(0,0,0,.15);

    transition:.3s;
}

.play-button:hover{
    transform:scale(1.08);
}

/* =========================
   CARDS
========================= */

.cards-container{
    width:90%;
    max-width:1200px;

    margin:50px auto 80px;

    display:grid;

    grid-template-columns:
        repeat(auto-fit,minmax(320px,1fr));

    gap:30px;
}

.card{

    background:white;

    border-radius:28px;

    padding:35px;

    box-shadow:0 15px 40px rgba(0,0,0,.06);

    transition:.35s;

}

.card:hover{
    transform:translateY(-10px);

    box-shadow:
        0 25px 50px rgba(15,23,42,.12);
}

.card-icon{

    width:72px;
    height:72px;

    border-radius:22px;

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

    color:white;

    background:
    linear-gradient(
        135deg,
        #F58A5C,
        #F7B267
    );

}

.card h3{
    font-size:1.4rem;
    margin-bottom:15px;
}

.card p{
    color:var(--text-light);
    line-height:1.8;
    margin-bottom:25px;
}

.card-btn{

    display:inline-flex;

    text-decoration:none;

    padding:14px 28px;

    border-radius:40px;

    background:
    linear-gradient(
        135deg,
        #F58A5C,
        #F4A261
    );

    color:white;

    font-weight:600;

    transition:.3s;

}

.card-btn:hover{

    transform:translateY(-3px);

}

/* =========================
   BOTÓN FLOTANTE
========================= */

.floating-button{
    position:fixed;

    right:30px;
    bottom:30px;

    width:70px;
    height:70px;

    border-radius:50%;

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

    text-decoration:none;

    color:white;

    background:
    linear-gradient(
        135deg,
        #ec4899,
        #d946ef
    );

    box-shadow:
        0 15px 35px rgba(217,70,239,.35);

    font-size:1.5rem;

    transition:.3s;
}

.floating-button:hover{
    transform:scale(1.1);
}



/* =========================
   RESPONSIVE
========================= */

@media(max-width:768px){

    .header{
        padding:0 20px;
    }

    .hero{
        width:95%;
        min-height:420px;
        margin-top:90px;
    }

    .hero-overlay{
        padding:40px 25px;
    }

    .hero h1{
        font-size:2.5rem;
    }

    .cards-container{
        grid-template-columns:1fr;
    }

    .menu-dropdown{
        top:80px;
        right:20px;
        width:220px;
    }

}