:root {
    --bg-body: #f8f9fa;
    --text-main: #212529;
    --bg-card: #ffffff;
    --border-color: #e5e5e5;
    --footer-bg: #f8f9fa;
    --title-color: #212529;
    --input-bg: #ffffff;
    --input-text: #212529;
}

[data-theme="dark"] {
    --bg-body: #000000;
    --text-main: #e0e0e0;
    --bg-card: #0a0a0a;
    --border-color: #333;
    --footer-bg: #000000;
    --title-color: #00ffff; /* Azul Neón Claro */
    --input-bg: #1a1a1a;
    --input-text: #e0e0e0;
}

body {
    padding-top: 0;
    background-color: var(--bg-body);
    color: var(--text-main);
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    transition: background-color 0.3s, color 0.3s;
}

/* Tipografía personalizada */
h1, h2, h3, h4, h5, h6, .navbar-brand {
    font-family: 'Montserrat', sans-serif;
}

/* Estilos generales de layout */
.container {
    max-width: 960px;
}

.footer {
    margin-top: 50px;
    padding: 20px 0;
    border-top: 1px solid var(--border-color);
    background-color: var(--footer-bg);
    text-align: center;
    color: #6c757d;
}

/* Títulos Neón en Dark Mode */
h1, h2, h3, h4, h5, h6, .navbar-brand, .card-title {
    color: var(--title-color);
}

/* Tarjetas y Contenido */
.card {
    background-color: var(--bg-card);
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    border: none;
    margin-bottom: 20px;
}

.card-header {
    background-color: rgba(0,0,0,0.03);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
    color: var(--title-color);
}

/* Corrección para Inputs y Formularios en Dark Mode */
.form-control {
    background-color: var(--input-bg);
    color: var(--input-text);
    border-color: var(--border-color);
}

.form-control:focus {
    background-color: var(--input-bg);
    color: var(--input-text);
    border-color: var(--title-color);
    box-shadow: 0 0 5px rgba(0, 255, 255, 0.2);
}

/* Corrección para Listas (ej. Dashboard) */
.list-group-item {
    background-color: var(--bg-card);
    color: var(--text-main);
    border-color: var(--border-color);
}

/* Badges de estado de seguridad */
.vuln-badge {
    background-color: #dc3545;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.85em;
    font-weight: bold;
}

.secure-badge {
    background-color: #198754;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.85em;
    font-weight: bold;
}

/* Utilidades para auditoría */
.audit-hint {
    font-size: 0.9em;
}

/* Corrección para elementos .bg-light de Bootstrap en Dark Mode */
[data-theme="dark"] .bg-light {
    background-color: var(--bg-card) !important;
    color: var(--text-main) !important;
}

/* Placeholder de Galería adaptable */
.gallery-placeholder {
    background-color: #eee;
}

[data-theme="dark"] .gallery-placeholder {
    background-color: #1a1a1a; /* Gris muy oscuro para diferenciar del fondo negro */
}

/* Corrección para Acordeón (FAQ) en Dark Mode */
[data-theme="dark"] .accordion-item {
    background-color: var(--bg-card);
    color: var(--text-main);
    border-color: var(--border-color);
}

[data-theme="dark"] .accordion-button {
    background-color: var(--bg-card);
    color: var(--text-main);
    box-shadow: none; /* Eliminar brillo azul por defecto */
}

[data-theme="dark"] .accordion-button:not(.collapsed) {
    background-color: #1a1a1a; /* Un poco más claro para indicar activo */
    color: var(--title-color);
    box-shadow: inset 0 -1px 0 rgba(0,0,0,.125);
}

[data-theme="dark"] .accordion-button::after {
    filter: invert(1) grayscale(100%) brightness(200%); /* Invierte la flecha a blanco */
}