/* =========================================================
   RESET
========================================================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

/* =========================================================
   BODY
========================================================= */

body{
    font-family:'Inter',sans-serif;
    background:#ffffff;
    color:#0f172a;
    overflow-x:hidden;
}

/* =========================================================
   TITLES
========================================================= */

h1,h2,h3,h4,h5,h6{
    font-family:'Montserrat',sans-serif;
    letter-spacing:-0.03em;
    font-weight:700;
}

/* =========================================================
   CONTAINER
========================================================= */

.container-flex{
    max-width:1280px;
    margin:0 auto;
    padding-left:24px;
    padding-right:24px;
}

/* =========================================================
   GRADIENT TEXT
========================================================= */

.gradient-text{
    background:linear-gradient(90deg,#00cfff 0%,#1d4ed8 100%);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

/* =========================================================
   HEADER BLUR
========================================================= */

.header-blur{
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
}

/* =========================================================
   BUTTONS
========================================================= */

.btn-primary{
    height:56px;
    padding:0 32px;
    border-radius:18px;
    background:#10bdf5;
    color:#ffffff;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    transition:.3s;
}

.btn-primary:hover{
    background:#22d3ee;
}

.btn-outline{
    height:56px;
    padding:0 32px;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.15);
    background:rgba(255,255,255,.04);
    color:#ffffff;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    transition:.3s;
}

.btn-outline:hover{
    border-color:rgba(34,211,238,.4);
}

/* =========================================================
   SECTION TITLE
========================================================= */

.section-kicker{
    color:#00b7ff;
    font-size:13px;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
    margin-bottom:14px;
}

.section-title{
    font-size:42px;
    line-height:1.08;
    font-weight:700;
    color:#0f172a;
}

.section-description{
    margin-top:18px;
    font-size:18px;
    line-height:1.7;
    color:#64748b;
}

/* =========================================================
   CARDS
========================================================= */

.card-soft{
    background:#ffffff;
    border:1px solid #e2e8f0;
    border-radius:28px;
    transition:.3s;
}

.card-soft:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 60px rgba(15,23,42,.08);
}

/* =========================================================
   CUSTOM SCROLLBAR
========================================================= */

html {
    scroll-behavior: smooth;
}

::-webkit-scrollbar{
    width:10px;
}

::-webkit-scrollbar-track{
    background:#020817;
}

::-webkit-scrollbar-thumb{
    background:#0ea5e9;
    border-radius:999px;
}


/* =========================================================
   PÁGINAS JURÍDICAS / LGPD / TERMOS
========================================================= */

.legal-page{
    background:#f6f8fb;
    color:#1f2937;
}

.legal-hero{
    background:linear-gradient(135deg,#0f172a,#1e3a5f);
    color:#ffffff;
    padding:120px 0 70px;
    text-align:center;
}

.legal-tag{
    display:inline-block;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.25);
    padding:8px 16px;
    border-radius:999px;
    font-size:14px;
    margin-bottom:22px;
}

.legal-hero h1{
    font-size:clamp(34px,5vw,58px);
    line-height:1.1;
    margin:0 0 18px;
}

.legal-hero p{
    max-width:760px;
    margin:0 auto 18px;
    font-size:18px;
    color:#dbeafe;
}

.legal-hero small{
    color:#bfdbfe;
}

.legal-content{
    padding:60px 0;
}

.legal-grid{
    display:grid;
    grid-template-columns:270px 1fr;
    gap:32px;
    align-items:start;
}

.legal-menu{
    background:#ffffff;
    border-radius:20px;
    padding:24px;
    box-shadow:0 12px 35px rgba(15,23,42,.08);
    position:sticky;
    top:24px;
}

.legal-menu h3{
    margin:0 0 16px;
    font-size:18px;
    color:#0f172a;
}

.legal-menu a{
    display:block;
    padding:9px 0;
    color:#475569;
    text-decoration:none;
    font-size:15px;
    border-bottom:1px solid #eef2f7;
}

.legal-menu a:hover{
    color:#2563eb;
}

.legal-card{
    background:#ffffff;
    border-radius:24px;
    padding:46px;
    box-shadow:0 12px 35px rgba(15,23,42,.08);
}

.legal-card section{
    padding-bottom:34px;
    margin-bottom:34px;
    border-bottom:1px solid #e5e7eb;
}

.legal-card section:last-child{
    border-bottom:none;
    margin-bottom:0;
    padding-bottom:0;
}

.legal-card h2{
    font-size:26px;
    color:#0f172a;
    margin:0 0 18px;
}

.legal-card h3{
    font-size:19px;
    color:#1e3a5f;
    margin:24px 0 10px;
}

.legal-card p{
    font-size:16.5px;
    line-height:1.75;
    color:#374151;
    margin:0 0 16px;
}

.legal-card ul{
    margin:12px 0 18px 20px;
    padding:0;
}

.legal-card li{
    margin-bottom:9px;
    line-height:1.6;
    color:#374151;
}

.legal-highlight{
    background:#eff6ff;
    border-left:5px solid #2563eb;
    padding:18px 20px;
    border-radius:14px;
    color:#1e3a5f !important;
    font-weight:500;
}

.legal-contact{
    background:#f8fafc;
    padding:32px !important;
    border-radius:20px;
    border:1px solid #e2e8f0 !important;
}

.legal-contact-box{
    background:#ffffff;
    padding:22px;
    border-radius:16px;
    border:1px solid #e5e7eb;
}

.legal-contact-box p{
    margin-bottom:8px;
}

@media(max-width:900px){
    .legal-grid{
        grid-template-columns:1fr;
    }

    .legal-menu{
        position:relative;
        top:auto;
    }

    .legal-card{
        padding:28px;
    }

    .legal-hero{
        padding:110px 0 50px;
    }
}