/* style.css */

/* --- Variables de Color (con el nuevo verde) --- */
:root {
    --primary-pink: #f8c8dc;
    --secondary-pink: #f5a9c0;
    /* Rosa para el título y detalles activos */
    --accent-gold: #ffbe8d;
    --text-dark: #333333;
    --text-light: #666666;
    /* Color para el texto de los selectores */
    --bg-light: #ffffff;
    --bg-body: #fdf6f9;
    --border-color: #e0e0e0;
    --button-success: #C6E0B4;
    /* <<< NUEVO COLOR VERDE SOLICITADO */
    --button-danger: #dc3545;
    --button-info: #007bff;
    --button-warning: #ffc107;
    --button-danger-hover: #e57373;
}

/* --- Estilos Generales --- */
body {
    font-family: 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
    line-height: 1.6;
    background-color: var(--bg-body);
    margin: 0;
    padding: 0;
    color: var(--text-dark);
}

.container {
    max-width: 960px;
    margin: 20px auto;
    background: var(--bg-light);
    padding: 25px;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    text-align: center;
    color: var(--text-dark);
    margin-bottom: 20px;
    font-weight: 600;
}

/* --- CAMBIO: Color del Título Principal --- */
h1 {
    color: var(--secondary-pink);
    font-weight: 700;
}

hr {
    border: none;
    border-top: 1px solid var(--border-color);
    margin: 30px 0;
}

/* (Estilos de Tablas no cambian) */
table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
    border-radius: 8px;
    overflow: hidden;
}

th,
td {
    padding: 15px;
    border: 1px solid var(--border-color);
    text-align: left;
}

th {
    background-color: var(--primary-pink);
    color: var(--bg-light);
    font-weight: bold;
    text-transform: uppercase;
    font-size: 0.9em;
}

td {
    background-color: var(--bg-light);
}


/* --- Estilos de Formularios (con selectores mejorados) --- */
/* (Esta sección se usará en otras páginas, la dejamos como base) */
form {
    border: 1px solid var(--border-color);
    padding: 25px;
    border-radius: 8px;
    background: #fdfdfd;
}

.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: var(--text-light);
}

.form-group input,
.form-group select {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 15px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 1em;
    transition: border-color 0.2s;
}


/* (Estilos de Botones no cambian) */
.btn {
    padding: 10px 20px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    text-decoration: none;
    color: white;
    font-weight: bold;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn:hover {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 25px;
}

.btn-crear {
    background-color: var(--button-success);
    color: var(--text-dark);
}

.btn-crear:hover {
    background-color: #b0d19a;
}

.btn-guardar {
    background-color: var(--secondary-pink);
    color: white;
}

.btn-guardar:hover {
    background-color: #e08ea8;
}

.btn-cancelar {
    background-color: var(--text-light);
    color: white;
}

.btn-cancelar:hover {
    background-color: #5a6268;
}


/* --- Header y Navegación Rediseñado --- */
.main-header {
    background-color: var(--bg-light);
    padding: 0;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.header-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 10px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    box-sizing: border-box;
    gap: 20px;
}

/* Wrapper para Logo + Info Usuario */
.brand-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    /* Alinear a la izquierda */
    justify-content: center;
    flex-shrink: 0;
}

.main-header .logo {
    height: 60px;
    /* Reducido levemente para balancear */
    width: auto;
    display: block;
}

.user-info {
    font-size: 0.85em;
    color: var(--text-light);
    margin-top: 5px;
    display: flex;
    align-items: center;
    gap: 8px;
    /* Espacio entre nombre e icono */
}

.user-name {
    font-weight: 600;
    color: var(--secondary-pink);
}

.logout-icon {
    color: var(--button-danger);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2px;
    border-radius: 4px;
    transition: background-color 0.2s;
}

.logout-icon:hover {
    background-color: #fee;
}

.logout-icon svg {
    width: 16px;
    height: 16px;
    fill: currentColor;
}

/* Info usuario móvil: Oculta en desktop */
.mobile-user-info {
    display: none;
}

/* Navegación Desktop Compacta */
.main-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: nowrap;
    /* Forzar una línea */
    justify-content: flex-end;
    align-items: center;
}

.main-nav ul li {
    margin: 0 10px;
    /* Menos margen para que entren */
}

.main-nav ul li a {
    text-decoration: none;
    color: var(--text-light);
    font-weight: 500;
    padding: 8px 0;
    transition: color 0.3s ease;
    position: relative;
    font-size: 0.95em;
    /* Fuente un poco más chica */
    white-space: nowrap;
    /* No romper líneas en items */
}

.main-nav ul li a:hover {
    color: var(--text-dark);
}

.main-nav ul li a::after {
    content: '';
    position: absolute;
    width: 0;
    height: 3px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--secondary-pink);
    transition: width 0.3s ease, background-color 0.3s ease;
}

.main-nav ul li a:hover::after {
    width: 100%;
}

.main-nav ul li a.active {
    color: var(--secondary-pink);
    font-weight: 600;
}

.main-nav ul li a.active::after {
    width: 100%;
    background-color: var(--secondary-pink);
}


/* --- Estilos para la página de Reservas (index.php) --- */
.filtros {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 20px;
    align-items: start;
    /* Alinea los items al inicio para evitar saltos */
    margin-bottom: 30px;
    padding: 25px;
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 8px;
}

/* --- CAMBIO: Alineación de los filtros --- */
.filtro-item {
    display: flex;
    flex-direction: column;
    text-align: center;
    /* Centra el label */
}

.filtro-item label {
    font-size: 0.9em;
    color: var(--text-light);
    margin-bottom: 8px;
    min-height: 2.5em;
    /* Altura mínima para que no salte si el texto ocupa 2 líneas */
    display: flex;
    align-items: center;
    justify-content: center;
}

/* --- CAMBIO: Nuevos estilos para los selectores --- */
.filtros select {
    width: 100%;
    padding: 12px 15px;
    border-radius: 6px;
    font-size: 0.8em;
    font-weight: 500;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23666666%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22/%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 15px top 50%;
    background-size: 10px auto;

    /* Colores solicitados */
    background-color: var(--primary-pink);
    color: var(--text-light);
    border: 1px solid var(--secondary-pink);
}

.filtros select:disabled {
    background-color: #e9ecef;
    border-color: #ccc;
    background-image: none;
    /* Quitamos la flecha en estado deshabilitado */
}

/* (El resto de los estilos del index.php no cambian) */
.navegacion-dias {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.navegacion-dias .btn {
    background-color: var(--primary-pink);
    color: white;
    font-size: 0.9em;
    padding: 8px 15px;
}

.navegacion-dias .btn:hover {
    background-color: var(--secondary-pink);
}

.navegacion-dias .btn:disabled {
    background-color: #ccc;
    cursor: not-allowed;
    box-shadow: none;
}

.navegacion-dias span {
    font-weight: bold;
    color: var(--text-dark);
}

.dias-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 15px;
}

.dia-columna {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    text-align: center;
    background-color: #fff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dia-columna:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
}

.dia-columna h4 {
    margin: 0;
    background-color: var(--primary-pink);
    color: white;
    padding: 10px;
    border-radius: 8px 8px 0 0;
    font-size: 0.95em;
    font-weight: 500;
}

.slots-grid {
    padding: 15px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.slot-link {
    display: block;
    text-decoration: none;
    padding: 10px 8px;
    border-radius: 6px;
    font-weight: bold;
    transition: all 0.2s;
    font-size: 0.9em;
}

.slot-link:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

/* --- CAMBIO: Nuevo color de botón disponible --- */
.slot-disponible {
    background-color: var(--button-success);
    color: var(--text-dark);
    /* Texto oscuro para mejor contraste */
    border: 1px solid #b0d19a;
}

.slot-disponible:hover {
    background-color: #b0d19a;
}

.slot-pasado {
    background-color: #e9ecef;
    color: #adb5bd;
    cursor: not-allowed;
    border: 1px solid #dee2e6;
}

/* --- NUEVOS ESTILOS PARA LA PÁGINA DE CONFIRMACIÓN --- */

/* --- CAMBIO: Formulario con label y textbox en la misma línea --- */
.form-group {
    display: grid;
    /* Usamos grid para alinear fácilmente */
    grid-template-columns: 120px 1fr;
    /* La etiqueta ocupa 120px, el input el resto */
    align-items: center;
    /* Centra verticalmente la etiqueta y el input */
    margin-bottom: 12px;
}

.form-group label {
    font-size: 0.9em;
    font-weight: 500;
    color: var(--text-light);
    padding-right: 15px;
    /* Espacio entre la etiqueta y el campo */
    text-align: right;
    /* Alinea el texto de la etiqueta a la derecha */
}

/* Nueva estructura para el resumen del turno */
.resumen-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    /* Dos columnas iguales */
    gap: 10px 20px;
    /* Espacio vertical y horizontal */
    background-color: var(--bg-body);
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 30px;
    border: 1px solid var(--border-color);
}

.resumen-item {
    display: flex;
    flex-direction: column;
}

.resumen-item .label {
    font-size: 0.8em;
    color: var(--text-light);
    margin-bottom: 4px;
    text-transform: uppercase;
}

.resumen-item .value {
    font-size: 1.1em;
    font-weight: 500;
    color: var(--text-dark);
}

.resumen-item.full-width {
    grid-column: 1 / -1;
    /* Ocupa todo el ancho */
    text-align: center;
    margin-top: 10px;
}

/* --- ESTILOS PARA VER TURNOS (verturnos.php) --- */

.view-turnos-container {
    max-width: 1000px;
}

.header-turnos {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 20px;
}

.header-turnos h1 {
    margin: 0;
    text-align: left;
}

.calendar-view-grid {
    display: grid;
    grid-template-columns: 300px 1fr;
    /* Columna fija para calendario y más ancha para detalles */
    gap: 30px;
}

.calendar-sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

#calendar-container {
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 15px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}

.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--text-dark);
    color: white;
    padding: 8px 12px;
    border-radius: 6px;
    margin-bottom: 10px;
}

.calendar-header .month-year {
    font-size: 1em;
    font-weight: bold;
    text-transform: capitalize;
}

.calendar-header .nav-btn {
    background: none;
    border: none;
    color: white;
    font-size: 1.2em;
    cursor: pointer;
    padding: 5px 8px;
    border-radius: 4px;
    transition: background-color 0.2s;
}

.calendar-header .nav-btn:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.calendar-days-of-week {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-weight: bold;
    font-size: 0.8em;
    color: var(--text-light);
    margin-bottom: 8px;
}

.calendar-days-of-week div {
    padding: 5px 0;
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 5px;
    text-align: center;
    font-size: 0.9em;
}

.calendar-day,
.empty-day {
    padding: 8px 0;
    border-radius: 4px;
    transition: background-color 0.2s, color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 30px;
}

.calendar-day {
    cursor: pointer;
    border: 1px solid #eee;
}

.calendar-day:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.calendar-day.selected {
    box-shadow: 0 0 0 2px var(--secondary-pink) !important;
}

.calendar-day.dia-actual {
    box-shadow: 0 0 0 2px var(--secondary-pink);
}

.calendar-day.pasado {
    opacity: 0.6;
}

.leyenda-colores {
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 15px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}

.leyenda-colores h4 {
    margin: 0 0 10px 0;
    text-align: left;
    font-size: 1em;
}

.leyenda-item {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
    font-size: 0.9em;
    color: var(--text-dark);
}

.color-box {
    width: 15px;
    height: 15px;
    border-radius: 3px;
    margin-right: 8px;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

/* --- NUEVOS ESTILOS SIMPLIFICADOS PARA EL CALENDARIO --- */

/* Días con turnos disponibles - VERDE */
.calendar-day.dia-disponible {
    background-color: var(--button-success);
    color: var(--text-dark);
}

/* Días sin turnos disponibles - ROSA */
.calendar-day.dia-no-disponible {
    background-color: var(--primary-pink);
    color: var(--text-dark);
}

/* Leyenda */
.color-box.dia-disponible {
    background-color: var(--button-success);
}

.color-box.dia-no-disponible {
    background-color: var(--primary-pink);
}

.turno-details-panel {
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 25px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
    min-height: 400px;
}

.turno-details-panel h4 {
    text-align: left;
    color: var(--text-dark);
    margin-bottom: 20px;
    font-size: 1.3em;
}

.turno-item {
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 15px;
    margin-bottom: 15px;
    background-color: #fff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.turno-item p {
    margin: 5px 0;
    font-size: 0.95em;
    color: var(--text-dark);
}

.turno-item p strong {
    color: var(--secondary-pink);
    font-size: 1.1em;
}

/* Estilos adicionales para el selector de profesional */
.selector-profesional {
    display: flex;
    align-items: center;
    gap: 10px;
}

.selector-profesional label {
    font-weight: 500;
    color: var(--text-dark);
}

.selector-profesional select {
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: var(--bg-light);
}

/* Estilos para mensajes */
.cargando,
.no-disponible {
    text-align: center;
    padding: 20px;
    color: var(--text-light);
    font-style: italic;
}

.mensaje {
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 20px;
    text-align: center;
}

.mensaje.exito {
    background-color: #d4edda;
    border: 1px solid #c3e6cb;
    color: #155724;
}

.mensaje.error {
    background-color: #f8d7da;
    border: 1px solid #f5c6cb;
    color: #721c24;
}

/* --- NUEVOS ESTILOS PARA ACORDEÓN EN PROFESIONALES.PHP --- */

.accordion-container {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
    background-color: #fff;
}

.accordion-item+.accordion-item {
    border-top: 1px solid var(--border-color);
}

.accordion-header {
    background-color: #f8f9fa;
    padding: 15px;
    cursor: pointer;
    font-weight: bold;
    color: var(--text-dark);
    transition: background-color 0.2s;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.accordion-header:hover {
    background-color: #f1f3f5;
}

/* Icono de flecha para el acordeón */
.accordion-header::after {
    content: '↓';
    /* Flecha hacia abajo por defecto */
    font-size: 1.2em;
    color: var(--secondary-pink);
    transition: transform 0.3s ease;
}

.accordion-item.active .accordion-header::after {
    transform: rotate(180deg);
    /* Gira la flecha hacia arriba */
}

.accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    background-color: #fff;
}

.accordion-item.active .accordion-content {
    max-height: 2000px;
    /* Un valor alto para permitir que el contenido se expanda */
    transition: max-height 0.5s ease-in;
}

/* ==========================================================================
   ESTILOS ESPECÍFICOS PARA PROFESIONALES.PHP
   ========================================================================== */

.accordion-container {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
    background-color: #fff;
}

.accordion-item+.accordion-item {
    border-top: 1px solid var(--border-color);
}

.accordion-header {
    background-color: #f8f9fa;
    padding: 15px;
    cursor: pointer;
    font-weight: bold;
    color: var(--text-dark);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.accordion-header:hover {
    background-color: #f1f3f5;
}

/* CAMBIO: Icono de flecha/triángulo para el acordeón */
.accordion-header::after {
    content: '▼';
    /* Triángulo hacia abajo por defecto */
    font-size: 1em;
    color: var(--secondary-pink);
    transition: transform 0.3s ease;
}

.accordion-item.active .accordion-header::after {
    transform: rotate(180deg);
    /* Gira el triángulo hacia arriba */
}

.accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}

.accordion-item.active .accordion-content {
    max-height: 2000px;
    transition: max-height 0.5s ease-in;
}

.accordion-content .servicio-fila {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 10px;
    align-items: center;
    padding: 8px 15px;
    border-top: 1px solid #f0f0f0;
}

.servicio-fila.header-row {
    font-weight: bold;
    color: var(--text-light);
    font-size: 0.8em;
    text-transform: uppercase;
    text-align: center;
    padding: 10px 15px;
    border-top: none;
    background-color: #f8f9fa;
}

.servicio-btn {
    padding: 12px;
    font-weight: 500;
    font-size: 0.9em;
    border-radius: 6px;
    cursor: pointer;
    text-align: left;
    transition: all 0.2s;
    user-select: none;
}

.servicio-fila input {
    padding: 10px 5px;
    font-size: 0.9em;
    text-align: center;
    border: 1px solid var(--border-color);
    border-radius: 4px;
}

.servicio-fila input::placeholder {
    color: #ccc;
    font-style: italic;
}

.servicio-fila input:disabled {
    background-color: #e9ecef;
}

/* CAMBIO: Lógica de colores y selección en profesionales.php */
.servicio-fila:not(.header-row):not(.seleccionado) .servicio-btn {
    background-color: #f0f0f0;
    /* Gris clarito */
    color: var(--text-light);
}

.servicio-fila.seleccionado {
    background-color: transparent;
    /* El fondo de la fila ya no cambia */
}

.servicio-fila.seleccionado .servicio-btn {
    background-color: var(--primary-pink);
    /* Rosa */
    color: var(--text-dark);
    font-weight: bold;
}

/* ==========================================================================
   HEADER Y NAVEGACIÓN
   ========================================================================== */

.main-header {
    background-color: var(--bg-light);
    padding: 0;
    /* Quitamos el padding para que el contenedor interior lo maneje */
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08);
    position: sticky;
    top: 0;
    z-index: 1000;
    width: 100%;
}

.header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1100px;
    /* Ancho máximo del contenido del header */
    margin: 0 auto;
    /* Centra el contenido */
    padding: 10px 20px;
    /* Padding interior */
}

.main-header .logo {
    height: 60px;
    /* Puedes ajustar el tamaño del logo aquí */
    width: auto;
}

.main-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
}

.main-nav ul li {
    margin: 0 15px;
    /* Espacio entre los elementos del menú */
}

.main-nav ul li a {
    text-decoration: none;
    color: var(--text-light);
    font-weight: 500;
    padding: 10px 5px;
    position: relative;
    font-size: 1em;
    transition: color 0.3s ease;
}

.main-nav ul li a:hover {
    color: var(--text-dark);
}

/* Subrayado rosa para el enlace activo y al pasar el mouse */
.main-nav ul li a::after {
    content: '';
    position: absolute;
    width: 0;
    height: 3px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--secondary-pink);
    transition: width 0.3s ease;
}

.main-nav ul li a:hover::after,
.main-nav ul li a.active::after {
    width: 100%;
}

.main-nav ul li a.active {
    color: var(--secondary-pink);
    /* Color del texto del enlace activo */
    font-weight: 600;
}

/* CAMBIO: Nuevos estilos para botones Editar/Eliminar */
.acciones a {
    padding: 6px 12px;
    border-radius: 5px;
    font-size: 0.7em;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.acciones a:hover {
    transform: translateY(-1px);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.acciones a.editar {
    background-color: var(--primary-pink);
    color: var(--text-dark);
}

.acciones a.eliminar {
    background-color: var(--button-danger-hover);
    color: white;
}

/* ==========================================================================
   ESTILOS FINALES PARA CALENDARIO DE GESTIÓN (verturnos.php)
   ========================================================================== */

/* Días con turnos disponibles - VERDE */
.calendar-day.dia-disponible {
    background-color: var(--button-success);
    color: var(--text-dark);
}

/* Días sin turnos disponibles - ROSA */
.calendar-day.dia-no-disponible {
    background-color: var(--primary-pink);
    color: var(--text-dark);
    cursor: default;
}

.calendar-day.dia-no-disponible:hover {
    background-color: var(--primary-pink);
}

/* Hace que el texto del número del día se ponga en negrita y oscuro */
.calendar-day.dia-con-turno {
    font-weight: bold !important;
    color: var(--text-dark) !important;
}

/* Leyenda */
.color-box.dia-disponible {
    background-color: var(--button-success);
}

.color-box.dia-no-disponible {
    background-color: var(--primary-pink);
}

/* ==========================================================================
   MEDIA QUERIES FOR RESPONSIVENESS
   ========================================================================== */

/* Botón Toggle (Oculto en Desktop) */
.menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    flex-direction: column;
    gap: 4px;
    padding: 10px;
    /* Aumentar área táctil */
}

.menu-toggle span {
    display: block;
    width: 25px;
    height: 3px;
    background-color: var(--text-dark);
    border-radius: 2px;
    transition: all 0.3s;
}

/* Animación Toggle */
.menu-toggle.open span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.menu-toggle.open span:nth-child(2) {
    opacity: 0;
}

.menu-toggle.open span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Estilos para calendario de cliente */
/* Estilos para calendario de cliente */
/* Estilos para calendario de cliente */
.calendar-day.client-reserved-future {
    background-color: #d4edda !important;
    /* Verde suave - Future Reserved */
    color: #155724 !important;
    border: 1px solid #c3e6cb;
    font-weight: bold;
}

.calendar-day.client-free-future {
    background-color: #ffe0e6 !important;
    /* Rosa suave - Future Free */
    color: #721c24 !important;
    border: 1px solid #f5c6cb;
}

.calendar-day.client-reserved-past {
    background-color: #e2e3e5 !important;
    /* Gris suave - Past Reserved */
    color: #383d41 !important;
    border: 1px solid #d6d8db;
    font-weight: bold;
}

.calendar-day.client-free-past {
    background-color: #ffffff !important;
    /* Blanco - Past Free */
    color: #666 !important;
    border: 1px solid #eee;
    opacity: 0.7;
}

/* Override para quitar el gris default de 'pasado' si se requiere en vista cliente, 
   o dejarlo para los días pasados sin turno? 
   User: "Blanco si tiene una reserva y la fecha ya paso". 
   Implica que los que tienen reserva son blancos. Los que no, pueden ser grises? 
   No especificó. Asumiremos que client-reserved-past gana sobre .pasado gracias a !important.
*/


/* Ajuste para móvil en tablas y grids si es necesario */
@media (max-width: 768px) {


    /* --- HEADER (Hamburger Menu) --- */
    .menu-toggle {
        display: flex;
        /* Mostrar botón */
        z-index: 1001;
    }
}

/* ==========================================================================
   ESTILOS DE AUTENTICACIÓN (LOGIN / REGISTRO)
   ========================================================================== */
body.login-page {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background-color: #f4f4f9;
    margin: 0;
}

.login-container {
    width: 100%;
    max-width: 450px;
    padding: 2rem;
    background: white;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Botón principal en páginas de autenticación (Rosa) */
.login-page .btn-primary {
    background-color: var(--secondary-pink) !important;
    border-color: var(--secondary-pink) !important;
    color: #fff;
    font-weight: bold;
    width: 100%;
    /* Asegurar ancho completo en estos formularios */
}

.login-page .btn-primary:hover {
    filter: brightness(0.95);
    background-color: var(--secondary-pink) !important;
    border-color: var(--secondary-pink) !important;
}

/* --- MODAL POPUP PROFESIONAL --- */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    /* Fondo semitransparente oscuro */
    backdrop-filter: blur(3px);
    /* Efecto difuminado moderno */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal-content {
    background: white;
    padding: 30px;
    border-radius: 12px;
    width: 90%;
    max-width: 400px;
    text-align: center;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
    transform: translateY(20px);
    transition: transform 0.3s ease;
    position: relative;
    border-top: 5px solid var(--secondary-pink);
    /* Detalle de color */
}

/* --- CLIENT BOOKING INTERFACE --- */
.calendar-grid-simple {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 5px;
    text-align: center;
}

.b-day {
    padding: 10px;
    background: #f9f9f9;
    border-radius: 4px;
    cursor: default;
    color: #ccc;
}

.b-day.available {
    background: #d4edda;
    color: #155724;
    cursor: pointer;
    font-weight: bold;
    transition: all 0.2s;
}

.b-day.available:hover {
    background: #c3e6cb;
    transform: scale(1.05);
}

.b-day.selected {
    background: var(--secondary-pink);
    color: white;
    border: 2px solid var(--primary-pink);
}

.slot-btn {
    display: block;
    width: 100%;
    padding: 10px;
    border: 1px solid var(--secondary-pink);
    background: white;
    color: var(--secondary-pink);
    border-radius: 6px;
    cursor: pointer;
    font-weight: 500;
    transition: all 0.2s;
}

.slot-btn:hover {
    background: var(--secondary-pink);
    color: white;
}

.btn-mini {
    background: #eee;
    border: none;
    padding: 5px 10px;
    border-radius: 4px;
    cursor: pointer;
}

.form-select {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 1rem;
}

.modal-icon-success {
    width: 60px;
    height: 60px;
    background-color: #d4edda;
    color: #155724;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px auto;
    font-size: 30px;
}

.modal-title {
    font-size: 1.5rem;
    color: var(--text-dark);
    margin-bottom: 10px;
    font-weight: bold;
}

.modal-text {
    color: var(--text-light);
    margin-bottom: 25px;
    font-size: 1rem;
}

.btn-modal {
    background-color: var(--secondary-pink);
    color: white;
    padding: 12px 25px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: bold;
    display: inline-block;
    transition: background-color 0.2s;
    border: none;
    cursor: pointer;
    width: 100%;
}

.btn-modal:hover {
    background-color: #e08ea8;
}


/* ==========================================================================
   ESTILOS RESPONSIVOS DE NAVEGACIÓN Y LAYOUT (MÓVIL)
   ========================================================================== */
@media (max-width: 768px) {
    .header-container {
        padding: 5px 15px;
        /* Menos padding en móvil */
    }

    .main-nav {
        position: absolute;
        top: 100%;
        /* Justo debajo del header */
        left: 0;
        width: 100%;
        background-color: var(--bg-light);
        box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.3s ease-out;
        flex-direction: column;
        z-index: 1000;
    }

    .main-nav.active {
        max-height: 100vh;
        /* Permitir scroll si el menú es muy alto */
        border-top: 1px solid var(--border-color);
        overflow-y: auto;
    }

    .main-nav ul {
        flex-direction: column;
        padding: 0;
        width: 100%;
    }

    .main-nav ul li {
        margin: 0;
        text-align: center;
        width: 100%;
        border-bottom: 1px solid #f0f0f0;
    }

    .main-nav ul li a {
        display: block;
        padding: 15px;
        width: 100%;
        box-sizing: border-box;
    }

    .main-nav ul li a:hover {
        background-color: #f9f9f9;
        color: var(--secondary-pink);
    }

    .main-nav ul li a::after {
        display: none;
        /* Quitar subrayado animado en móvil */
    }

    /* --- LAYOUT GENERAL --- */
    .container {
        padding: 15px;
        width: 95%;
        margin: 10px auto;
        box-sizing: border-box;
    }

    h1 {
        font-size: 1.5em;
    }

    h2 {
        font-size: 1.3em;
    }

    /* --- CALENDARIO (index.php, verturnos.php) --- */
    .calendar-view-grid {
        display: block;
        /* Romper el grid */
    }

    .calendar-sidebar {
        width: 100%;
        margin-bottom: 20px;
    }

    /* Asegurar que el calendario pequeño no se rompa */
    #calendar-container {
        padding: 10px;
        overflow-x: auto;
        /* Scroll si es muy pequeño el dispositivo */
        margin: 0 auto;
    }

    .calendar-grid {
        gap: 2px;
    }

    .calendar-day {
        font-size: 0.8em;
        height: 35px;
        /* Días más altos para toque fácil */
    }

    /* Panel de Detalles más compacto, irá DEBAJO del calendario */
    .turno-details-panel {
        padding: 15px;
        min-height: auto;
        width: 100%;
        box-sizing: border-box;
    }

    /* --- FILTROS (index.php) --- */
    .filtros {
        grid-template-columns: 1fr;
        /* Columna única */
        padding: 15px;
        gap: 15px;
    }

    /* Botones de filtro visualización (index.php pro) */
    .filtros-visualizacion {
        flex-direction: column;
    }

    .filtros-visualizacion .btn {
        width: 100%;
        margin-bottom: 5px;
    }

    /* --- RESUMEN DE RESERVAS (confirmar.php) --- */
    .resumen-grid {
        grid-template-columns: 1fr;
    }

    .resumen-item {
        border-bottom: 1px solid #eee;
        padding-bottom: 10px;
        margin-bottom: 10px;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    .resumen-item .label {
        margin-bottom: 0;
    }

    /* --- GRID DE DÍAS (nuevo_turno.php) --- */
    .dias-grid {
        grid-template-columns: repeat(2, 1fr);
        /* 2 columnas en móvil en lugar de 6 */
        gap: 10px;
    }

    .navegacion-dias {
        flex-direction: column;
        gap: 10px;
    }

    .navegacion-dias button {
        width: 100%;
    }

    /* --- MENÚ HAMBURGUESA MEJORADO --- */
    .menu-toggle {
        display: flex;
        border: 1px solid var(--border-color);
        /* Borde para visibilidad */
        border-radius: 4px;
        padding: 8px 12px;
        margin-left: auto;
        /* Empujar a la derecha */
    }

    .menu-toggle span {
        background-color: #333;
        /* Forzar color oscuro */
    }

    /* --- HEADER (Hamburger Menu) --- */
    .menu-toggle {
        display: flex;
        /* Mostrar botón */
        z-index: 1002;
        /* Más alto que todo */
        position: relative;
        margin-left: auto;
        /* Empujar a la derecha */
    }

    /* Asegurar que el contenedor interno sea flex para que margin-left: auto funcione */
    .header-container {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 10px 15px;
        /* Menos padding en móvil */
        width: 100%;
        box-sizing: border-box;
    }

    .header-logo {
        flex-grow: 0;
    }

    .main-nav {
        position: absolute;
        top: 100%;
        /* Justo debajo del header */
        left: 0;
        width: 100%;
        background-color: var(--bg-light);
        box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.3s ease-out;
        flex-direction: column;
        z-index: 1000;
        display: flex;
        /* IMPORTANTE: para que se renderice contenido */
    }

    .main-nav.active {
        max-height: 100vh;
        /* Permitir scroll si el menú es muy alto */
        border-top: 1px solid var(--border-color);
        overflow-y: auto;
    }

    .main-nav ul {
        flex-direction: column;
        padding: 0;
        width: 100%;
    }

    .main-nav ul li {
        margin: 0;
        text-align: center;
        width: 100%;
        border-bottom: 1px solid #f0f0f0;
    }

    .main-nav ul li a {
        display: block;
        padding: 15px;
        width: 100%;
        box-sizing: border-box;
    }

    .main-nav ul li a:hover {
        background-color: #f9f9f9;
        color: var(--secondary-pink);
    }

    .main-nav ul li a::after {
        display: none;
        /* Quitar subrayado animado en móvil */
    }

    /* --- LAYOUT GENERAL --- */
    .container {
        padding: 15px;
        width: 95%;
        margin: 10px auto;
        box-sizing: border-box;
    }

    h1 {
        font-size: 1.5em;
    }

    h2 {
        font-size: 1.3em;
    }

    /* --- CALENDARIO (index.php, verturnos.php) --- */
    .calendar-view-grid {
        display: block;
        /* Romper el grid */
    }

    .calendar-sidebar {
        width: 100%;
        margin-bottom: 20px;
    }

    /* Asegurar que el calendario pequeño no se rompa */
    #calendar-container {
        padding: 10px;
        overflow-x: auto;
        /* Scroll si es muy pequeño el dispositivo */
        margin: 0 auto;
    }

    .calendar-grid {
        gap: 2px;
    }

    .calendar-day {
        font-size: 0.8em;
        height: 35px;
        /* Días más altos para toque fácil */
    }

    /* Panel de Detalles más compacto, irá DEBAJO del calendario */
    .turno-details-panel {
        padding: 15px;
        min-height: auto;
        width: 100%;
        box-sizing: border-box;
    }

    /* --- FILTROS (index.php) --- */
    .filtros {
        grid-template-columns: 1fr;
        /* Columna única */
        padding: 15px;
        gap: 15px;
    }

    /* Botones de filtro visualización (index.php pro) */
    .filtros-visualizacion {
        flex-direction: column;
    }

    .filtros-visualizacion .btn {
        width: 100%;
        margin-bottom: 5px;
    }

    /* --- RESUMEN DE RESERVAS (confirmar.php) --- */
    .resumen-grid {
        grid-template-columns: 1fr;
    }

    .resumen-item {
        border-bottom: 1px solid #eee;
        padding-bottom: 10px;
        margin-bottom: 10px;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    .resumen-item .label {
        margin-bottom: 0;
    }

    /* --- GRID DE DÍAS (nuevo_turno.php) --- */
    .dias-grid {
        grid-template-columns: repeat(2, 1fr);
        /* 2 columnas en móvil en lugar de 6 */
        gap: 10px;
    }

    .navegacion-dias {
        flex-direction: column;
        gap: 10px;
    }

    .navegacion-dias button {
        width: 100%;
    }

    /* --- TABLAS RESPONSIVAS (CARD VIEW) --- */
    table,
    thead,
    tbody,
    th,
    td,
    tr {
        display: block;
    }

    /* Ocultar encabezados de tabla */
    thead tr {
        position: absolute;
        top: -9999px;
        left: -9999px;
    }

    tr {
        border: 1px solid var(--border-color);
        margin-bottom: 15px;
        border-radius: 8px;
        background-color: #fff;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
    }

    td {
        /* Comportamiento como fila dentro de la tarjeta */
        border: none;
        border-bottom: 1px solid #f0f0f0;
        position: relative;
        padding-left: 45% !important;
        /* Espacio para el label */
        text-align: right;
        min-height: 25px;
        /* Altura mínima */
        display: flex;
        align-items: center;
        justify-content: flex-end;
        padding-top: 10px !important;
        padding-bottom: 10px !important;
        white-space: normal;
        /* Permitir salto de línea en contenido largo */
    }

    td:last-child {
        border-bottom: none;
    }

    td:before {
        /* Label simmulado usando data-label */
        position: absolute;
        top: 0;
        left: 15px;
        width: 40%;
        padding-right: 10px;
        white-space: nowrap;
        text-align: left;
        font-weight: bold;
        color: var(--text-light);
        content: attr(data-label);
        height: 100%;
        display: flex;
        align-items: center;
        font-size: 0.85em;
        text-transform: uppercase;
    }

    .acciones {
        justify-content: flex-end;
    }

    /* --- BOTONES --- */
    .btn {
        width: 100%;
        margin-bottom: 10px;
        box-sizing: border-box;
        text-align: center;
    }

    .header-turnos .acciones-header {
        width: 100%;
        flex-direction: column;
    }

    .acciones-header .btn {
        margin-bottom: 0;
    }

    /* Filtro items (nuevo_turno.php) */
    .filtro-item {
        text-align: left;
    }

    .filtro-item label {
        justify-content: flex-start;
        text-align: left;
    }

    /* --- Ajustes específicos fichatecnica --- */
    .accordion-header {
        font-size: 0.9em;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .accordion-header span:last-child {
        align-self: flex-end;
        /* Estado a la derecha o abajo */
    }

    /* --- HORARIOS RESPONSIVOS (profesionales.php) --- */
    .horario-fila {
        display: flex !important;
        /* Sobrescribir grid inline */
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 10px !important;
        padding: 15px 0 !important;
    }

    .horario-inputs {
        width: 100%;
        display: grid !important;
        grid-template-columns: 1fr auto 1fr;
        /* Inicio - 'a' - Fin */
        gap: 10px;
    }

    .horario-inputs input[type="time"] {
        width: 100%;
        text-align: center;
    }

    /* Servicios inputs (stack vertical) en mobile */
    .servicio-fila {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .servicio-fila input {
        width: 100%;
    }

    .servicio-btn {
        width: 100%;
        text-align: center;
    }
}
/* --- RESPONSIVE DESIGN (Mvil y Tablets) --- */
@media (max-width: 768px) {
    .calendar-view-grid {
        grid-template-columns: 1fr; /* Stack vertically: Calendar top, Slots bottom */
        gap: 20px;
    }

    .calendar-sidebar, .turno-details-panel {
        width: 100%;
        min-height: auto;
    }
    
    .filtros {
        grid-template-columns: 1fr; /* 1 column filters */
        padding: 15px;
        gap: 15px;
    }

    .header-container {
        flex-direction: column;
        align-items: center;
        padding: 15px;
    }

    .resumen-grid {
        grid-template-columns: 1fr; /* 1 column popup details */
    }

    .modal-content {
        width: 90%;
        margin: 20% auto;
        padding: 20px;
        max-width: none;
    }

    .container {
        padding: 15px;
        margin: 10px auto;
    }

    /* Adjust Calendar Day Size for touch */
    .calendar-day {
        min-height: 40px; 
    }
}


/* Colores de Estado de Turno */
.estado-pendiente { color: #856404; background-color: #fff3cd; border: 1px solid #ffeeba; padding: 2px 6px; border-radius: 4px; font-weight: bold; }
.estado-seada { color: #155724; background-color: #d4edda; border: 1px solid #c3e6cb; padding: 2px 6px; border-radius: 4px; font-weight: bold; }
.estado-pagada { color: #004085; background-color: #cce5ff; border: 1px solid #b8daff; padding: 2px 6px; border-radius: 4px; font-weight: bold; }
.estado-cancelada { color: #721c24; background-color: #f8d7da; border: 1px solid #f5c6cb; padding: 2px 6px; border-radius: 4px; font-weight: bold; }
