/* ==================================== */
/* 1. ESTILOS BASE Y TIPOGRAFÍA */
/* ==================================== */
body {
    font-family: 'Arial', sans-serif;
    background-color: #f4f7f9; /* Fondo muy claro */
    color: #333;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 100vh;
}

header {
    width: 100%;
    background-color: #007bff; /* Azul primario para la cabecera */
    color: white;
    padding: 20px 0;
    text-align: center;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

h1 {
    margin: 0;
    font-size: 1.8em;
}

h2 {
    color: #007bff;
    border-bottom: 2px solid #ccc;
    padding-bottom: 10px;
    margin-bottom: 20px;
}

/* ==================================== */
/* 2. LAYOUT PRINCIPAL */
/* ==================================== */
.container {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    padding: 30px;
    max-width: 1200px; /* Ancho máximo para centrar */
    width: 100%;
}

section {
    background-color: white;
    padding: 25px;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    flex: 1; /* Ocupa el espacio disponible */
    min-width: 350px; /* Asegura que no se hagan demasiado pequeñas */
}

/* ==================================== */
/* 3. ESTILOS DE ENTRADA (INPUT SECTION) */
/* ==================================== */
.input-section {
    order: 1; /* Asegura que la entrada vaya primero */
}

.input-group {
    margin-bottom: 15px;
}

.input-group label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
    color: #333;
}

.input-group input {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-sizing: border-box; /* Incluye padding y border en el width */
    font-size: 1em;
}

.help-text {
    font-size: 0.85em;
    color: #6c757d; /* Gris sutil */
    margin-top: 5px;
}

hr {
    border: none;
    height: 1px;
    background-color: #eee;
    margin: 20px 0;
}

/* Diseño para la opción dual (Ángulo y Tiempo) */
.input-group-dual {
    display: flex;
    gap: 20px;
}
.input-group-dual .input-group {
    flex: 1;
}

.separator {
    text-align: center;
    font-weight: bold;
    color: #007bff;
    margin: 15px 0;
}

/* Estilo del botón */
button {
    width: 100%;
    padding: 15px;
    background-color: #28a745; /* Verde para la acción */
    color: white;
    border: none;
    border-radius: 6px;
    font-size: 1.1em;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.1s;
    margin-top: 20px;
}

button:hover {
    background-color: #218838; /* Oscurece al pasar el mouse */
}

button:active {
    transform: scale(0.99); /* Efecto de "clic" */
}

/* ==================================== */
/* 4. ESTILOS DE RESULTADOS (RESULTS SECTION) */
/* ==================================== */
.results-section {
    order: 2; /* Asegura que los resultados vayan después */
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.result-box {
    background-color: #e9ecef; /* Fondo gris claro para las cajas de resultado */
    padding: 15px;
    border-left: 5px solid #007bff; /* Borde de color para resaltar */
    border-radius: 6px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.result-box p {
    margin: 0;
    font-weight: 500;
}

.result-value {
    font-size: 1.5em;
    font-weight: bold;
    color: #dc3545; /* Rojo para los valores destacados */
    margin-right: 10px;
}

.unit {
    font-size: 0.9em;
    color: #6c757d;
}

/* ==================================== */
/* 5. FOOTER Y RESPONSIVE */
/* ==================================== */
footer {
    width: 100%;
    background-color: #343a40; /* Gris oscuro */
    color: white;
    text-align: center;
    padding: 10px 0;
    margin-top: auto; /* Empuja el footer hacia abajo */
    font-size: 0.8em;
}

/* Media query para hacer el diseño responsivo en pantallas pequeñas */
@media (max-width: 768px) {
    .container {
        flex-direction: column; /* Apila las secciones verticalmente */
        padding: 15px;
    }
    
    section {
        min-width: 100%;
    }
    
    .input-group-dual {
        flex-direction: column;
        gap: 0;
    }
}