/* ==========================================================
   FAD APP
   STYLE.CSS
   PARTE 1
   Reset + Header + Hero
========================================================== */

:root{

    --primary:#2563eb;
    --primary-dark:#1d4ed8;
    --secondary:#0f172a;
    --accent:#38bdf8;

    --text:#334155;
    --title:#0f172a;

    --white:#ffffff;

    --bg:#f8fafc;
    --bg-light:#ffffff;

    --border:#e2e8f0;

    --shadow:0 12px 40px rgba(15,23,42,.08);

    --radius:18px;

    --transition:.35s ease;

}

/*========================*/

*{

    margin:0;
    padding:0;
    box-sizing:border-box;

}

html{

    scroll-behavior:smooth;

}

body{

    font-family:'Poppins',sans-serif;

    background:var(--bg);

    color:var(--text);

    overflow-x:hidden;

}

img{

    max-width:100%;

    display:block;

    height:auto;

}

a{

    text-decoration:none;

}

ul{

    list-style:none;

}

.container{

    width:min(1200px,92%);

    margin:auto;

}

/*======================================================
HEADER
======================================================*/

header{

    position:fixed;

    top:0;

    left:0;

    width:100%;

    z-index:999;

    background:rgba(255,255,255,.88);

    backdrop-filter:blur(16px);

    -webkit-backdrop-filter:blur(16px);

    border-bottom:1px solid rgba(0,0,0,.05);

    transition:.3s;

}

header .container{

    min-height:85px;

    display:flex;

    align-items:center;

    justify-content:space-between;

    gap:30px;

}

.logo img{

    width:80px;

}

/*========================*/

nav{

    display:flex;

    align-items:center;

    gap:34px;

}

nav a{

    color:var(--title);

    font-size:.95rem;

    font-weight:500;

    transition:var(--transition);

    position:relative;

}

nav a::after{

    content:"";

    position:absolute;

    left:0;

    bottom:-6px;

    width:0;

    height:2px;

    background:var(--primary);

    transition:.3s;

}

nav a:hover{

    color:var(--primary);

}

nav a:hover::after{

    width:100%;

}

/*========================*/

.menu-toggle{

    display:none;

    border:none;

    background:none;

    cursor:pointer;

    font-size:1.8rem;

    color:var(--title);

}

/*======================================================
BOTÕES
======================================================*/

.btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    gap:10px;

    padding:15px 30px;

    background:linear-gradient(135deg,var(--primary),var(--accent));

    color:#fff;

    border-radius:999px;

    font-weight:600;

    transition:.35s;

    box-shadow:0 15px 30px rgba(37,99,235,.25);

}

.btn:hover{

    transform:translateY(-4px);

    box-shadow:0 20px 40px rgba(37,99,235,.35);

}

.btn-outline{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    gap:10px;

    padding:15px 28px;

    border:2px solid var(--primary);

    border-radius:999px;

    color:var(--primary);

    font-weight:600;

    transition:.35s;

}

.btn-outline:hover{

    background:var(--primary);

    color:#fff;

}

/*======================================================
HERO
======================================================*/

.hero{

    position:relative;

    overflow:hidden;

    padding-top:170px;

    padding-bottom:100px;

    background:
    radial-gradient(circle at top right,#dbeafe 0%,transparent 35%),
    radial-gradient(circle at left,#e0f2fe 0%,transparent 40%),
    var(--bg);

}

.hero-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    align-items:center;

    gap:80px;

}

.hero-content{

    animation:fadeLeft .8s ease;

}

.tag{

    display:inline-block;

    padding:8px 18px;

    border-radius:999px;

    background:#dbeafe;

    color:var(--primary);

    font-weight:700;

    font-size:.82rem;

    letter-spacing:.5px;

    margin-bottom:25px;

}

.hero h1{

    font-size:clamp(2.8rem,5vw,4.6rem);

    color:var(--title);

    line-height:1.1;

    font-weight:800;

    margin-bottom:25px;

}

.hero h1 span{

    color:var(--primary);

}

.hero p{

    font-size:1.08rem;

    line-height:1.9;

    margin-bottom:40px;

    max-width:560px;

}

/*========================*/

.hero-buttons{

    display:flex;

    gap:18px;

    flex-wrap:wrap;

}

/*========================*/

.numbers{

    margin-top:55px;

    display:flex;

    gap:45px;

    flex-wrap:wrap;

}

.numbers div{

    text-align:center;

}

.numbers h2{

    color:var(--primary);

    font-size:2.1rem;

    font-weight:800;

}

.numbers span{

    font-size:.92rem;

    color:#64748b;

}

/*======================================================
IMAGEM HERO
======================================================*/

.hero-image{

    display:flex;

    justify-content:center;

    animation:fadeRight .8s ease;

}

.hero-image img{

    width:100%;

    max-width:580px;

    filter:drop-shadow(0 35px 50px rgba(0,0,0,.15));

    animation:float 5s ease-in-out infinite;

}

/*======================================================
ANIMAÇÕES
======================================================*/

@keyframes float{

    0%{

        transform:translateY(0px);

    }

    50%{

        transform:translateY(-15px);

    }

    100%{

        transform:translateY(0);

    }

}

@keyframes fadeLeft{

    from{

        opacity:0;

        transform:translateX(-50px);

    }

    to{

        opacity:1;

        transform:translateX(0);

    }

}

@keyframes fadeRight{

    from{

        opacity:0;

        transform:translateX(50px);

    }

    to{

        opacity:1;

        transform:translateX(0);

    }

}

/*==========================================================
APLICATIVOS
==========================================================*/

.apps{

    padding:110px 0;

    background:#ffffff;

}

.apps h2{

    text-align:center;

    font-size:2.5rem;

    color:var(--title);

    margin-bottom:18px;

}

.subtitle{

    max-width:700px;

    margin:auto;

    text-align:center;

    color:#64748b;

    line-height:1.8;

    margin-bottom:70px;

    font-size:1.05rem;

}

/*========================*/

.cards{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));

    gap:35px;

}

/*========================*/

.card{

    background:#fff;

    border-radius:22px;

    padding:40px;

    border:1px solid var(--border);

    transition:.35s;

    box-shadow:0 8px 30px rgba(15,23,42,.05);

    display:flex;

    flex-direction:column;

    align-items:flex-start;

    position:relative;

    overflow:hidden;

}

.card::before{

    content:"";

    position:absolute;

    top:0;

    left:0;

    width:100%;

    height:5px;

    background:linear-gradient(90deg,var(--primary),var(--accent));

    transform:scaleX(0);

    transform-origin:left;

    transition:.4s;

}

.card:hover{

    transform:translateY(-12px);

    box-shadow:0 20px 45px rgba(37,99,235,.15);

}

.card:hover::before{

    transform:scaleX(1);

}

.card img{

    width:95px;

    margin-bottom:25px;

}

.card h3{

    color:var(--title);

    font-size:1.5rem;

    margin-bottom:18px;

}

.card p{

    color:#64748b;

    line-height:1.9;

    flex:1;

    margin-bottom:30px;

}

.card a{

    color:var(--primary);

    font-weight:700;

    transition:.3s;

}

.card a:hover{

    letter-spacing:.5px;

}

/*==========================================================
BENEFÍCIOS
==========================================================*/

.benefits{

    padding:110px 0;

    background:linear-gradient(180deg,#f8fafc,#eef6ff);

}

.benefits h2{

    text-align:center;

    font-size:2.4rem;

    margin-bottom:70px;

    color:var(--title);

}

/*========================*/

.benefits-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));

    gap:30px;

}

/*========================*/

.benefits-grid>div{

    background:#fff;

    border-radius:20px;

    padding:40px 30px;

    text-align:center;

    transition:.35s;

    border:1px solid rgba(0,0,0,.05);

    box-shadow:0 10px 35px rgba(0,0,0,.05);

}

.benefits-grid>div:hover{

    transform:translateY(-10px);

    box-shadow:0 20px 40px rgba(37,99,235,.12);

}

.benefits-grid i{

    width:78px;

    height:78px;

    display:flex;

    align-items:center;

    justify-content:center;

    margin:auto;

    margin-bottom:25px;

    border-radius:50%;

    background:linear-gradient(135deg,var(--primary),var(--accent));

    color:#fff;

    font-size:30px;

}

.benefits-grid h3{

    font-size:1.35rem;

    color:var(--title);

    margin-bottom:15px;

}

.benefits-grid p{

    color:#64748b;

    line-height:1.8;

}

/*==========================================================
CTA
==========================================================*/

.cta{

    position:relative;

    overflow:hidden;

    padding:120px 0;

    background:linear-gradient(135deg,#2563eb,#0f172a);

    color:#fff;

    text-align:center;

}

.cta::before{

    content:"";

    position:absolute;

    width:500px;

    height:500px;

    background:rgba(255,255,255,.05);

    border-radius:50%;

    top:-250px;

    right:-150px;

}

.cta::after{

    content:"";

    position:absolute;

    width:350px;

    height:350px;

    background:rgba(255,255,255,.04);

    border-radius:50%;

    bottom:-180px;

    left:-120px;

}

.cta .container{

    position:relative;

    z-index:5;

}

.cta h2{

    font-size:2.7rem;

    margin-bottom:25px;

    line-height:1.3;

}

.cta p{

    max-width:700px;

    margin:auto;

    line-height:1.9;

    opacity:.92;

    margin-bottom:45px;

    font-size:1.05rem;

}

.cta .btn{

    background:#fff;

    color:var(--primary);

    box-shadow:0 18px 45px rgba(255,255,255,.15);

}

.cta .btn:hover{

    transform:translateY(-5px);

}

/*==========================================================
FOOTER
==========================================================*/

footer{

    background:#0f172a;

    color:#cbd5e1;

    padding:90px 0 40px;

}

.footer-grid{

    display:grid;

    grid-template-columns:2fr 1fr 1.2fr;

    gap:60px;

}

footer h3{

    color:#fff;

    margin-bottom:22px;

    font-size:1.4rem;

}

footer p{

    line-height:1.9;

    margin-bottom:12px;

}

footer ul{

    display:flex;

    flex-direction:column;

    gap:14px;

}

footer ul li{

    transition:.3s;

    cursor:pointer;

}

footer ul li:hover{

    color:#fff;

    padding-left:8px;

}

footer i{

    color:#60a5fa;

    width:22px;

}

/*========================*/

footer a{

    color:#fff;

}

/*==========================================================
EFEITO DE APARECIMENTO
==========================================================*/

.card,
.benefits-grid>div{

    animation:fadeUp .8s ease both;

}

@keyframes fadeUp{

    from{

        opacity:0;

        transform:translateY(35px);

    }

    to{

        opacity:1;

        transform:translateY(0);

    }

}

/*==========================================================
RESPONSIVIDADE
==========================================================*/

/* Desktop Grande */
@media (max-width:1400px){

    .container{
        width:min(1200px,94%);
    }

}

/* Notebook */
@media (max-width:1200px){

    .hero-grid{

        gap:50px;

    }

    .hero h1{

        font-size:3.5rem;

    }

    .cards{

        grid-template-columns:repeat(2,1fr);

    }

}

/*==========================================================
TABLET
==========================================================*/

@media (max-width:992px){

    header .container{

        min-height:75px;

    }

    .desktop-btn{

        display:none;

    }

    .menu-toggle{

        display:block;

        z-index:1001;

    }

    nav{

        position:fixed;

        top:75px;

        left:-100%;

        width:100%;

        height:calc(100vh - 75px);

        background:#fff;

        display:flex;

        flex-direction:column;

        justify-content:flex-start;

        align-items:center;

        gap:30px;

        padding-top:60px;

        transition:.35s;

        box-shadow:0 20px 40px rgba(0,0,0,.08);

    }

    nav.active{

        left:0;

    }

    nav a{

        font-size:1.15rem;

    }

    .hero{

        padding-top:130px;

    }

    .hero-grid{

        grid-template-columns:1fr;

        text-align:center;

        gap:60px;

    }

    .hero-content{

        order:2;

    }

    .hero-image{

        order:1;

    }

    .hero p{

        max-width:700px;

        margin:25px auto 40px;

    }

    .hero-buttons{

        justify-content:center;

    }

    .numbers{

        justify-content:center;

    }

    .hero-image img{

        max-width:480px;

    }

    .footer-grid{

        grid-template-columns:1fr;

        text-align:center;

    }

    footer ul{

        align-items:center;

    }

}

/*==========================================================
CELULAR GRANDE
==========================================================*/

@media (max-width:768px){

    .hero{

        padding-top:120px;

        padding-bottom:70px;

    }

    .hero h1{

        font-size:2.7rem;

    }

    .hero p{

        font-size:1rem;

    }

    .cards{

        grid-template-columns:1fr;

    }

    .benefits-grid{

        grid-template-columns:1fr;

    }

    .hero-buttons{

        flex-direction:column;

        align-items:stretch;

    }

    .hero-buttons .btn,
    .hero-buttons .btn-outline{

        width:100%;

        justify-content:center;

    }

    .numbers{

        gap:25px;

    }

    .numbers div{

        flex:1;

    }

    .cta{

        padding:90px 0;

    }

    .cta h2{

        font-size:2rem;

    }

    .cta p{

        font-size:1rem;

    }

    .apps,
    .benefits{

        padding:80px 0;

    }

}

/*==========================================================
CELULAR
==========================================================*/

@media (max-width:576px){

    .logo img{

        width:50px;

    }

    .hero h1{

        font-size:2.2rem;

    }

    .hero-image img{

        max-width:320px;

    }

    .card{

        padding:28px;

    }

    .benefits-grid > div{

        padding:30px 25px;

    }

    .benefits-grid i{

        width:65px;

        height:65px;

        font-size:24px;

    }

    .apps h2,
    .benefits h2{

        font-size:2rem;

    }

    .subtitle{

        font-size:.95rem;

    }

    .cta h2{

        font-size:1.8rem;

    }

    footer{

        padding:70px 0 30px;

    }

}

/*==========================================================
CELULARES PEQUENOS
==========================================================*/

@media (max-width:360px){

    .container{

        width:94%;

    }

    .hero h1{

        font-size:1.9rem;

    }

    .btn,
    .btn-outline{

        padding:14px 20px;

        font-size:.9rem;

    }

    .card{

        padding:22px;

    }

    .numbers{

        flex-direction:column;

        gap:15px;

    }

}

/*==========================================================
SCROLLBAR
==========================================================*/

::-webkit-scrollbar{

    width:10px;

}

::-webkit-scrollbar-track{

    background:#eef2f7;

}

::-webkit-scrollbar-thumb{

    background:linear-gradient(var(--primary),var(--accent));

    border-radius:20px;

}

::-webkit-scrollbar-thumb:hover{

    background:var(--primary-dark);

}

/*==========================================================
SELEÇÃO DE TEXTO
==========================================================*/

::selection{

    background:var(--primary);

    color:#fff;

}

/*==========================================================
FOCUS
==========================================================*/

button,
a{

    outline:none;

}

button:focus-visible,
a:focus-visible{

    outline:3px solid rgba(37,99,235,.35);

    outline-offset:4px;

}

/*==========================================================
MENU MOBILE
==========================================================*/

.menu-toggle{

    transition:.3s;

}

.menu-toggle:hover{

    transform:rotate(90deg);

}

/*==========================================================
EFEITOS
==========================================================*/

.card,
.benefits-grid > div,
.btn,
.btn-outline{

    will-change:transform;

}

/*==========================================================
IMAGENS
==========================================================*/

.hero-image img,
.card img{

    user-select:none;

    -webkit-user-drag:none;

}