body {
    color: #fff;
}

div.calendar {
    margin: 125px calc(100% - 70%); /* Centra el calendario con márgenes calculados */
    margin-bottom: 50px;
    background: linear-gradient(to right, #101010, #3E3E3E); /* Fondo con un degradado */
    border-radius: 10px; /* Bordes redondeados */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra suave para darle profundidad */
    overflow: hidden; /* Oculta cualquier contenido fuera del contenedor */
    
    & > .calendar-header {
        display: flex; /* Usamos Flexbox para la disposición */
        justify-content: space-between; /* Espaciado entre los elementos */
        align-items: center; /* Alinea los elementos al centro */
        padding: 10px;
        background: linear-gradient(to right, #956534, #d2bc8a, #956534); /* Fondo con degradado */
        color: #fff; /* Color blanco para el texto */
    
        & > button.nav-btn {
            flex: 0 0 10%; /* El botón ocupa el 10% del contenedor */
            display: flex;
            justify-content: center; /* Centra el contenido dentro del botón */
            align-items: center; /* Centra el contenido dentro del botón */
            background-color: transparent; /* Fondo transparente */
            color: white; /* Texto blanco */
            border: none; /* Sin borde */
            padding: 0; /* Sin relleno por defecto */
            font-size: 1.2rem; /* Tamaño de fuente */
            font-weight: bold; /* Texto en negrita */
            cursor: pointer; /* Cambia el cursor al puntero al pasar sobre el botón */
            transition: background-color 0.3s; /* Transición suave en el cambio de color de fondo */
        }
    
        & > button.nav-btn:hover {
            transform: scale(1.1); /* Aumenta el tamaño del botón al pasar el cursor */
        }
    
        & > span#calendar-header {
            flex: 0 0 60%; /* El título ocupa el 60% del contenedor */
            text-align: center; /* Centra el texto */
            font-size: 1.5rem; /* Tamaño de fuente */
            font-weight: bold; /* Texto en negrita */
        }
    }

    & > div.calendar-body {
        display: grid; /* Usamos Grid para la disposición de los días */
        grid-template-columns: repeat(7, 1fr); /* Crea 7 columnas (una por cada día de la semana) */
        padding: 10px;
        background-color: #101010; /* Fondo oscuro para el cuerpo del calendario */
        
        & > div.day, /* Estilos para los días de la semana */
        & > div.date { /* Estilos para las fechas */
            padding: 10px;
            margin: 5px;
            text-align: center;
            border-radius: 5px; /* Bordes redondeados para las celdas */
            font-size: 1rem;
            transition: transform 0.3s, background-color 0.3s; /* Transición suave en hover */
        }
        
        & > div.day {
            font-weight: bold; /* Días de la semana en negrita */
            color: #d2bc8a; /* Color dorado */
            text-transform: uppercase; /* Convertir texto a mayúsculas */
        }
        
        & > div.date.empty {
            visibility: hidden; /* Oculta los días vacíos */
            background-color: transparent; /* Fondo transparente */
            pointer-events: none; /* Desactiva los eventos de clic */
        }
        
        & > div.date {
            background-color: #333; /* Fondo oscuro para las fechas */
            cursor: pointer; /* Cursor de puntero al pasar sobre las fechas */
            
            &:hover {
                transform: scale(1.1); /* Aumenta el tamaño al pasar el cursor */
                background-color: #444; /* Fondo más claro al pasar el cursor */
            }
        }
        
        & > div.today {
            background-color: #7d5228; /* Fondo color especial para el día de hoy */
            color: #fff; /* Texto blanco */
            font-weight: bold; /* Texto en negrita */
            
            &:hover {
                transform: scale(1.1); /* Aumenta el tamaño al pasar el cursor */
                background-color: #7d5228; /* Fondo sin cambio al pasar el cursor */
            }
        }
    }
}


div.modal {
    display: none; /* Oculta el modal por defecto */
    position: fixed; /* Posiciona el modal de forma fija en pantalla */
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Centra el modal horizontal y verticalmente */
    z-index: 1; /* Se asegura de que aparezca por encima del contenido normal */
    background: linear-gradient(to right, #101010, #3E3E3E); /* Fondo degradado oscuro */
    border-radius: 10px; /* Esquinas redondeadas */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.5); /* Sombra para darle profundidad */
    width: 90%; /* Ancho responsivo */
    max-width: 600px; /* Límite máximo de ancho */
    padding: 20px; /* Espaciado interno */
    color: #fff; /* Texto blanco */

    & > div.modal-content {
        display: flex;
        flex-direction: column; /* Acomoda los elementos en columna */
        gap: 15px; /* Espacio entre elementos */
        position: relative;

        & > h2 {
            font-size: 1.5rem; /* Tamaño grande para título */
            font-weight: bold;
            text-align: center;
            margin: 0;
        }

        & > select#event-text {
            padding: 8px;
            border: 1px solid #666; /* Borde gris oscuro */
            border-radius: 5px;
            font-size: 1rem;
            background-color: #fff; /* Fondo blanco */
            color: #2a2a2a; /* Texto gris oscuro */
        }

        & > div.manage-event {
            display: flex; /* Distribuye elementos en fila */

            & > div.routine-exercises {
                width: 80%; /* Ocupa gran parte del espacio horizontal */
                margin-left: 50px;
                max-height: 300px; /* Ajusta a la altura que necesites */
                overflow-y: auto;
                
                & > h4 {
                    margin-top: 0; /* Elimina margen superior del título */
                }
            }

            & > div.time-inputs {
                display: flex;
                flex-direction: column; /* Inputs de tiempo en columna */
            }
        }
        & > div.modal-buttons{
            margin-top:auto;
        }
    }

    /*& > div.modal-buttons {
        display: flex;
        justify-content: space-between; /* Separa los botones a los extremos 

        & > button {
            padding: 10px 15px;
            font-size: 1rem;
            border: none;
            border-radius: 5px;
            cursor: pointer; /* Cambia el cursor al pasar por encima 
        }
    }*/
}


/* Botones de modo */
#routine-mode-switch {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-bottom: 10px;
}

#routine-mode-switch .mode-btn {
    background: #3E3E3E;
    padding: 8px 15px;
    border-radius: 8px;
    border: none;
    color: #fff;
    font-weight: bold;
    cursor: pointer;
    transition: 0.3s;
}

#routine-mode-switch .mode-btn:hover {
    transform: scale(1.05);
}

#routine-form-section {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

#user-routines-container {
    max-height: 400px;
    overflow-y: auto;
    padding-right: 10px;
}


#select-exercises {
  background-color: #3E3E3E;
  color: white;
  margin-top: 16px;
  padding: 10px 20px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 16px;
  transition: background-color 0.3s ease;
}

#select-exercises:hover {
  background-color: #5a5a5a;
}

#routine-form-section input,
#routine-form-section select {
    padding: 8px;
    border: 1px solid #666;
    border-radius: 5px;
    font-size: 1rem;
    background-color: #fff;
    color: #2a2a2a;
}
.muscle-group{
    max-height: 200px;
    overflow-y: auto;
}

#selected-exercises-container{ 
    max-height: 400px;
    overflow-y: auto;
}

#selected-exercises-container .muscle-group h4 {
    cursor: pointer;
    margin: 10px;
}

#selected-exercises-container .muscle-group ol {
    list-style: none;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}

#selected-exercises-container .muscle-group ol li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 5px 10px;
    border-bottom: 1px solid #ddd;
}

#selected-exercises-container .muscle-group ol li button,#delete-exercise {
    background-color: red;
    color: white;
    border: none;
    padding: 5px 10px;
    cursor: pointer;
    border-radius: 5px;
}

#selected-exercises-container .muscle-group ol li button:hover,#delete-exercise:hover {
    background-color: darkred;
}

#save-event {
    background-color: #28a745;
    color: #fff;
}

#save-event:hover {
    background-color: #218838;
}

#save-routine {
    background-color: #28a745;
    color: #fff;
}

#save-routine:hover {
    background-color: #218838;
}

#edit-event {
    background-color: #3E3E3E;
    color: #fff;
}

#edit-event:hover {
    background-color: #5a5a5a;
}

#update-routine {
    background-color: #28a745;
    color: #fff;
}

#update-routine:hover {
    background-color: #218838;
}

#delete-event {
    background-color: #dc3545;
    color: #fff;
}

#delete-event:hover {
    background-color: #c82333;
}

span.close, span.close-routine, span.close-exercise {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 1.5rem;
    cursor: pointer;
}

.exercise-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 10px;
    max-height: 400px;
    overflow-y: auto;
}

.exercise-item {
    display: flex; /* Usa flexbox para alinear horizontalmente los elementos hijos (imagen y texto) */
    align-items: center; /* Centra verticalmente los elementos dentro del contenedor */
    gap: 10px; /* Espacio de 10px entre los elementos hijos */
    padding: 10px; /* Relleno interno de 10px alrededor del contenido */
    border: 2px solid #ccc; /*Borde de 2px con color gris claro */
    border-radius: 10px; /* Esquinas redondeadas de 10px */
    cursor: pointer; /* El cursor cambia a una mano para indicar que es clickeable */
    transition: background-color 0.3s, border-color 0.3s; /* Transiciones suaves para color de fondo y borde */
    
    & > img {
        width: 60px; /* Ancho fijo de 60px para la imagen */
        height: 60px; /* Alto fijo de 60px */
        object-fit: contain; /* Escala la imagen para que encaje sin recortarse ni deformarse */
        border-radius: 5px; /* Bordes levemente redondeados */
    }

    & > p {
        margin: 0; /* Elimina márgenes por defecto del párrafo */
        font-weight: 500; /* Grosor medio del texto */
        flex: 1; /* El párrafo ocupa el espacio restante disponible */
    }
}

.exercise-item.selected {
    border: 2px solid #956534;
    background-color: #a8804e;
}

div.buttons {
    display: flex; /* Usa flexbox para colocar los botones en línea */
    justify-content: space-evenly; /* Distribuye el espacio de manera uniforme entre los botones */
    margin-bottom: 15px; /* Margen inferior de 15px para separar de otros elementos debajo */

    & > button {
        background: linear-gradient(to right, #956534, #d2bc8a, #956534); /* Fondo con un degradado dorado/marrón */
        padding: 10px; /* Relleno interno de 10px */
        border: none; /* Elimina el borde por defecto */
        border-radius: 5px; /* Esquinas redondeadas para el botón */
        color: #fff; /* Texto en color blanco */
        cursor: pointer; /* El cursor se convierte en una mano al pasar sobre el botón */
        transition: 0.3s; /* Transición suave para cualquier cambio visual */
    }

    & > button:hover {
        transform: scale(1.1); /* Al pasar el mouse, el botón se agranda ligeramente */
    }
}


/* Estilo general para las rutinas */
#user-routines-container {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin: 2rem auto;
    width: 100%;
    max-width: 600px;
}

/* Estilo de cada bloque de rutina */
.routine-block {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center; /* Alinea verticalmente el texto y los botones */
    padding: 1rem;
    transition: background-color 0.3s ease;
}

/* Estilo del encabezado de cada rutina */
.routine-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

/* Estilo del nombre de la rutina */
.routine-name {
    font-size: 1.2rem;
    font-weight: bold;
    margin: 0;
}

/* Grupo de botones de edición y eliminación */
.routine-buttons {
    display: flex;
    gap: 10px;
}

/* Estilo de los botones */
button {
    padding: 0.5rem 1rem;
    font-size: 1rem;
    cursor: pointer;
    border: none;
    border-radius: 5px;
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* Estilo del botón de editar */
.edit-button {
    background-color: #3E3E3E;
    color: white;
}

.exercise-entry {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 5px 10px;
    border-bottom: 1px solid #ddd;
}

/* Estilo del botón de eliminar */
.delete-button {
    background-color: #f44336;
    color: white;
}

.delete-button:hover {
    background-color: #e53935;
}

.event-indicator {
    display: inline-block; /* Hace que el indicador sea un bloque en línea */
    width: 8px; /* Ancho de 8px */
    height: 8px; /* Alto de 8px */
    background-color: red; /* Color de fondo rojo */
    border-radius: 50%; /* Hace que el indicador sea redondo */
    position: absolute; /* Posiciona el indicador de forma absoluta dentro del contenedor */
    top: 5px; /* Posición de 5px desde la parte superior */
    right: 5px; /* Posición de 5px desde el lado derecho */
}

/* Estilo para pantallas con un ancho entre 441px y 1300px */
@media screen and (min-width: 441px) and (max-width: 1300px) {
    div.calendar {
        margin: 125px 105px; /* Aplica márgenes de 125px en la parte superior e inferior, y 105px en los lados */
    }
}


@media screen and (max-width: 440px) {
    /* Ajusta el tamaño del calendario */
    div.calendar {
        max-width: -webkit-fill-available; /* Asegura que el calendario ocupe todo el ancho disponible */
        width: 100%; /* Asegura que el calendario tenga un ancho del 100% */
        margin: 100px auto; /* Centra el calendario en la pantalla con márgenes en la parte superior e inferior */
        border-radius: 8px; /* Bordes redondeados */
        font-size: 0.75rem; /* Reduce el tamaño de la fuente */
        overflow: hidden; /* Oculta cualquier contenido que sobresalga */
    }

    /* Ajuste para el encabezado del calendario */
    .calendar-header {
        padding: 6px; /* Espaciado alrededor del encabezado */
        font-size: 0.85rem; /* Reduce el tamaño de la fuente del encabezado */
        text-align: center; /* Centra el texto del encabezado */
    }

    /* Ajuste para los botones de navegación */
    .nav-btn {
        font-size: 0.9rem; /* Reduce el tamaño de la fuente de los botones de navegación */
        padding: 5px; /* Espaciado dentro de los botones */
    }

    /* Ajuste para el cuerpo del calendario */
    .calendar-body {
        display: grid;
        grid-template-columns: repeat(7, 1fr); /* Mantiene 7 columnas uniformes */
        gap: 1px; /* Reduce el espacio entre las celdas */
        padding: 3px; /* Espaciado dentro del cuerpo del calendario */
    }

    /* Ajuste para los días y fechas */
    .day, .date {
        font-size: 0.6rem; /* Reduce el tamaño de la fuente de los días y las fechas */
        padding: 3px; /* Espaciado dentro de las celdas de los días y fechas */
        margin: 1px; /* Espaciado entre las celdas */
        min-width: 18px; /* Establece un tamaño mínimo para las celdas */
        max-width: 100%; /* Asegura que las celdas no sobrepasen el ancho disponible */
        text-align: center; /* Centra el texto dentro de las celdas */
    }

    /* Ajustes para el modal */
    .modal {
        max-width: 90%; /* Limita el ancho máximo del modal al 90% */
        width: 90%; /* Establece el ancho del modal al 90% */
        padding: 10px; /* Añade espaciado dentro del modal */
    }

    /* Ajuste para el contenido del modal */
    .modal-content {
        padding: 8px; /* Espaciado dentro del contenido del modal */
        height: 500px!important; /* Establece el ancho del modal al 90% */

    }
    
    #selected-exercises-container{ 
        max-height: 100px;
        overflow-y: auto;
    }
    
    #user-routines-container{
        max-height: 300px!important;
        overflow-y: auto;
        padding-right: 10px;
    }
    
    div.routine-exercises {
        width: 80%; /* Ocupa gran parte del espacio horizontal */
        margin-left: 50px;
        max-height: 200px; /* Ajusta a la altura que necesites */
        overflow-y: auto;
        
    }
    .exercise-grid {
        grid-template-columns: 1fr; /* Una sola columna en móvil */
        max-height: 200px; /* Ajusta según lo que necesites */
        overflow-y: auto;
    }
    
    .exercise-info input[type="number"] {
    width: 30px !important;
  }

  .exercise-info select {
    width: 60px !important;
  }

  .exercise-info {
    flex-wrap: wrap; /* por si no entra todo en una línea */
    gap: 6px;
  }

  .exercise-info strong {
    width: 100%;
  }
}