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

:root {
    --azul: #1592ff;
    --azul2: #2e7bff;
    --ciano: #25d8e8;
    --amarelo: #ffd322;
    --texto: #f7faff;
    --suave: #bac9dd;
}

html {
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    font-family: "Segoe UI", Arial, sans-serif;
    color: var(--texto);
    background:
        radial-gradient(circle at 68% 18%, rgba(24, 139, 255, .17), transparent 35%),
        radial-gradient(circle at 68% 22%, rgba(39, 216, 232, .06), transparent 28%),
        linear-gradient(135deg, #020915, #031327 45%, #082849);
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image: radial-gradient(circle, rgba(66, 170, 255, .72) 1px, transparent 1.5px);
    background-size: 34px 34px;
    opacity: .10;
}

.sobre-page {
    width: min(1420px, calc(100% - 42px));
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.primeira-dobra {
    min-height: 100vh;
    display: grid;
    grid-template-rows: 72px 1fr auto;
    padding-bottom: 14px;
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.logo {
    width: 186px;
    display: block;
}

.logo-link {
    display: inline-flex;
    text-decoration: none;
}

.btn-acesso {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 18px;
    min-width: 152px;
    justify-content: center;
    border: 1px solid rgba(24, 143, 255, .92);
    border-radius: 10px;
    background: rgba(5, 26, 53, .70);
    box-shadow: 0 0 18px rgba(21, 146, 255, .12);
    color: #ecf8ff;
    text-decoration: none;
    font-size: 12.5px;
    font-weight: 800;
}

.btn-acesso span {
    color: var(--azul);
    font-size: 11px;
}

.hero-grid {
    display: grid;
    grid-template-columns: 390px 1fr;
    gap: 26px;
    align-items: center;
    min-height: 0;
}

.hero-texto {
    align-self: center;
}

.hero-texto h1 {
    max-width: 520px;
    font-size: 35px;
    line-height: 1.12;
    letter-spacing: -1.1px;
    font-weight: 800;
}

.hero-texto h1 span {
    color: var(--azul2);
}

.hero-texto h1 strong {
    color: var(--amarelo);
    font-weight: 800;
}

.linha {
    width: 68px;
    height: 4px;
    border-radius: 999px;
    margin: 18px 0 15px;
    background: linear-gradient(90deg, var(--ciano), var(--azul));
}

.descricao {
    max-width: 360px;
    color: #d9e5f4;
    font-size: 16px;
    line-height: 1.58;
}

.pilares {
    margin-top: 20px;
    display: grid;
    gap: 14px;
}

.pilares article {
    display: grid;
    grid-template-columns: 52px 1fr;
    gap: 14px;
    align-items: start;
}

.pilar-icone {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 9px;
    background: rgba(3, 20, 42, .72);
    font-size: 20px;
}

.pilar-icone.azul {
    color: var(--azul);
    border: 1px solid rgba(31, 146, 255, .68);
}

.pilar-icone.ciano {
    color: var(--ciano);
    border: 1px solid rgba(39, 216, 232, .68);
}

.pilar-icone.amarelo {
    color: var(--amarelo);
    border: 1px solid rgba(255, 211, 34, .68);
}

.pilares h3 {
    font-size: 16px;
    line-height: 1.1;
    margin-bottom: 5px;
}

.pilares p {
    color: var(--suave);
    font-size: 13px;
    line-height: 1.43;
}

.pilares a {
    color: #fff;
    font-weight: 800;
    text-decoration: none;
}

/* ÓRBITA CORRIGIDA: itens separados, sem encostar */
.sistema-orbital {
    width: 720px;
    height: 455px;
    position: relative;
    justify-self: center;
    align-self: center;
    margin-top: -10px;
}

.sistema-orbital::before {
    content: "";
    position: absolute;
    inset: 8px 42px;
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(74, 178, 255, .85) 1px, transparent 2px),
        radial-gradient(circle, rgba(25, 140, 255, .38) 1px, transparent 2px);
    background-size: 34px 34px, 56px 56px;
    opacity: .20;
}

.orbita {
    position: absolute;
    left: 50%;
    top: 50%;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    border: 1px solid rgba(31, 146, 255, .36);
}

.orbita-1 {
    width: 180px;
    height: 180px;
}

.orbita-2 {
    width: 300px;
    height: 300px;
}

.orbita-3 {
    width: 500px;
    height: 405px;
}

.centro {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 178px;
    height: 178px;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    display: grid;
    place-items: center;
    border: 2px solid rgba(39, 161, 255, .92);
    background: radial-gradient(circle, #071d35, #020915 66%, #00050a);
    box-shadow:
        0 0 30px rgba(25, 148, 255, .70),
        inset 0 0 25px rgba(31, 146, 255, .16);
    z-index: 4;
}

.centro img {
    width: 130px;
}

.modulo {
    position: absolute;
    z-index: 6;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 2px;
    text-align: center;
    color: #fff;
    font-weight: 800;
    font-size: 10px;
    line-height: 1.04;
    background: radial-gradient(circle at center, rgba(22, 87, 150, .94), rgba(4, 16, 32, .94));
    border: 1px solid rgba(110, 199, 255, .78);
    box-shadow:
        0 0 18px rgba(52, 174, 255, .58),
        inset 0 0 17px rgba(44, 149, 255, .25);
    text-shadow: 0 2px 8px rgba(0,0,0,.72);
}

.modulo i {
    display: block;
    font-style: normal;
    font-size: 20px;
    line-height: 1;
}

/* Posições fixas e espaçadas na órbita elíptica */
.m-ativos {
    left: 328px;
    top: 12px;
}

.m-os {
    left: 483px;
    top: 62px;
}

.m-licencas {
    left: 583px;
    top: 178px;
}

.m-agenda {
    left: 520px;
    top: 320px;
}

.m-estoque {
    left: 390px;
    top: 365px;
}

.m-qr {
    left: 292px;
    top: 374px;
}

.m-relatorios-baixo {
    left: 176px;
    top: 312px;
}

.m-vendas {
    left: 105px;
    top: 196px;
}

.m-orcamentos {
    left: 162px;
    top: 70px;
}

.m-relatorios-alto {
    left: 270px;
    top: 34px;
}

.cards-resumo {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

.cards-resumo article {
    display: grid;
    grid-template-columns: 50px 1fr;
    gap: 14px;
    min-height: 82px;
    padding: 16px 18px;
    border: 1px solid rgba(31, 146, 255, .24);
    border-radius: 11px;
    background: rgba(3, 18, 36, .70);
    backdrop-filter: blur(14px);
}

.card-icone {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    color: var(--azul);
    border: 1px solid rgba(31, 146, 255, .52);
    border-radius: 9px;
    font-size: 22px;
    background: rgba(6, 26, 52, .75);
}

.cards-resumo h3 {
    font-size: 16px;
    margin-bottom: 5px;
}

.cards-resumo p {
    color: var(--suave);
    font-size: 13px;
    line-height: 1.42;
}

.dashboard-preview {
    padding-top: 28px;
}

.dashboard-moldura {
    overflow: hidden;
    border-radius: 13px;
    border: 1px solid rgba(68, 174, 255, .78);
    background: #fff;
    box-shadow:
        0 0 28px rgba(31, 146, 255, .30),
        0 28px 90px rgba(0,0,0,.34);
}

.dashboard-moldura img {
    width: 100%;
    display: block;
}

.rodape {
    margin: 26px 0 28px;
    padding-top: 18px;
    border-top: 1px solid rgba(140, 190, 255, .16);
    text-align: center;
}

.rodape a {
    color: #25a8ff;
    text-decoration: none;
    font-size: 20px;
    font-weight: 500;
}

.whatsapp {
    position: fixed;
    right: 24px;
    bottom: 24px;
    width: 58px;
    height: 58px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #20d366;
    z-index: 30;
    box-shadow: 0 0 26px rgba(32, 211, 102, .56);
    transition: .2s ease;
}

.whatsapp:hover {
    transform: translateY(-3px) scale(1.04);
}

.whatsapp svg {
    width: 36px;
    height: 36px;
    fill: #fff;
}

@media (max-width: 1280px) {
    .sobre-page {
        width: min(1180px, calc(100% - 34px));
    }

    .hero-grid {
        grid-template-columns: 360px 1fr;
        gap: 18px;
    }

    .hero-texto h1 {
        font-size: 35px;
    }

    .sistema-orbital {
        transform: scale(.84);
        transform-origin: center;
    }

    .cards-resumo {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 900px) {
    .primeira-dobra {
        min-height: auto;
        grid-template-rows: auto auto auto;
        padding-bottom: 24px;
    }

    .topbar {
        padding: 18px 0;
        gap: 14px;
        flex-direction: column;
    }

    .hero-grid {
        grid-template-columns: 1fr;
    }

    .hero-texto h1 {
        font-size: 32px;
        max-width: 100%;
    }

    .descricao {
        max-width: 100%;
    }

    .sistema-orbital {
        width: 720px;
        transform: scale(.52);
        transform-origin: center;
        height: 340px;
        margin-left: calc((100% - 720px) / 2);
    }

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


/* =========================================================
   CORREÇÃO FINAL DA ÓRBITA
   10 itens pequenos, circulares, distribuídos na órbita:
   5 na parte superior e 5 na parte inferior
   ========================================================= */
.sistema-orbital{
    width: 720px;
    height: 455px;
    position: relative;
    justify-self: center;
    align-self: center;
    margin-top: -8px;
}

.orbita-1{
    width: 184px;
    height: 184px;
}

.orbita-2{
    width: 300px;
    height: 300px;
}

.orbita-3{
    width: 520px;
    height: 360px;
}

.centro{
    width: 178px;
    height: 178px;
}

.centro img{
    width: 130px;
}

.modulo{
    position: absolute;
    z-index: 6;
    width: 66px;
    height: 66px;
    min-width: 66px;
    min-height: 66px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 7px 5px;
    transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    font-weight: 800;
    font-size: 9px;
    line-height: 1.04;
    background: radial-gradient(circle at center, rgba(22, 87, 150, .95), rgba(4, 16, 32, .97));
    border: 1px solid rgba(110, 199, 255, .82);
    box-shadow:
        0 0 16px rgba(52, 174, 255, .48),
        inset 0 0 14px rgba(44, 149, 255, .20);
    text-shadow: 0 2px 8px rgba(0,0,0,.72);
}

.modulo i{
    display: block;
    font-style: normal;
    font-size: 18px;
    line-height: 1;
}

.modulo span{
    display: block;
    max-width: 100%;
    font-size: 9px;
    line-height: 1.05;
}

/* 5 itens na parte superior da órbita */
.m-vendas{
    left: 142px;
    top: 138px;
}

.m-orcamentos{
    left: 234px;
    top: 73px;
}

.m-relatorios-alto{
    left: 360px;
    top: 49px;
}

.m-ativos{
    left: 486px;
    top: 73px;
}

.m-os{
    left: 578px;
    top: 138px;
}

/* 5 itens na parte inferior da órbita */
.m-relatorios-baixo{
    left: 142px;
    top: 315px;
}

.m-qr{
    left: 234px;
    top: 379px;
}

.m-estoque{
    left: 360px;
    top: 403px;
}

.m-agenda{
    left: 486px;
    top: 379px;
}

.m-licencas{
    left: 578px;
    top: 315px;
}

/* Notebook */
@media (max-width: 1280px){
    .sistema-orbital{
        transform: scale(.84);
        transform-origin: center;
    }
}

/* Tablet */
@media (max-width: 900px){
    .sistema-orbital{
        width: 720px;
        height: 340px;
        transform: scale(.52);
        transform-origin: center;
        margin-left: calc((100% - 720px) / 2);
    }
}

/* Mobile */
@media (max-width: 640px){
    .sistema-orbital{
        transform: scale(.44);
        transform-origin: center;
    }

    .modulo{
        width: 64px;
        height: 64px;
        min-width: 64px;
        min-height: 64px;
    }

    .modulo i{
        font-size: 17px;
    }

    .modulo span{
        font-size: 8.6px;
    }
}
