p {
    color: var(--text-color);
}

h6,
h2,
li,
strong,
span {
    color: white;
}

h5,
.card-title,
.mb-0,
.metric-avg,
.metric-label {
    color: white;
}

:root {
    /* Paleta de Colores - Oscura/Moderna (Ajusta según preferencia) */
    --bg-color: #121212;
    --surface-color: #1e1e1e;
    --primary-color: #00ffff;
    /* Cyan brillante tipo "cyberpunk" */
    --secondary-color: #f0f;
    /* Magenta */
    --text-color: #e0e0e0;
    --text-muted-color: #f5f1f1;
    /* Gris más claro para mejor contraste */
    --gauge-bg: #2a2a2a;
    --gauge-scale: #555;
    --needle-color: var(--primary-color);

    /* Fuentes */
    --font-family-sans: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --font-family-mono: 'Fira Code', monospace;

    /* Transiciones */
    --transition-speed: 0.3s;

    /* Pequeño ajuste para :root para usar colores RGB */
    --primary-color-rgb: 0, 255, 255;
}

/* Reset Básico y Estilos Globales */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-family-sans);
    background-color: var(--bg-color);
    color: var(--text-color);
    line-height: 1.6;
    overflow-x: hidden;
    /* Evitar scroll horizontal */
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.container {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 1rem 0;
    flex-grow: 1;
    /* Empuja el footer hacia abajo */
}

/* Estilos de Navegación (Simplificado, ajusta según tu nav en main.hbs) */
.navbar {
    background-color: var(--surface-color);
    padding: 0.8rem 0;
    border-bottom: 1px solid #333;
}

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

.navbar-brand {
    color: var(--primary-color);
    font-weight: bold;
    font-size: 1.5rem;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.navbar-brand img {
    border-radius: 6px;
}

/* Emoji cohete del sistema (color real con fuentes Color Emoji) */
.navbar-brand .brand-rocket {
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", "Twemoji Mozilla", sans-serif;
    font-size: 1.45rem;
    line-height: 1;
    display: inline-block;
    vertical-align: -0.12em;
}

.navbar-nav {
    list-style: none;
    display: flex;
}

.nav-item {
    margin-left: 1.5rem;
}

.nav-link {
    color: var(--text-muted-color);
    text-decoration: none;
    transition: color var(--transition-speed) ease;
}

.nav-link:hover,
.nav-link.active {
    color: var(--primary-color);
}

/* Estilos Footer (Simplificado) */
footer {
    background-color: var(--surface-color);
    color: var(--text-muted-color);
    text-align: center;
    padding: 1rem 0;
    margin-top: auto;
    /* Asegura que esté al final */
    border-top: 1px solid #333;
}

/* Contenedores Principales (index.hbs) */
.speed-test-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 2rem 0;
    margin-bottom: 3rem;
}

.advanced-analysis-container {
    padding: 2rem 0;
    text-align: center;
    border-top: 1px solid #333;
    /* Separador */
}

.advanced-analysis-container h2 {
    margin-bottom: 2rem;
    color: var(--primary-color);
}

/* Estilos Base para Botones (serán más específicos) */
button,
.btn {
    cursor: pointer;
    padding: 0.8rem 1.5rem;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    transition: all var(--transition-speed) ease;
}

/* Estilos Base para Cards (serán más específicos) */
.card {
    background-color: var(--surface-color);
    border-radius: 8px;
    padding: 1.5rem;
    border: 1px solid #333;
    transition: transform var(--transition-speed) ease, box-shadow var(--transition-speed) ease;
}

/* Añadir link a Google Fonts (o puedes auto-hospedar) */
/* Coloca esto preferiblemente en el <head> de main.hbs */
/* @import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;700&family=Fira+Code&display=swap'); */

/* --- Nuevo Contenedor para Gauge.js --- */
.gauge-wrapper {
    width: 300px;
    /* O el tamaño que desees */
    height: 150px;
    margin-bottom: 2rem;
    position: relative;
    /* Para posible posicionamiento de texto superpuesto si se necesita */
}

#speed-gauge-canvas {
    display: block;
    /* Asegura que ocupe el espacio correctamente */
    width: 100%;
    height: 100%;
}

/* {{change 1: Add background color to speedChart and latencyChart}} */
#speedChart,
#latencyChart {
    background-color: white;
}

/* Agrega estos estilos para los mensajes de error */
.error-message {
    color: red;
    /* Color rojo para los errores */
    margin-top: 0.5rem;
    /* Espacio superior */
    font-size: 0.9rem;
    /* Tamaño de fuente más pequeño */
    text-align: center;
    /* Centrar el texto */
}

/* --- Contenedor de Resultados --- */
.results-container {
    display: flex;
    flex-direction: column;
    /* Vertical por defecto (móvil) */
    align-items: center;
    /* Centrar cajas en móvil */
    gap: 1rem;
    /* Espacio reducido en móvil */
    margin-bottom: 2.5rem;
    width: 100%;
    max-width: 90%;
    /* Ligeramente más estrecho en móvil */
}

.result-box {
    background-color: var(--surface-color);
    padding: 1rem 1.5rem;
    border-radius: 8px;
    text-align: center;
    border: 1px solid #333;
    width: 100%;
    /* Ancho completo en móvil por defecto */
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

/* Estilos específicos para las cajas */
.result-box.main-result {
    /* Estilos especiales si los necesitas, ej. borde más grueso */
    border: 2px solid var(--primary-color);
}

.result-box.main-result .large-value {
    font-size: 2.2rem;
    /* Tamaño grande para descarga */
    color: var(--primary-color);
}

.result-label {
    display: block;
    font-size: 0.8rem;
    color: var(--text-muted-color);
    margin-bottom: 0.3rem;
}

.result-label .unit {
    font-size: 0.7rem;
}

.result-value {
    display: block;
    font-family: var(--font-family-mono);
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--text-color);
}

.result-status .result-value {
    font-size: 1rem;
    color: var(--primary-color);
}


/* Media Query para Escritorio (ej. 768px o más) */
@media (min-width: 768px) {
    .results-container {
        flex-direction: row;
        justify-content: space-between;
        align-items: stretch;
        flex-wrap: wrap;
        max-width: 800px;
        gap: 1.5rem;
    }

    .result-box {
        width: auto;
        flex: 1 1 150px;
        min-width: 140px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    /* Eliminar o comentar esta regla específica */
    /* .result-box.main-result {
        flex-basis: 180px; 
    } */
}


/* --- Botón de Inicio --- */
.start-button {
    background: linear-gradient(145deg, var(--primary-color), var(--secondary-color));
    color: #000;
    font-size: 1.2rem;
    padding: 1rem 2.5rem;
    border-radius: 50px;
    /* Botón más redondeado */
    border: none;
    box-shadow: 0 4px 15px rgba(0, 255, 255, 0.2), 0 2px 5px rgba(255, 0, 255, 0.2);
    transition: all var(--transition-speed) ease;
}

.start-button:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 8px 25px rgba(0, 255, 255, 0.3), 0 4px 10px rgba(255, 0, 255, 0.3);
}

.start-button:active {
    transform: translateY(0) scale(1);
    box-shadow: 0 2px 5px rgba(0, 255, 255, 0.2), 0 1px 2px rgba(255, 0, 255, 0.2);
}

.start-button:disabled {
    background-color: #555;
    color: #999;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Estilos para el indicador de ubicación */
.location-status {
    text-align: center;
    margin-top: 1rem;
}

.location-indicator {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-size: 0.9rem;
    transition: all var(--transition-speed) ease;
}

.location-indicator.loading {
    background-color: rgba(255, 193, 7, 0.2);
    color: #ffc107;
    border: 1px solid #ffc107;
}

.location-indicator.success {
    background-color: rgba(40, 167, 69, 0.2);
    color: #28a745;
    border: 1px solid #28a745;
}

.location-indicator.error {
    background-color: rgba(220, 53, 69, 0.2);
    color: #dc3545;
    border: 1px solid #dc3545;
}

.location-indicator i {
    margin-right: 0.5rem;
}

/* --- Sección Análisis Avanzado --- */
.advanced-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    /* Rejilla responsive */
    gap: 1.5rem;
    margin-top: 1rem;
    align-items: stretch;
}

.advanced-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background-color: rgba(30, 30, 30, 0.8);
    /* Ligeramente transparente */
    backdrop-filter: blur(5px);
    /* Efecto cristal esmerilado */
    border: 1px solid rgba(var(--primary-color-rgb, 0, 255, 255), 0.3);
}

.advanced-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 255, 255, 0.15);
    border-color: rgba(var(--primary-color-rgb, 0, 255, 255), 0.6);
}

.advanced-card .card-icon {
    font-size: 2.5rem;
    margin-bottom: 1rem;
}

.advanced-card .card-title {
    color: var(--primary-color);
    margin-bottom: 0.8rem;
    font-size: 1.1rem;
    min-height: 2.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.advanced-card .card-text {
    color: var(--text-color);
    font-size: 0.9rem;
    flex-grow: 1;
    /* Empuja botón abajo si es necesario */
    margin-bottom: 1rem;
    min-height: 2.8rem;
    text-align: center;
}

.advanced-card .btn {
    margin-top: auto;
    /* Alinea botón al final */
    background-color: var(--primary-color);
    color: #000;
    padding: 0.5rem 1rem;
    font-size: 0.9rem;
}

.advanced-card .btn:hover {
    background-color: var(--secondary-color);
    color: var(--text-color);
}

.advanced-card .btn.disabled {
    background-color: #444;
    color: #888;
}

.advanced-card .btn-info {
    background-color: rgba(var(--primary-color-rgb, 0, 255, 255), 0.5);
    border: 1px solid var(--primary-color);
    color: var(--primary-color);
}

.advanced-card .btn-info:hover {
    background-color: var(--primary-color);
    color: #000;
}

/* Style the "Iniciar Análisis", "Ver Mapa", and "Ver Historial" buttons like the "Ver Alertas" button */
.btn.btn-info,
#start-stability-btn {
    /* Include the specific ID for the stability button */
    background-color: #17a2b8;
    /* Keep the original background color for btn-info */
    border-color: #17a2b8;
    color: #212529;
    /* Ensure text color is same as Ver Alertas button */
}

.btn.btn-info:hover,
#start-stability-btn:hover {
    background-color: #663399;
    /* Same purple hover as alerts button */
    border-color: #663399;
    color: #fff;
}

/* Keep the original styling for the "Ver Alertas" button */
.btn-warning {
    background-color: #ffc107;
    /* Keep original warning background */
    border-color: #ffc107;
    color: #212529;
}

.btn-warning:hover {
    background-color: #663399;
    /* Purple hover */
    border-color: #663399;
    color: #fff;
}

/* --- Utilidades --- */
.value-hidden {
    opacity: 0;
    transition: opacity 0.2s ease-in-out;
}

/* AÚN FALTA: Responsividad detallada y Animaciones/Efectos AR */

/* Estilos específicos para la sección de resultados de evaluación */
.assessment-results {
    margin-top: 1rem;
    /* Añadir espacio arriba */
    width: 100%;
    /* Ocupar ancho de la tarjeta */
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    min-height: 100px;
}

.assessment-results .text-muted {
    color: var(--text-muted-color);
    /* Asegurar color tenue para mensaje inicial */
    text-align: center;
    /* Centrar el mensaje inicial */
}

/* Estilo para un posible título H5 dentro de assessment-results */
.assessment-results h5 {
    color: var(--primary-color);
    margin-bottom: 0.5rem;
    font-size: 1rem;
    text-align: center;
    width: 100%;
}

.assessment-results .assessment-list {
    list-style: none;
    /* Quitar puntos de la lista */
    padding: 0;
    margin: 0.5rem auto 0;
    /* Margen si hay título h5 arriba */
    color: var(--text-color);
    /* Asegurar color de texto principal para la lista */
    font-size: 0.85rem;
    /* Tamaño ligeramente más pequeño */
    width: 100%;
    max-width: 260px;
    text-align: left;
}

.assessment-results .assessment-list li {
    margin-bottom: 0.4rem;
    /* Espacio entre elementos de la lista */
    color: var(--text-color);
    /* Reafirmar color de texto para los items */
}

/* Estilos para resultados de análisis de estabilidad */
.stability-results {
    margin-top: 1rem;
    width: 100%;
    text-align: center;
}

.stability-results .text-muted,
.stability-results .text-danger,
.stability-results .text-warning {
    text-align: center;
    /* Centrar mensajes de estado/error */
}

.stability-results .stability-list {
    list-style: none;
    padding: 0;
    margin: 0.5rem auto 0;
    /* Margen superior para separar del título h5 */
    color: var(--text-color);
    /* Asegurar color de texto principal para la lista */
    font-size: 0.85rem;
    width: 100%;
    max-width: 260px;
    text-align: left;
}

/* Asegurar color para el título H5 dentro de stability-results */
.stability-results h5 {
    color: var(--primary-color);
    /* Usar color primario para el título */
    margin-bottom: 0.5rem;
    /* Espacio debajo del título */
    font-size: 1rem;
    /* Tamaño adecuado para subtítulo de tarjeta */
    text-align: center;
}

.stability-results .stability-list li {
    margin-bottom: 0.4rem;
    color: var(--text-color);
    /* Reafirmar color de texto para los items */
}

/* Estilos para evaluación por aplicación */
.app-assessment-results {
    margin-top: 1rem;
    width: 100%;
    text-align: center;
}

.app-assessment-results .text-muted {
    color: var(--text-muted-color);
    text-align: center;
}

.app-assessment-results h5 {
    /* Estilo para futuro título */
    color: var(--primary-color);
    margin-bottom: 0.5rem;
    font-size: 1rem;
    text-align: center;
}

.app-assessment-results .app-assessment-list {
    list-style: none;
    padding: 0;
    margin: 0;
    /* Sin margen superior si no hay h5 por ahora */
    color: var(--text-color);
    font-size: 0.85rem;
    margin: 0 auto;
    width: 100%;
    max-width: 260px;
    text-align: left;
}

.app-assessment-results .app-assessment-list li {
    margin-bottom: 0.4rem;
    color: var(--text-color);
}

.text-muted.small {
    color: #aaa !important;
    /* A lighter gray color - adjust as needed - !important to override other styles */
    width: 100%;
    text-align: center;
}

.text-muted.small a:hover {
    color: #bbb;
    /* A slightly brighter gray on hover */
}

/* Alineación específica para los contenedores de resultados */
#contextual-assessment-results,
#connection-status,
#apps-recommendation,
#app-assessment-results,
#stability-analysis-results {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    min-height: 120px;
}

.container .speed-test-container,
.container .advanced-analysis-container,
.blog-section,
.blog-post {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
}

.blog-card h2 {
    font-size: 1.2rem;
}

.blog-actions {
    margin-top: 1rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: center;
}

.blog-post .lead {
    color: var(--text-muted-color);
}

.blog-post h2,
.blog-post h3 {
    color: var(--primary-color);
}

.blog-post h2 {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}

.blog-post h3 {
    margin-top: 0.85rem;
    font-size: 1rem;
}

.blog-cta {
    margin-top: 1.25rem;
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}