/* ============================================================
   CALENDARIO HORIZONTAL - Sistema de Scroll con Botones
   ============================================================ */

/* Contenedor principal: botones + calendario + spinner */
#rc-calendario-container {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    --rc-day-gap: 0.75rem;
    --rc-day-width-min: 58px;
    --rc-day-width-base: 64px;
    --rc-day-height-base: 104px;
}

/* Ocultar botones en móvil (pantallas menores a md) */
@media (max-width: 768px) {
    #rc-scroll-left,
    #rc-scroll-right {
        display: none !important;
    }
}

/* Wrapper del calendario (viewport responsivo) */
#rc-calendario-wrapper {
    flex: 1;
    background: white;
    border-radius: 1rem;
    border: 1px solid #e5e7eb;
    padding: 1rem;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    min-height: 120px;
}

/* Grid de días (flex horizontal con scroll suave) */
#rc-grid-dias {
    display: flex;
    gap: var(--rc-day-gap);
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.25rem;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    
    /* Ocultar scrollbar nativo */
    -ms-overflow-style: none;
    scrollbar-width: none;
}

#rc-grid-dias::-webkit-scrollbar {
    display: none;
}

/* Días redondos (círculos sin comprimir) */
[data-date] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: var(--rc-day-width-base);
    min-width: var(--rc-day-width-base);
    height: var(--rc-day-height-base);
    flex-shrink: 0;
    
    border: 2px solid #d1d5db;
    border-radius: 1rem;
    background: white;
    color: #1f2937;
    
    font-weight: 600;
    font-size: 0.75rem;
    cursor: pointer;
    
    transition: all 0.2s ease;
}

@media (min-width: 769px) {
    [data-date] {
        width: max(var(--rc-day-width-min), calc((100% - (5 * var(--rc-day-gap))) / 6));
        min-width: max(var(--rc-day-width-min), calc((100% - (5 * var(--rc-day-gap))) / 6));
        height: 110px;
        border-radius: 1rem;
    }
}

@media (max-width: 768px) {
    [data-date] {
        width: 58px;
        min-width: 58px;
        height: 98px;
        border-radius: 0.875rem;
    }
}

/* Día sin seleccionar - hover */
[data-date]:not(.selected):not(.disabled):hover {
    border-color: #3b82f6;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.2);
    background: #f0f9ff;
}

/* Día seleccionado */
[data-date].selected {
    background: #dbeafe;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    color: #1e40af;
    font-weight: 700;
}

/* Domingo/Día deshabilitado */
[data-date].disabled {
    opacity: 0.4;
    cursor: not-allowed;
    background: #f3f4f6;
    border-color: #e5e7eb;
}

[data-date].disabled:hover {
    border-color: #e5e7eb;
    box-shadow: none;
    background: #f3f4f6;
}

/* Color de disponibilidad - Verde (muchos slots) */
[data-date].status-high {
    border-color: #22c55e;
    background: #f0fdf4;
}

[data-date].status-high:hover {
    border-color: #22c55e;
    background: #dcfce7;
    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.2);
}

/* Color de disponibilidad - Naranja (pocos slots) */
[data-date].status-medium {
    border-color: #f97316;
    background: #fffbeb;
}

[data-date].status-medium:hover {
    border-color: #f97316;
    background: #fef3c7;
    box-shadow: 0 2px 8px rgba(249, 115, 22, 0.2);
}

/* Color de disponibilidad - Rojo (muy pocos slots) */
[data-date].status-low {
    border-color: #ef4444;
    background: #fef2f2;
}

[data-date].status-low:hover {
    border-color: #ef4444;
    background: #fee2e2;
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.2);
}

/* El día seleccionado siempre debe imponerse al color de disponibilidad */
[data-date].selected,
[data-date].selected:hover,
[data-date].selected.status-high,
[data-date].selected.status-high:hover,
[data-date].selected.status-medium,
[data-date].selected.status-medium:hover,
[data-date].selected.status-low,
[data-date].selected.status-low:hover {
    background: #dbeafe;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    color: #1e40af;
    font-weight: 700;
}

/* Spinner lineal debajo del calendario */
#rc-spinner {
    height: 3px;
    background: #f3f4f6;
    border-radius: 9999px;
    overflow: hidden;
    margin-top: 0.75rem;
    display: none;
}

#rc-spinner.visible {
    display: block;
}

#rc-spinner::after {
    content: '';
    display: block;
    width: 30%;
    height: 100%;
    background: linear-gradient(
        90deg,
        transparent,
        #3b82f6,
        transparent
    );
    animation: slideRight 1.5s infinite;
}

/* Botones de scroll (laterales - rectangulares verticales) */
.rc-scroll-btn {
    width: 36px;
    height: var(--rc-day-height-base);
    border-radius: 0.5rem;
    border: 2px solid #e5e7eb;
    background: white;
    color: #3b82f6;
    
    font-size: 18px;
    font-weight: 600;
    cursor: pointer;
    
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    
    transition: all 0.2s ease;
    padding: 0;
}

@media (min-width: 769px) {
    .rc-scroll-btn {
        height: 110px;
    }
}

@media (max-width: 768px) {
    .rc-scroll-btn {
        height: 98px;
    }
}

.rc-scroll-btn:hover:not(:disabled) {
    border-color: #3b82f6;
    background: #f0f9ff;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.2);
}

.rc-scroll-btn:active:not(:disabled) {
    transform: scale(0.95);
}

.rc-scroll-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Animación de deslizamiento del spinner */
@keyframes slideRight {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(400%); }
}
