@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

:root{
    --bg:#030712;
    --bg-soft:#0f172a;

    --primary:#2563eb;
    --primary-light:#60a5fa;

    --card:rgba(255,255,255,.04);
    --border:rgba(255,255,255,.08);

    --text:#ffffff;
    --muted:#94a3b8;
}

*{
    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;
    line-height:1.6;
}

/* BACKGROUND */

body::before{

    content:"";

    position:fixed;

    inset:0;

    background:
    radial-gradient(circle at 20% 20%, rgba(37,99,235,.15), transparent 30%),
    radial-gradient(circle at 80% 20%, rgba(37,99,235,.10), transparent 30%);

    z-index:-20;

}

#particles-js{

    position:fixed;

    inset:0;

    z-index:-10;

}

/* HEADER */

header{

    position:fixed;

    top:0;

    width:100%;

    z-index:1000;

    backdrop-filter:blur(20px);

    background:rgba(3,7,18,.85);

    border-bottom:1px solid rgba(255,255,255,.05);

}

.navbar{

    max-width:1400px;

    margin:auto;

    min-height:95px;

    padding:0 40px;

    display:flex;

    align-items:center;

    justify-content:space-between;

}

.logo{
    position:relative;
}

.logo::before{

    content:"";

    position:absolute;

    width:180px;

    height:180px;

    left:50%;

    top:50%;

    transform:translate(-50%,-50%);

    background:
    radial-gradient(
      rgba(37,99,235,.18),
      transparent
    );

    filter:blur(50px);

    z-index:-1;

}

.logo img{

    height:90px;

    width:auto;

    object-fit:contain;

}

/* MENU */

.menu{

    display:flex;

    gap:35px;

    list-style:none;

}

.menu a{

    color:white;

    text-decoration:none;

    font-weight:500;

    position:relative;

}

.menu a::after{

    content:"";

    position:absolute;

    left:0;

    bottom:-6px;

    width:0;

    height:2px;

    background:var(--primary-light);

    transition:.3s;

}

.menu a:hover::after{

    width:100%;

}

/* HERO */

.hero{

    min-height:100vh;

    display:flex;

    justify-content:center;

    align-items:center;

    text-align:center;

    padding-top:140px;

    position:relative;

}

.hero::before{

    content:"";

    position:absolute;

    width:700px;

    height:700px;

    border-radius:50%;

    background:
    radial-gradient(
        rgba(37,99,235,.25),
        transparent
    );

    filter:blur(120px);

    z-index:-1;

}

.hero-content{

    max-width:1000px;

    padding:20px;

}

.hero-badge{

    display:inline-block;

    padding:12px 24px;

    border-radius:999px;

    background:rgba(255,255,255,.05);

    border:1px solid rgba(59,130,246,.25);

    margin-bottom:25px;

}

.hero h1{

    font-size:5rem;

    line-height:1.05;

    font-weight:800;

    margin-bottom:25px;

}

.hero span{
    color:var(--primary-light);
}

.hero p{

    max-width:800px;

    margin:0 auto 40px;

    color:var(--muted);

    font-size:1.2rem;

}

.hero-buttons{

    display:flex;

    justify-content:center;

    gap:20px;

    flex-wrap:wrap;

}

/* BOTÕES */

.btn{

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--primary-light)
    );

    color:white;

    text-decoration:none;

    padding:18px 36px;

    border-radius:999px;

    font-weight:700;

    transition:.3s;

}

.btn:hover{

    transform:translateY(-4px);

}

.btn-outline{

    border:1px solid rgba(255,255,255,.12);

    color:white;

    text-decoration:none;

    padding:18px 36px;

    border-radius:999px;

}

/* GERAL */

section{

    padding:100px 20px;

}

.container{

    max-width:1200px;

    margin:auto;

}

h2{

    text-align:center;

    font-size:3rem;

    margin-bottom:60px;

}

.portfolio-card h3 a {

    color: inherit;

    text-decoration: none;

    transition: 0.3s ease;
}

.portfolio-card h3 a:hover {

    color: #0f4c81;

    text-decoration: underline;
}

.section-subtitle{

    text-align:center;

    color:var(--muted);

    margin-bottom:40px;

}

/* STATS */

.stats-grid{

    display:grid;

    grid-template-columns:
    repeat(4,1fr);

    gap:25px;

}

.stat{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:20px;

    padding:30px;

    text-align:center;

}

.stat h3{

    font-size:3rem;

    color:var(--primary-light);

}

/* PROCESSO */

.process-grid{

    display:grid;

    grid-template-columns:
    repeat(5,1fr);

    gap:20px;

}

.process-card{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:20px;

    padding:25px;

    text-align:center;

}

.process-card h3{

    color:var(--primary-light);

    font-size:3rem;

}

/* PORTFÓLIO */

.portfolio-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:30px;

}

.portfolio-card{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:25px;

    overflow:hidden;

    transition:.3s;

}

.portfolio-card:hover{

    transform:translateY(-8px);

}

.portfolio-gallery{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:8px;

    padding:15px;

}

.portfolio-gallery img{

    width:100%;

    height:260px;

    object-fit:cover;

    border-radius:15px;

    transition:.4s;

}

.portfolio-gallery img:hover{

    transform:scale(1.03);

}

.portfolio-card h3{

    padding:15px 20px 10px;

}

.portfolio-card p{

    padding:0 20px 25px;

    color:var(--muted);

}

/* BENEFÍCIOS */

.cards{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:25px;

}

.card{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:20px;

    padding:30px;

    text-align:center;

}

/* PLANOS */

.planos{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:30px;

    align-items:stretch;

}

.plano{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:25px;

    padding:40px 30px;

    display:flex;

    flex-direction:column;

}

.destaque{

    border:2px solid var(--primary);

    transform:scale(1.03);

}

.badge-popular{

    background:var(--primary);

    color:white;

    padding:8px 14px;

    border-radius:999px;

    font-size:.8rem;

    display:inline-block;

    margin-bottom:20px;

}

.valor{

    font-size:2.2rem;

    color:var(--primary-light);

    font-weight:800;

    margin:20px 0;

}

.plano-indicado{

    min-height:90px;

    color:var(--muted);

}

.plano ul{

    list-style:none;

    margin:20px 0;

    flex-grow:1;

}

.plano li{

    margin-bottom:12px;

}

/* FAQ */

.faq-item{

    background:var(--card);

    border:1px solid var(--border);

    border-radius:20px;

    padding:25px;

    margin-bottom:20px;

}

.faq-item p{

    color:var(--muted);

}

/* CTA */

.cta{

    text-align:center;

}

.cta p{

    color:var(--muted);

    margin-bottom:30px;

}

/* FOOTER */

footer{

    text-align:center;

    padding:40px;

    color:var(--muted);

    border-top:1px solid var(--border);

}

/* MOBILE */

@media(max-width:992px){

    .hero h1{
        font-size:3rem;
    }

    .stats-grid,
    .process-grid,
    .cards,
    .planos,
    .portfolio-grid{

        grid-template-columns:1fr;

    }

}

@media(max-width:768px){

    .navbar{

        flex-direction:column;

        gap:15px;

        padding:20px;

    }

    .menu{

        flex-wrap:wrap;

        justify-content:center;

    }

    .hero{

        padding-top:220px;

    }

    .hero h1{

        font-size:2.3rem;

    }

    h2{

        font-size:2rem;

    }

    .portfolio-gallery{

        grid-template-columns:1fr;

    }

}