﻿:root {
    --cg-bg: #090b10;
    --cg-bg-soft: #11151d;
    --cg-card: #151a24;
    --cg-border: #2a3140;
    --cg-text: #f3f6fb;
    --cg-text-soft: #b8c1d1;
    --cg-primary: #1f7bff;
    --cg-primary-strong: #0a5bdb;
    --cg-success: #22c55e;

    --bs-primary: #1f7bff;
    --bs-primary-rgb: 31, 123, 255;
    --bs-link-color: #69a8ff;
    --bs-link-hover-color: #9ac7ff;
}

body {
    background: linear-gradient(180deg, #090b10 0%, #0d1118 36%, #0a0d14 100%);
    color: var(--cg-text);
}

.navbar {
    background: rgba(8, 11, 17, 0.8) !important;
    backdrop-filter: blur(8px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.navbar .nav-link {
    color: #e8edf8;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus {
    color: #ffffff;
}

.navbar .btn {
    white-space: nowrap;
}

.navbar-brand img {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 0.15rem;
}

.hero-section {
    position: relative;
    background: radial-gradient(circle at 20% 25%, rgba(31, 123, 255, 0.24), transparent 45%),
        radial-gradient(circle at 80% 20%, rgba(34, 197, 94, 0.12), transparent 35%),
        linear-gradient(130deg, #06080d 0%, #0f141e 52%, #090c13 100%);
}

.hero-media-wrap {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: #0c1018;
    box-shadow: 0 1.5rem 3rem rgba(0, 0, 0, 0.35);
}

.hero-media-wrap img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.badge.text-bg-light {
    background: rgba(31, 123, 255, 0.16) !important;
    color: #b8d7ff !important;
    border: 1px solid rgba(31, 123, 255, 0.4);
}

.text-primary,
.feature i,
.bi-check.text-primary {
    color: var(--cg-primary) !important;
}

.btn-primary {
    border: 0;
    color: #fff;
    background: linear-gradient(135deg, var(--cg-primary) 0%, var(--cg-primary-strong) 100%);
    box-shadow: 0 0.75rem 1.8rem rgba(31, 123, 255, 0.3);
}

.btn-primary:hover,
.btn-primary:focus {
    background: linear-gradient(135deg, #3a90ff 0%, #1368eb 100%);
}

.btn-outline-primary {
    color: #9ac7ff;
    border-color: rgba(31, 123, 255, 0.5);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    color: #fff;
    background-color: var(--cg-primary);
    border-color: var(--cg-primary);
}

.btn-success {
    border: 0;
    background: linear-gradient(135deg, #21b95a 0%, #118f42 100%);
}

section {
    background: transparent;
}

.bg-light {
    background-color: var(--cg-bg-soft) !important;
}

.border-bottom {
    border-color: rgba(255, 255, 255, 0.08) !important;
}

section p,
section .lead,
.text-muted,
.accordion-body {
    color: var(--cg-text-soft) !important;
}

h1,
h2,
h3,
h4,
h5,
.fw-bolder,
.fw-bold,
.card-title,
.accordion-button {
    color: var(--cg-text);
}

.feature-card,
.pricing-card,
#contato .card,
.card,
.accordion-item {
    background: linear-gradient(180deg, #121722 0%, #0e131c 100%);
    border-color: var(--cg-border) !important;
    box-shadow: 0 0.8rem 2rem rgba(0, 0, 0, 0.2);
}

.feature {
    background: linear-gradient(140deg, #1f7bff 0%, #0a5bdb 100%) !important;
}

.feature-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.feature-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 1.25rem 2.6rem rgba(0, 0, 0, 0.35);
}

.step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    font-weight: 700;
    color: #fff;
    background-color: var(--cg-primary);
}

.accordion-button {
    background-color: #111722;
}

.accordion-button:not(.collapsed) {
    background-color: #171e2c;
    color: #ffffff;
    box-shadow: none;
}

.accordion-button:focus {
    box-shadow: 0 0 0 0.2rem rgba(31, 123, 255, 0.25);
}

img.rounded-4 {
    border: 1px solid rgba(255, 255, 255, 0.14);
}

footer {
    background: #05070b !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

@media (max-width: 991.98px) {
    .hero-section .display-5 {
        font-size: 2.05rem;
    }
}
