.reserva-sala-form {
    padding: 0px;
    /*background: #f5f5f5;*/
    border-radius: 8px;
    font-family: "Gill sans nova", Sans-serif;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.6em;
    color: #000000;
}
#form-reserva {
	margin-top: 40px;
}
.reserva-total {
	display:none;
}
.reserva-total, #sin-disponibilidad {
	margin-top:40px;
    background-color: #F0E754;
    font-family: "Bebas Neue", Sans-serif;
    font-size: 20px;
    font-weight: 400;
    text-transform: uppercase;
    line-height: 1em;
    letter-spacing: 1.5px;
    color: #000000;
    border-style: none;
    border-radius: 0px 0px 0px 0px;
    padding: 20px;
}
#reserva-total {
	margin-top:20px;
}
.linea-precio {
	margin:5px 0px 5px 20px;
}
.linea-precio.total{
    font-size: 24px;
	margin-top:10px;
}
.titulo-tabla-reservas {
    font-family: "Bebas Neue", Sans-serif;
    font-size: 24px;
    font-weight: 200;
    line-height: 1em;
    letter-spacing: 0px;
    color: #000000;
	margin-top:10px;
}
.reserva-sala-form label {
    display: block;
    margin-top: 20px;
    margin-bottom: 5px;
    font-weight: bold;
}
.reserva-sala-form label.thin {
    display: block;
    margin-top: 20px;
    margin-bottom: 5px;
    font-weight: normal;
}

.reserva-sala-form button
{	
	margin-top:40px;
    width: 100%;
    padding: 8px;
	border: solid 0px #FFFFFF;
}
.reserva-sala-form input:not([type="checkbox"]):not([type="radio"]),
.reserva-sala-form select {
    width: 100%;
    margin-top: 0px;
    padding: 8px;
}
/* Franja horaria diaria */
.franja-tiempo {
    position: relative;
    width: 100%;
    height: 20px;
    background: #eaeaea;
    margin-bottom: 50px; /* deja sitio a los textos */
    border-radius: 0px;
    overflow: visible;
}

/* Tramos ocupados */
.franja-ocupada {
    position: absolute;
    top: 0;
    height: 100%;
    background: #F0E754;
    z-index: 2;
}

/* Marcas horarias */
.marca-hora {
    position: absolute;
    top: 100%;
    transform: translateX(-50%);
    text-align: center;
    z-index: 3;
}

.marca-hora::before {
    content: '';
    position: absolute;
    top: -20px;
    left: 50%;
    width: 1px;
    height: 20px;
    background: #999;
}

.marca-hora span {
    font-size: 10px;
    color: #555;
    white-space: nowrap;
}


.tabla-reservas {
    border: 1px solid #ddd;
    width: 100%;
    border-collapse: collapse;
    margin-top: 10px;
    font-family: "Gill sans nova", Sans-serif;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.6em;
    color: #000000;
	margin-block-end: 30px;
}

.tabla-reservas td {
    border: 0px solid #ddd;
    padding: 8px;
	background-color: #FFFFFF !important;
    text-align: center;
}

.tabla-reservas th {
    border: 0px solid #ddd;
    padding: 8px;
    text-align: center;
    background: #f3f3f3;
    font-weight: 600;
}

/* ===============================
   DATEPICKER MODERNO
================================ */

.ui-datepicker {
	margin-top:10px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: 12px;
    /*box-shadow: 0 10px 25px rgba(0,0,0,0.08);*/
    font-family: inherit;
    width: auto;
}

/* Header */
.ui-datepicker-header {
    background: none;
    border: none;
    padding-bottom: 8px;
    margin-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.ui-datepicker td, .ui-datepicker th {
    background-color: #FFFFFF !important;
	text-align:-webkit-center;
}
.ui-datepicker-title {
    font-weight: 600;
    font-size: 15px;
    color: #111827;
}

/* Flechas */
.ui-datepicker-prev,
.ui-datepicker-next {
    cursor: pointer;
    border-radius: 8px;
    padding: 4px;
}

.ui-datepicker-prev:hover,
.ui-datepicker-next:hover {
    background: #f3f4f6;
}

/* Tabla */
.ui-datepicker-calendar {
    width: 100%;
    border-collapse: collapse;
}

/* Días de la semana */
.ui-datepicker-calendar th {
    font-size: 12px;
    font-weight: 500;
    color: #6b7280;
    padding-bottom: 6px;
}

/* Días */
.ui-datepicker-calendar td .ui-state-default{
	border: 0px solid #c5c5c5;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    width: 36px;
	margin-bottom:5px;
}

.ui-datepicker-calendar td a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    width: 36px;
    border-radius: 10px;
    text-decoration: none;
    font-size: 14px;
    color: #111827;
	margin-bottom:5px;
    transition: background 0.2s ease, color 0.2s ease;
}

/* Hover */
.ui-datepicker-calendar td a:hover {
    background: #e5e7eb;
}

/* Hoy */
.ui-datepicker-today a {
    border: 1px solid #2563eb;
    color: #2563eb;
}

/* Día seleccionado */
.ui-datepicker-current-day a {
    border: 0px solid #dad55e;
    background: #F0E754 !important;
    color: #000000 !important;
	font-weight: 700 !important;
}

/* Días deshabilitados */
.ui-datepicker-unselectable span {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    width: 36px;
    border-radius: 10px;
    color: #9ca3af;
}
/* Día festivo / cerrado */
.ui-datepicker td.festivo span {
    background: #cc0000;
    color: #FFFFFF;
    border-radius: 8px;
    font-weight: 600;
}

/* Cursor bloqueado */
.ui-datepicker td.festivo {
    cursor: not-allowed;
}
.ui-datepicker td.festivo span {
    pointer-events: auto; 
    cursor: not-allowed;
}
/* Footer (si usas botón hoy/cerrar) */
.ui-datepicker-buttonpane {
    margin-top: 10px;
    border-top: 1px solid #e5e7eb;
    padding-top: 8px;
}

.ui-datepicker-buttonpane button {
    background: #f3f4f6;
    border: none;
    border-radius: 8px;
    padding: 6px 10px;
    cursor: pointer;
}
.servicios-opcionales label {
	font-weight: normal;
	margin-bottom:20px;
}
.servicios-opcionales label.title {
	font-weight: 700;
	margin-bottom:20px;
}
.servicios-opcionales input[type="checkbox"] {
  transform:scale(2);
  margin:0px 15px !important;
}
.servicios-opcionales input[type="checkbox"]:checked {
  color: #000000;
  accent-color: #F0E754;
}
.info-dia-reserva, .horas-bloqueadas {
    width: 100%;
    font-family: "Gill sans nova", Sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.3em;
    color: #000000;
}
 .horas-bloqueadas { 
	margin-bottom:20px;
 }
 
.reserva-sala-ok {
	background-color: #F0E754;
	padding: 40px;
}
.reserva-sala-resumen {
    font-family: "Gill sans nova", Sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.3em;
    color: #000000;
}
.reserva-sala-resumen .linea-precio-total {
	margin: 50px 0 0 0;
    font-family: "Bebas Neue", Sans-serif;
    font-size: 24px;
    font-weight: 400;
    text-transform: uppercase;
    line-height: 1em;
    letter-spacing: 1.5px;
    color: #000000;
}
.reserva-sala-resumen hr {
	margin: 30px 0;
    color: #000000;
    background-color: #000000;
    height: 0px !important;
    border: none;
}
.reserva-sala-ok h3 { 
	font-family: "Bebas Neue", Sans-serif;
    font-size: 30px;
    font-weight: 200;
    line-height: 1em;
    letter-spacing: 0px;
    color: #000000;
	margin-bottom: 10px; 
}
.reserva-sala-ok .button { display:inline-block; padding:10px 14px; background-color:#000000;color:#FFFFFF;margin-top:20px;
    font-family: "Bebas Neue", Sans-serif;
    font-size: 24px;
    font-weight: 400;
    text-transform: uppercase;}
