/* ============================================
   CORREÇÃO UNIVERSAL DE CONTRASTE
   ============================================ */

/* ============================================
   TEXTOS PADRÃO - GARANTIR LEGIBILIDADE
   ============================================ */

body {
    color: #2a2f3a;
    background-color: #ffffff;
}

p {
    color: #3a4150;
    font-weight: 400;
    line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
    color: #0d2249;
    font-weight: 700;
}

/* ============================================
   SEÇÃO HERO - TEXTO BRANCO COM SHADOW
   ============================================ */

.hero {
    background: linear-gradient(135deg, #1a4789 0%, #2d5fa3 100%);
}

.hero h1,
.hero h2,
.hero h3,
.hero p {
    color: #ffffff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.hero .lead {
    color: rgba(255, 255, 255, 0.95);
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}

/* ============================================
   BACKGROUNDS ESCUROS - TEXTO BRANCO
   ============================================ */

.bg-primary,
.bg-dark,
[style*="background: #0d2249"],
[style*="background: #051423"] {
    color: #ffffff !important;
}

.bg-primary h1,
.bg-primary h2,
.bg-primary h3,
.bg-primary h4,
.bg-primary h5,
.bg-primary h6,
.bg-dark h1,
.bg-dark h2,
.bg-dark h3,
.bg-dark h4,
.bg-dark h5,
.bg-dark h6 {
    color: #ffffff !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.bg-primary p,
.bg-primary li,
.bg-dark p,
.bg-dark li {
    color: rgba(255, 255, 255, 0.95) !important;
}

.bg-primary a,
.bg-dark a {
    color: #e8f0ff !important;
    font-weight: 600;
}

.bg-primary a:hover,
.bg-dark a:hover {
    color: #ffffff !important;
    text-decoration: underline;
}

/* ============================================
   BACKGROUNDS CLAROS - TEXTO ESCURO
   ============================================ */

.bg-light {
    background-color: #f8f9fb !important;
    color: #2a2f3a;
}

.bg-light h1,
.bg-light h2,
.bg-light h3,
.bg-light h4,
.bg-light h5,
.bg-light h6 {
    color: #0d2249;
}

.bg-light p,
.bg-light li {
    color: #3a4150;
}

/* ============================================
   CARDS E CONTÊINERES
   ============================================ */

.card {
    background: #ffffff;
    border: 1px solid #e9ecf0;
}

.card h3,
.card h4,
.card h5,
.card h6 {
    color: #0d2249;
    font-weight: 700;
}

.card p {
    color: #5a5f6b;
    font-size: 1rem;
    line-height: 1.8;
}

.card-body {
    color: #3a4150;
}

/* ============================================
   SEÇÕES ESPECÍFICAS
   ============================================ */

.section-header h2 {
    color: #1a4789 !important;
    font-weight: 800;
    background: none !important;
    -webkit-background-clip: unset !important;
    -webkit-text-fill-color: unset !important;
}

.about-content {
    color: #3a4150;
}

.about-content h2 {
    color: #0d2249;
    font-weight: 800;
}

.about-content p {
    color: #3a4150;
    line-height: 1.8;
    font-size: 1.05rem;
}

.about-content ul li {
    color: #3a4150;
    font-size: 1.05rem;
}

/* ============================================
   DEPOIMENTOS
   ============================================ */

.testimonials-grid .card {
    border: 1px solid #e9ecf0;
}

.testimonials-grid .card p {
    color: #5a5f6b;
    font-size: 1.05rem;
    line-height: 1.8;
}

.testimonials-grid .card h4 {
    color: #1a4789;
    font-weight: 700;
    margin-top: 1.5rem;
}

/* ============================================
   LINKS
   ============================================ */

a {
    color: #1a4789;
    font-weight: 500;
    text-decoration: none;
}

a:hover {
    color: #0d2249;
    text-decoration: underline;
}

a:active {
    color: #2d5fa3;
}

/* ============================================
   FORMULÁRIOS
   ============================================ */

label {
    color: #2a2f3a;
    font-weight: 600;
    font-size: 1rem;
}

input,
textarea,
select {
    background-color: #ffffff;
    color: #2a2f3a;
    border: 2px solid #e9ecf0;
    font-size: 1rem;
}

input:focus,
textarea:focus,
select:focus {
    background-color: #ffffff;
    border-color: #1a4789;
    color: #2a2f3a;
    box-shadow: 0 0 0 4px rgba(26, 71, 137, 0.1);
}

input::placeholder,
textarea::placeholder {
    color: #8b8f98;
    opacity: 0.8;
}

/* ============================================
   BOTÕES
   ============================================ */

.btn {
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0.3px;
}

.btn-primary {
    background-color: #1a4789;
    border-color: #1a4789;
    color: #ffffff;
}

.btn-primary:hover {
    background-color: #0d2249;
    border-color: #0d2249;
    color: #ffffff;
}

.btn-outline-primary {
    color: #1a4789;
    border-color: #1a4789;
}

.btn-outline-primary:hover {
    background-color: #1a4789;
    border-color: #1a4789;
    color: #ffffff;
}

.btn-light {
    color: #1a4789;
    background-color: #ffffff;
    border-color: #ffffff;
}

.btn-light:hover {
    background-color: #f8f9fb;
    border-color: #f8f9fb;
    color: #0d2249;
}

/* ============================================
   FOOTER
   ============================================ */

footer {
    background: linear-gradient(180deg, #0d2249, #051423);
    color: #ffffff;
}

footer h2,
footer h3,
footer h4,
footer h5,
footer h6 {
    color: #ffffff;
}

footer p,
footer li {
    color: rgba(255, 255, 255, 0.9);
}

footer a {
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
}

footer a:hover {
    color: #e8f0ff;
    text-decoration: underline;
}

/* ============================================
   NAVBAR
   ============================================ */

.navbar {
    background-color: #ffffff;
}

.navbar-brand {
    color: #1a4789;
}

.nav-link {
    color: #2a2f3a !important;
    font-weight: 500;
}

.nav-link:hover {
    color: #1a4789 !important;
}

.nav-link.active {
    color: #1a4789 !important;
    font-weight: 700;
}

/* ============================================
   BREADCRUMBS
   ============================================ */

.breadcrumb {
    background-color: #f8f9fb;
    padding: 1rem;
}

.breadcrumb-item {
    color: #3a4150;
}

.breadcrumb-item.active {
    color: #1a4789;
    font-weight: 600;
}

.breadcrumb-item a {
    color: #1a4789;
    text-decoration: none;
}

.breadcrumb-item a:hover {
    color: #0d2249;
    text-decoration: underline;
}

/* ============================================
   ALERTS E NOTIFICAÇÕES
   ============================================ */

.alert-info {
    background-color: #f0f4ff;
    border: 1px solid #d4e2ff;
    color: #0d2249;
}

.alert-warning {
    background-color: #fff3cd;
    border: 1px solid #ffc107;
    color: #664d03;
}

.alert-success {
    background-color: #d1e7dd;
    border: 1px solid #198754;
    color: #0f5132;
}

.alert-danger {
    background-color: #f8d7da;
    border: 1px solid #f5c6cb;
    color: #842029;
}

/* ============================================
   LISTAS
   ============================================ */

ul li,
ol li {
    color: #3a4150;
    font-size: 1.05rem;
    line-height: 1.8;
    margin-bottom: 0.8rem;
}

/* ============================================
   MEDIA QUERIES - MOBILE
   ============================================ */

@media (max-width: 768px) {
    body {
        font-size: 1rem;
    }

    h1 {
        font-size: 2rem;
        color: #0d2249;
    }

    h2 {
        font-size: 1.5rem;
        color: #0d2249;
    }

    p {
        font-size: 1rem;
        color: #3a4150;
    }

    .hero h1,
    .hero h2 {
        color: #ffffff;
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    }
}
