/* --- Agenda / Allergens (from web.css) ---------------------------------- */

/* Day strip — sticky below the app header (54px = fixed nav bar height) */
.agenda-strip-sticky {
  position: sticky;
  top: 54px;
  z-index: 90;
  background: var(--color-bg-card);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Offset the reservation list so it clears the sticky strip */
.reservation_list--strip-offset {
  margin-top: 41px;
}

/* Period headers (morning/afternoon/evening) — compact in agenda context */
.reservation_list .time-period-header.content-section-header {
  padding: 12px 0 8px 0 !important;
}
.reservation_list .time-period-header .content-title {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-muted);
  letter-spacing: 1.5px;
}
.agenda-modal__close-btn:hover {
  color: var(--color-text-subtle);
  background-color: transparent; border: 1px solid var(--color-border); transition: var(--transition-fast)
}
#date_buttons::-webkit-scrollbar { display: none }
#btn_close_allergen_filter { height: 40px !important }
.allergen-card {
  display: flex !important; flex-direction: column; align-items: center; justify-content: center; min-width: 90px; padding-bottom: 6px;
  cursor: pointer;
  background-color: var(--color-bg-card); border: 1px solid var(--color-bg-subtle) !important;
  border-radius: var(--radius-sm) !important; box-shadow: 0 2px 4px rgba(0,0,0,0.02); transition: transform 0.2s, box-shadow 0.2s
}
.allergen-card:hover { border-color: var(--color-primary) !important; box-shadow: 0 6px 12px rgba(0,0,0,0.08) !important; transform: translateY(-2px) }
.allergen-card.bg-template { color: var(--color-text-inverse) !important; background-color: var(--color-primary) !important; border-color: var(--color-primary) !important }
.allergen-card.bg-template .allergen-card__label { color: var(--color-text-inverse) !important }

@media (max-width: 767px) {
  .selected-agenda-day { margin-top: 62px !important; font-size: 0.8em; text-align: center; border-bottom: 1px solid #e1e1e157; opacity: 0.7 }
  div#booking-allergens-card { margin-bottom: 3px; font-size: var(--text-xs) }
}

/* AGENDA MODAL - BEM STRUCTURE */
.ht-agenda-modal__travel-badge {
display: none;
  padding: 0.25em 0.4em;
  font-size: 75%;
  font-weight: var(--font-weight-bold);
  line-height: 1;
  vertical-align: baseline;
  /* Captured from badge badge-dark shadow-sm */
  color: var(--color-text-inverse);
  text-align: center;
  white-space: nowrap;
  background: rgba(0, 0, 0, 0.5);
  background-color: var(--color-text-heading);
  border-radius: 0.25rem;
  box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075) !important;
  backdrop-filter: blur(4px);
}

.ht-agenda-modal__hero {
  position: relative;
  width: 100%;
  height: 35vh;
  min-height: 250px;
  overflow: hidden;
  background-color: var(--color-bg-subtle, #f8f9fa);
}

/* Blurred ambient backdrop — same src as hero-img, browser uses cached copy */
.ht-agenda-modal__hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: blur(15px) brightness(0.45);
  transform: scale(1.1); /* prevents blur from leaving white edges */
}

/* Sharp foreground poster */
.ht-agenda-modal__hero-img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.ht-agenda-modal__hero-gradient {
position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 60%;
  pointer-events: none;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, transparent 100%);
}

.ht-agenda-modal__hero-content {
position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  padding: 20px;
}

.ht-agenda-modal__hero-title {
  margin: 0 !important;
  font-weight: var(--font-weight-bold) !important;
  /* Captured from text-white font-weight-bold m-0 */
  color: var(--color-text-inverse) !important;
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.ht-agenda-modal__actions {
display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px !important;
  padding: 20px 30px !important;
  background-color: var(--color-bg-card) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* Custom Action Buttons */
.ht-agenda-modal__action-btn {
display: flex !important;
  flex: 1 !important;
  align-items: center;
  justify-content: center;
  /* Grow to fill space equally */
  min-width: 0;
  /* Allow shrinking if needed */
  padding: 10px 16px !important;
  font-size: 1rem !important;
  font-weight: var(--font-weight-semibold) !important;
  /* Slightly lighter weight */
  text-transform: none !important;
  /* Standard font size */
  text-decoration: none !important;
  border: 2px solid transparent !important;
  /* Reduced padding */
  border-radius: var(--radius-pill) !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08) !important;
  transition: var(--transition-fast);
  /* Softer shadow */
}

.ht-agenda-modal__action-btn:hover {
  text-decoration: none !important;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.12) !important;
transform: translateY(-1px);
}

.ht-agenda-modal__action-btn i {
margin-right: 8px;
  font-size: 18px;
  /* Standard icon size */
}

/* Specific Variants using CSS Variables */
.ht-agenda-modal__action-btn--info {
  color: var(--color-text-inverse) !important;
background-color: var(--color-info, #17a2b8) !important;
  border-color: var(--color-info, #17a2b8) !important;
}

.ht-agenda-modal__action-btn--book {
  color: var(--color-success, #28a745) !important;
background-color: var(--color-bg-card) !important;
  border-color: var(--color-success, #28a745) !important;
}

.ht-agenda-modal__action-btn--book:hover {
  color: var(--color-text-inverse) !important;
background-color: var(--color-success, #28a745) !important;
}

.ht-agenda-modal__action-btn--past {
  color: var(--color-danger, #dc3545) !important;
  cursor: not-allowed;
background-color: var(--color-bg-card) !important;
  border-color: var(--color-danger, #dc3545) !important;
  opacity: 0.7;
}


.ht-agenda-modal__actions:empty {
display: none !important;
  padding: 0 !important;
  border: none !important;
}

.ht-agenda-modal__desc {
  margin: 0 !important;
font-size: 1rem;
  line-height: 1.6;
  color: var(--color-text-body);
  /* Captured from text-body m-0 */
  color: var(--color-text-heading) !important;
}

.ht-agenda-modal__map-container {
  /* Captured from w-100 rounded-lg shadow-sm */
  width: 100% !important;
  height: 100%;
  /* Fill parent */
  min-height: 400px;
overflow: hidden;
  background-color: var(--color-border-light);
  /* Ensure visibility */
  border-radius: 0 !important;
  /* Remove radius for immersive feel or keep it? user said immersive. let's remove radius or match modal */
}

/* Floating Action Button (FAB) */
.ht-agenda-modal__close-btn {
  top: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
width: 50px;
  height: 50px;
  margin-left: auto;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s;
}

.ht-agenda-modal__back-btn {
  top: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
width: 50px;
  height: 50px;
  margin-right: 10px;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s;
  /* Space between back btn and other elements if needed */
}

.ht-agenda-modal__close-btn:hover,
.ht-agenda-modal__back-btn:hover {
transform: scale(1.1);
}

.ht-agenda-modal__overlay-header {
position: absolute;
  top: 15px;
  right: 15px;
  left: 15px;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 15px;
  pointer-events: none;
  background: transparent;
  border: none;
  /* Let clicks pass through except for buttons */
}

.ht-agenda-modal__overlay-header>* {
pointer-events: auto;
  /* Re-enable clicks for children */
}

.ht-agenda-modal__floating-actions {
position: absolute;
  right: 15px;
  bottom: 15px;
  z-index: 20;
  /* High z-index to sit on top */
  display: flex;
  gap: 10px;
}

.ht-agenda-modal__fab {
  display: flex !important;
  align-items: center;
  justify-content: center;
width: 42px;
  height: 42px;
  padding: 0;
  color: var(--color-text-heading);
  text-decoration: none !important;
  cursor: pointer;
  background: var(--color-bg-card);
  border: none;
  border-radius: 50% !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ht-agenda-modal__fab:hover {
  color: var(--color-primary);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2) !important;
transform: translateY(-2px);
}

/* Info Grid Section */
.ht-agenda-modal__content {
padding: 20px !important;
}

.ht-agenda-modal__info-grid {
display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 24px;
}
/* =========================================
   ACCIONES DE AGENDA (Botones del Modal)
   ========================================= */

/* 1. Contenedor de botones */
#modal-agenda-actions.ht-agenda-modal__actions {
  display: flex;
  gap: 12px !important;
  /* Separación perfecta entre botones */
  width: 100% !important;
  /* Espacio para respirar del contenido superior */
  padding: 15px 15px !important;
  margin-top: 0px !important;
}

/* 2. Estructura Base para ambos botones */
#modal-agenda-actions a {
  display: flex !important;
  flex: 1;
  align-items: center !important;
  justify-content: center !important;
  /* Forma de píldora (Premium) */
  padding: 14px 16px !important;
  font-family: var(--font-family-body) !important;
  font-size: 1rem !important;
  font-weight: var(--font-weight-bold) !important;
  text-decoration: none !important;
  /* Ambos botones ocuparán exactamente el 50% del ancho */
  border: none !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
  transition: var(--transition-fast) !important;
}
.ht-agenda-modal__info-item {
display: flex;
  flex-direction: column;
  align-items: center;
  /* White card */
  padding: 16px;
  /* Center content in card */
  text-align: center;
  background-color: var(--color-bg-card);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  /* Soft shadow */
  transition: transform 0.2s ease;
}

.ht-agenda-modal__info-item:hover {
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
transform: translateY(-2px);
}

.ht-agenda-modal__info-header {
display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  /* Center header */
  margin-bottom: 8px;
  /* Muted text */
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-subtle) !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ht-agenda-modal__info-header i {
  margin-right: 8px;
font-size: 18px;
  color: var(--color-primary);
  /* Default icon color */
}

.ht-agenda-modal__info-header i.icon-category {
color: var(--color-info) !important;
  /* Info color */
}

.ht-agenda-modal__info-value {
  padding-left: 2px;
  /* Dark text */
  margin: 0;
font-size: 1.1rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-heading) !important;
}

/* Description Section */
.ht-agenda-modal__section {
  padding: 24px;
margin-top: 24px;
  text-align: left;
  background-color: var(--color-bg-card);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.ht-agenda-modal__section-title {
  display: block;
  padding-bottom: 8px;
  margin-bottom: 12px;
font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-subtle) !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--color-border-light);
}
/* =========================================
   MODAL DE RESERVA (Agenda Modal)
   ========================================= */

/* 2. Botón Cerrar (X) estilo nativo */
#booking_agenda_modal .ht-modal-close-btn {
  position: absolute !important;
  top: 20px !important;
  right: 20px !important;
  z-index: 10 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  color: var(--color-text-subtle) !important;
  background-color: var(--color-bg-subtle) !important;
  /* Gris suave */
  border: none !important;
  border-radius: 50% !important;
  transition: var(--transition-fast) !important;
}





#booking_agenda_modal .ht-modal-header-title {
  /* Slate Dark */
  margin: 0 !important;
  font-family: var(--font-family-body) !important;
  font-size: 1.4rem !important;
  font-weight: 800 !important;
  color: var(--color-text-heading) !important;
}

/* 4. Títulos de Sección (Limpiamos las líneas feas laterales) */
#booking_agenda_modal .content-title {
  font-family: var(--font-family-body) !important;
  font-size: 0.85rem !important;
  font-weight: 800 !important;
  color: var(--color-text-muted) !important;
  text-align: center !important;
  /* Slate claro */
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  background: transparent !important;

  border: none !important;
}



/* 5. Etiquetas (Adultos, Niños) */
#booking_agenda_modal .form-label {
  margin: 0 !important;
  font-family: var(--font-family-body) !important;
  font-size: 1.05rem !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--color-text-heading) !important;
}



/* 7. Textarea de Observaciones */
#booking_agenda_modal textarea {
  padding: 16px !important;
  font-family: var(--font-family-body) !important;
  font-size: 0.95rem !important;
  color: var(--color-text-heading) !important;
  resize: none !important;
  background-color: var(--color-bg-body) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.02) !important;
  transition: var(--transition-fast) !important;
}

#booking_agenda_modal textarea:focus {
  outline: none !important;
  background-color: var(--color-text-inverse) !important;
  border-color: var(--color-success) !important;
  box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.15) !important;
}

/* 8. Botones del Footer (Soluciona el problema de superposición) */
#booking_agenda_modal .ht-modal-footer {
  display: flex;
  flex-direction: column;
  /* Forzamos a que se apilen si hay varios */
  gap: 12px;
  padding: 24px 0 0 0 !important;
  border: none !important;
}

#booking_agenda_modal .ht-modal-footer .btn {
  /* display: flex !important; */
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  padding: 16px 24px !important;
  margin: 0 !important;
  font-size: 1.05rem !important;
  font-weight: var(--font-weight-bold) !important;
  border-radius: var(--radius-pill) !important;
  transition: var(--transition-fast) !important;
}

/* Botón Siguiente (Negro Premium) */
#booking_agenda_modal #save_booking_agenda {
  color: var(--color-text-inverse) !important;
  background-color: var(--color-text-heading) !important;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.15) !important;
}

#booking_agenda_modal #save_booking_agenda:active {
  transform: scale(0.96) !important;
}
  
        /* Botón Loading */
        #booking_agenda_modal #loading_button {
          /* Esmeralda para estado cargando */
          color: var(--color-text-inverse) !important;
          cursor: not-allowed !important;
          background-color: var(--color-success) !important;
          box-shadow: none !important;
        }
    
        /* 9. Pantalla de Éxito (Si se muestra dentro del modal) */
        #booking_agenda_modal #booking_sucess_container {
          display: flex !important;
          align-items: center !important;
          justify-content: center !important;
          width: 80px !important;
          height: 80px !important;
          margin: 0 auto 24px auto !important;
          background-color: var(--color-success-soft) !important;
          border-radius: 50% !important;
          box-shadow: 0 0 0 10px rgba(16, 185, 129, 0.1) !important;
        }
    
        #booking_agenda_modal #booking_success_icon {
          padding: 0 !important;
          margin: 0 !important;
          font-size: 40px !important;
          color: var(--color-success) !important;
        }
    
        /* =========================================
           MODAL ERROR DE CAPACIDAD (Childrens Full)
           ========================================= */
    
        /* 1. Tarjeta Principal */
        #dialog-childrensfull .modal-content {
          padding: 30px 24px 24px 24px !important;
          background-color: var(--color-text-inverse) !important;
          border: none !important;
          border-radius: var(--radius-lg) !important;
          box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
        }
    
        /* 2. Icono Superior (Alerta Premium animada) */
        #dialog-childrensfull .modal-icon {
          display: flex;
          align-items: center;
          justify-content: center;
          /* Fondo rojo pastel */
          width: 72px;
          height: 72px;
          margin: 0 auto 20px auto !important;
          background-color: var(--color-danger-soft) !important;
          border-radius: 50%;
          animation: htPulseAlert 2s infinite;
          /* Usa la misma animación de latido */
        }
    
        #dialog-childrensfull .modal-icon i {
          margin: 0 !important;
          /* Rojo vibrante */
          font-size: 36px !important;
          color: var(--color-danger) !important;
        }
    
        /* 3. Cabecera y Título */
        #dialog-childrensfull .modal-header {
          justify-content: center;
          padding: 0 0 12px 0 !important;
          border-bottom: none !important;
        }
    
        #dialog-childrensfull .modal-title {
          width: 100%;
          margin: 0 !important;
          font-family: var(--font-family-body) !important;
          font-size: 1.35rem !important;
          font-weight: 800 !important;
          color: var(--color-text-heading) !important;
          /* Negro Slate oscuro */
          text-align: center;
        }
    
        /* 4. Cuerpo del Mensaje */
        #dialog-childrensfull .modal-body {
          padding: 0 10px 24px 10px !important;
          font-family: var(--font-family-body) !important;
          font-size: 0.95rem !important;
          line-height: 1.6 !important;
          color: var(--color-text-body) !important;
          /* Gris intermedio para facilitar lectura */
          text-align: center !important;
        }
    
        /* 5. Footer y Botón principal */
        #dialog-childrensfull .modal-footer {
          padding: 0 !important;
          border: none !important;
        }
    
        #dialog-childrensfull .btn-inline {
          display: flex;
          width: 100%;
        }
    
        /* Transformamos el '.btn-dark' estándar en un botón táctil de ancho completo */
        #dialog-childrensfull .btn-dark {
          display: flex;
          align-items: center;
          justify-content: center;
          width: 100% !important;
          padding: 14px 24px !important;
          margin: 0 !important;
          font-size: 1rem !important;
          font-weight: var(--font-weight-bold) !important;
          /* Negro Premium */
          color: var(--color-text-inverse) !important;
          text-decoration: none !important;
          background-color: var(--color-text-heading) !important;
          border: none !important;
          border-radius: var(--radius-pill) !important;
          box-shadow: 0 10px 20px rgba(15, 23, 42, 0.15) !important;
          transition: transform 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
          /* Por si el tag <a> mete subrayado */
        }
    
        #dialog-childrensfull .btn-dark:active {
          transform: scale(0.96) !important;
        }
    
        div#confirm_message_row {
          padding: 20px;
        }
    
        /* =========================================
           MODAL CONFLICTO DE RESERVA (Not Allowed)
           ========================================= */
    
        /* 1. Tarjeta Principal */
        #booking_notallowed_modal .modal-content {
          padding: 30px 24px 24px 24px !important;
          background-color: var(--color-text-inverse) !important;
          border: none !important;
          border-radius: var(--radius-lg) !important;
          box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
        }
    
        /* Ocultamos el header vacío */
        #booking_notallowed_modal .modal-header {
          display: none !important;
        }
    
        /* 2. Cuerpo y Fake Icon (Inyectado por CSS) */
        #booking_notallowed_info {
          display: flex;
          flex-direction: column;
          align-items: center;
          padding: 0 10px 20px 10px !important;
        }
    
        /* Inyectamos un círculo naranja suave con exclamación (Aviso) */
        #booking_notallowed_info::before {
          display: flex;
          align-items: center;
          justify-content: center;
          /* Fondo naranja muy pálido */
          width: 72px;
          height: 72px;
          margin-bottom: 20px;
          font-family: var(--font-family-body);
          font-size: var(--text-2xl);
          font-weight: 800;
          color: var(--color-warning);
          content: "!";
          /* Naranja vibrante (Warning) */
          background-color: var(--color-warning-soft);
          border-radius: 50%;
          box-shadow: 0 0 0 8px rgba(245, 158, 11, 0.05);
          /* Halo sutil */
        }
    
        /* 3. Tipografía del Mensaje */
        #booking_notallowed_info h4 {
          /* Negro Slate */
          margin-bottom: 12px !important;
          font-family: var(--font-family-body) !important;
          font-size: 1.35rem !important;
          font-weight: 800 !important;
          line-height: 1.3 !important;
          color: var(--color-text-heading) !important;
        }
    
        #booking_notallowed_info h4 strong {
          color: var(--color-success) !important;
          /* Resalta el nombre del cliente en verde o puedes dejarlo slate */
        }
    
        #booking_notallowed_info p {
          /* Gris Pizarra */
          margin-bottom: 20px !important;
          font-family: var(--font-family-body) !important;
          font-size: 0.95rem !important;
          line-height: 1.6 !important;
          color: var(--color-text-body) !important;
        }
    
        #booking_notallowed_info p strong {
          font-weight: var(--font-weight-bold) !important;
          color: var(--color-text-heading) !important;
        }
    
        #booking_notallowed_info h6 {
          font-family: var(--font-family-body) !important;
          font-size: 0.9rem !important;
          font-weight: 800 !important;
          color: var(--color-light-text) !important;
          text-transform: uppercase !important;
          letter-spacing: 0.5px !important;
        }
    
        /* 4. Footer y Botones (Apilados) */
        #booking_notallowed_buttons {
          display: flex;
          flex-direction: column;
          /* Apilamos los botones siempre */
          gap: 12px;
          padding: 0 !important;
          border: none !important;
        }
    
        /* Estructura base de ambos botones (permite textos largos) */
        #booking_notallowed_buttons .btn {
          width: 100% !important;
          height: auto !important;
          /* Un poco menos redondo porque el texto es de varias líneas */
          padding: 16px 20px !important;
          margin: 0 !important;
          font-size: 0.95rem !important;
          font-weight: var(--font-weight-bold) !important;
          /* Permite que el texto baje de línea si no cabe */
          line-height: 1.4 !important;
          white-space: normal !important;
          border: none !important;
          border-radius: var(--radius-md) !important;
          box-shadow: none !important;
          transition: var(--transition-fast) !important;
        }
    
        #booking_notallowed_buttons .btn:active {
          transform: scale(0.96) !important;
        }
    
        /* Botón: Volver y seleccionar otra fecha (Acción Segura Principal) */
        #booking_notallowed_buttons .btn-success {
          order: 1;
          /* Negro Premium */
          color: var(--color-text-inverse) !important;
          background-color: var(--color-text-heading) !important;
          box-shadow: 0 10px 20px rgba(15, 23, 42, 0.15) !important;
          /* Lo ponemos arriba porque es la acción recomendada/segura */
        }
    
        /* Botón: Cancelar la anterior (Acción Destructiva / Peligro) */
        #booking_notallowed_buttons .btn-danger {
          /* Texto rojo vibrante */
          order: 2;
          /* Fondo rojo muy pálido */
          color: var(--color-danger) !important;
          background-color: var(--color-danger-soft) !important;
          /* Lo ponemos debajo */
        }
    
        #booking_notallowed_buttons .btn-danger:active {
          background-color: var(--color-danger-soft) !important;
        }
/* Agenda List Card (BEM) */
.ht-agenda-card {
display: flex;
  width: auto;
  padding: 16px;
  margin: 0 15px 15px 15px;
  background-color: var(--color-bg-card);
  border: 1px solid rgba(0, 0, 0, 0.03);
  border-radius: var(--radius-sm);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  /* Side margins */
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ht-agenda-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
transform: translateY(-2px);
}

.ht-agenda-card__image {
width: 80px;
  min-width: 80px;
  height: 80px;
  margin: auto 10px auto 0;
  margin-right: 16px;
  background-color: var(--color-border-light);
  background-position: center;
  background-size: cover;
  border-radius: var(--radius-md);
  /* Placeholder bg */
}

.ht-agenda-card__body {
  display: flex;
flex-grow: 1;
  flex-direction: column;
  justify-content: space-between;
  min-width: 0;
  /* Enable text truncation in flex children */
}

.ht-agenda-card__header {
display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1;
}

.ht-agenda-card__title {
margin: 0;
  /* text-dark */
  font-size: 1rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
  color: var(--color-primary);
}

.ht-agenda-card__meta {
  /* text-muted */
  display: flex;
  align-items: center;
  margin-bottom: auto;
font-size: 0.85rem;
  color: var(--color-text-subtle);
  /* Push footer down */
}

.ht-agenda-card__footer {
display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
}


/* Agenda Time Marker (BEM) */
.ht-agenda-time-marker {
position: relative;
  z-index: 5;
  width: 100%;
  height: 2px;
  margin: 0;
}

.ht-agenda-time-marker__line {
margin: 0;
  border: none;
  border-top: 2px solid var(--color-primary);
  opacity: 0.7;
}

.ht-agenda-time-marker__label {
position: absolute;
  top: 50%;
  right: 0;
  z-index: 10;
  padding: 0 8px;
  font-size: 0.85rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.3;
  color: var(--color-primary);
  background-color: var(--color-bg-card);
  border-radius: 10px 0 0 10px;
  transform: translateY(-50%);
}

/* =========================================
 SELECTOR DE CANTIDAD (TICKET STYLE)=========================================*/

/* Contenedor Principal (Píldora) */
.input-group.cantidad {
display: flex !important;
  align-items: center;
  width: 120px !important;
  max-width: 140px;
  height: 48px;
  padding: 4px !important;
  overflow: hidden;
  background-color: var(--color-bg-subtle) !important;
  border: 1px solid var(--color-border) !important;
  /* Gris muy suave */
  border-radius: var(--radius-pill) !important;
}

/* El Input Central */
.input-group.cantidad .form-control {
  height: auto !important;
  padding: 0 !important;
  font-family: var(--font-family-body) !important;
  font-size: 1.1rem !important;
  font-weight: 800 !important;
  color: var(--color-text-heading) !important;
  pointer-events: none;
background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  /* Evita que el teclado móvil salte innecesariamente */
}

/* Botones (-) y (+) */

/* Iconos de Material Icons */
.input-group.cantidad .material-icons {
font-size: 18px !important;
  font-weight: bold;
}

/* Eliminamos los bordes y fondos de los grupos de Bootstrap */
.input-group-prepend,
.input-group-append {
margin: 0 !important;
}
/*******************************
* AGENDA
*******************************/

.card-img-box {
  width: 100%;
  height: 193px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

a.texto-dia {
  opacity: 1 !important;
}

#adults_row .input-group.cantidad {
  float: right !important;
}

#childrens_row .input-group.cantidad {
  float: right !important;
}

/* AGENDA MODAL - BEM STRUCTURE */
.agenda-modal__travel-badge {
  display: none;
  padding: 0.25em 0.4em;
  font-size: 75%;
  font-weight: var(--font-weight-bold);
  line-height: 1;
  vertical-align: baseline;
  /* Captured from badge badge-dark shadow-sm */
  color: var(--color-text-inverse);
  text-align: center;
  white-space: nowrap;
  background: rgba(0, 0, 0, 0.5);
  background-color: var(--color-text-heading);
  border-radius: 0.25rem;
  box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075) !important;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}

.agenda-modal__hero {
  position: relative;
  width: 100%;
  height: 35vh;
  /* Adjustable max-height as requested (approx 50vh or less) */
  min-height: 250px;
  overflow: hidden;
  background-color: var(--color-bg-subtle, #f8f9fa);
  /* Blur effect for the background image set via JS */
}

.agenda-modal__hero::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  content: '';
  /* Darken the background slightly so text pops and image stands out */
  background: rgba(0, 0, 0, 0.6);
  -webkit-backdrop-filter: blur(15px);
  backdrop-filter: blur(15px);
}

.agenda-modal__hero img {
  position: relative;
  z-index: 1;
  /* Ensure full image is visible */
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain !important;
  object-fit: contain !important;
  /* Above the blur layer */
}

.agenda-modal__hero-gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 60%;
  pointer-events: none;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, transparent 100%);
}

.agenda-modal__hero-content {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  padding: 20px;
}

.agenda-modal__hero-title {
  margin: 0 !important;
  font-weight: var(--font-weight-bold) !important;
  /* Captured from text-white font-weight-bold m-0 */
  color: var(--color-text-inverse) !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.agenda-modal__actions {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px !important;
  padding: 20px 30px !important;
  background-color: var(--color-bg-card) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* Custom Action Buttons */
.agenda-modal__action-btn {
  display: flex !important;
  flex: 1 !important;
  align-items: center;
  justify-content: center;
  /* Grow to fill space equally */
  min-width: 0;
  /* Allow shrinking if needed */
  padding: 10px 16px !important;
  font-size: 1rem !important;
  font-weight: var(--font-weight-semibold) !important;
  /* Slightly lighter weight */
  text-transform: none !important;
  /* Standard font size */
  text-decoration: none !important;
  border: 2px solid transparent !important;
  /* Reduced padding */
  border-radius: var(--radius-pill) !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08) !important;
  transition: var(--transition-fast);
  /* Softer shadow */
}

.agenda-modal__action-btn:hover {
  text-decoration: none !important;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.12) !important;
  transform: translateY(-1px);
}

.agenda-modal__action-btn i {
  margin-right: 8px;
  font-size: 18px;
  /* Standard icon size */
}

/* Specific Variants using CSS Variables */
.agenda-modal__action-btn--info {
  color: var(--color-text-inverse) !important;
  background-color: var(--color-info, #17a2b8) !important;
  border-color: var(--color-info, #17a2b8) !important;
}

.agenda-modal__action-btn--book {
  color: var(--color-success, #28a745) !important;
  background-color: var(--color-bg-card) !important;
  border-color: var(--color-success, #28a745) !important;
}

.agenda-modal__action-btn--book:hover {
  color: var(--color-text-inverse) !important;
  background-color: var(--color-success, #28a745) !important;
}

.agenda-modal__action-btn--past {
  color: var(--color-danger, #dc3545) !important;
  cursor: not-allowed;
  background-color: var(--color-bg-card) !important;
  border-color: var(--color-danger, #dc3545) !important;
  opacity: 0.7;
}

.agenda-modal__actions:empty {
  display: none !important;
  padding: 0 !important;
  border: none !important;
}

.agenda-modal__desc {
  margin: 0 !important;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-text-body);
  /* Captured from text-body m-0 */
  color: var(--color-text-heading) !important;
}

.agenda-modal__map-container {
  /* Captured from w-100 rounded-lg shadow-sm */
  width: 100% !important;
  height: 100%;
  /* Fill parent */
  min-height: 400px;
  overflow: hidden;
  background-color: var(--color-border-light);
  /* Ensure visibility */
  border-radius: 0 !important;
  /* Remove radius for immersive feel or keep it? user said immersive. let's remove radius or match modal */
}

/* When map is active, the parent div needs to be full height */
#modal-agenda-map {
  /* Remove padding for full bleed */
  display: flex;
  flex-direction: column;
  height: 100vh;
  /* Or ample height */
  padding: 0 !important;
}

/* Floating Action Button (FAB) */
.agenda-modal__close-btn {
  top: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  margin-left: auto;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s;
}

.agenda-modal__back-btn {
  top: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  margin-right: 10px;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s;
  /* Space between back btn and other elements if needed */
}

.agenda-modal__close-btn:hover,
.agenda-modal__back-btn:hover {
  transform: scale(1.1);
}

.agenda-modal__overlay-header {
  position: absolute;
  top: 15px;
  right: 15px;
  left: 15px;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 15px;
  pointer-events: none;
  background: transparent;
  border: none;
  /* Let clicks pass through except for buttons */
}

.agenda-modal__overlay-header>* {
  pointer-events: auto;
  /* Re-enable clicks for children */
}

.agenda-modal__floating-actions {
  position: absolute;
  right: 15px;
  bottom: 15px;
  z-index: 20;
  /* High z-index to sit on top */
  display: flex;
  gap: 10px;
}

.agenda-modal__fab {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  padding: 0;
  color: var(--color-text-heading);
  text-decoration: none !important;
  cursor: pointer;
  background: var(--color-bg-card);
  border: none;
  border-radius: 50% !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.agenda-modal__fab:hover {
  color: var(--color-primary);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2) !important;
  transform: translateY(-2px);
}

/* Info Grid Section */
.agenda-modal__content {
  padding: 24px 30px !important;
}

.agenda-modal__info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 24px;
}

.agenda-modal__info-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  /* White card */
  padding: 16px;
  /* Center content in card */
  text-align: center;
  background-color: var(--color-bg-card);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  /* Soft shadow */
  transition: transform 0.2s ease;
}

.agenda-modal__info-item:hover {
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.agenda-modal__info-header {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  /* Center header */
  margin-bottom: 8px;
  /* Muted text */
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-subtle) !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.agenda-modal__info-header i {
  margin-right: 8px;
  font-size: 18px;
  color: var(--color-primary);
  /* Default icon color */
}

.agenda-modal__info-header i.icon-category {
  color: var(--color-info) !important;
  /* Info color */
}

.agenda-modal__info-value {
  padding-left: 2px;
  /* Dark text */
  margin: 0;
  font-size: 1.1rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-heading) !important;
}

/* Description Section */
.agenda-modal__section {
  padding: 24px;
  margin-top: 24px;
  text-align: left;
  background-color: var(--color-bg-card);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.agenda-modal__section-title {
  display: block;
  padding-bottom: 8px;
  margin-bottom: 12px;
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-subtle) !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--color-border-light);
}

/* Agenda List Card (BEM) */

/* Agenda Time Marker (BEM) */
.agenda-time-marker {
  position: relative;
  z-index: 5;
  width: 100%;
  height: 2px;
  margin: 0;
}

.agenda-time-marker__line {
  margin: 0;
  border: none;
  border-top: 2px solid var(--color-primary);
  opacity: 0.7;
}

.agenda-time-marker__label {
  position: absolute;
  top: 50%;
  right: 0;
  z-index: 10;
  padding: 0 8px;
  font-size: 0.85rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.3;
  color: var(--color-primary);
  background-color: var(--color-bg-card);
  border-radius: 10px 0 0 10px;
  transform: translateY(-50%);
}

/*******************************
* AGENDA
*******************************/

#agenda-items-content {
  padding-bottom: 0;
}


.filterDiv {
  float: left;
  /** display: none; /* Hidden by default */
}

#poster-modal {
  max-width: 100%;
  max-height: 45vh;
}

div#mapContainer {
  min-height: calc(100vh - 380px);
}

.agenda-groups {
  display: inline-table;
  min-width: 100px;
  text-align: center;
}

.logo-footer-agenda {
  max-height: 50px;
}

button#auth_modal_close,
button#booking_agenda_close {
  position: relative;
  bottom: 11px;
  padding: 0 10px;
  color: red;
}
/* =========================================
   AGENDA GRID LAYOUT (Sidebar + Content)
   ========================================= */

/* --- MOBILE (default): sidebar = fixed bottom footer --- */
.ht-agenda-grid {
  display: block;
}

.ht-agenda-sidebar {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 90;
  width: 100%;
  padding: 16px 0 0 0;
  background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 40%);
}

.ht-agenda-filter-wrapper {
  display: flex;
  gap: 8px;
  padding: 8px 12px;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.ht-agenda-filter-wrapper::-webkit-scrollbar { display: none; }

/* Filter items — pill style (mobile) */
.ht-agenda-filter-item {
  flex: 0 0 auto;
  padding: 7px 14px;
  font-size: 0.8rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
  text-decoration: none;
  cursor: pointer;
  background: var(--color-bg-body);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  transition: var(--transition-fast);
}

.ht-agenda-filter-item:hover {
  color: var(--color-light-text);
  text-decoration: none;
  background: var(--color-bg-subtle);
}

.ht-agenda-filter-item.is-active,
a.ht-agenda-filter-item.is-active {
  color: var(--color-text-inverse);
  background: var(--color-dark);
  border-color: var(--color-text-heading);
}

.ht-agenda-main {
  padding-bottom: 80px; /* space for fixed footer on mobile */
}

