/* infoReserva.css: estilos desktop limpios y funcionales para el popup de reserva */
.info {
  position: absolute;
  top: 80px;
  right: 32px;
  background: #fff;
  border-radius: 16px;
  box-shadow: none;
  border: none;
  width: 340px;
  max-width: 100%;
  min-height: 480px;
  height: auto;
  display: block;
  padding: 0.5rem 0.5rem 0.5rem 0.5rem;
  margin: 0;
  z-index: 100;
}
.card, .info .card {
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
}
.card-body, .info .card-body {
  position: relative;
  padding: 0;
}
.close {
  top: 1.25rem;
  right: 1.25rem;
  z-index: 10;
  opacity: 0.7;
}
.close img.btn_close {
  width: 28px;
  height: 28px;
}
#infoReserva {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
#infoReserva h4 {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 1.25rem;
  color: #222;
  letter-spacing: 0;
  word-break: normal;
  writing-mode: initial !important;
  text-orientation: initial !important;
  transform: none !important;
  display: block !important;
}
#infoReserva ul, #infoReserva .list-unstyled {
  padding-left: 0;
  margin-bottom: 1rem;
}
#infoReserva li {
  margin-bottom: 0.5rem;
  font-size: 1rem;
  color: #333;
  display: flex;
  align-items: center;
}
#infoReserva label, #infoReserva span, #infoReserva .fw-semibold {
  font-size: 1rem;
  color: #222;
}
#infoReserva .form-select {
  min-width: 120px;
  font-size: 1rem;
}
#infoReserva .form-control {
  font-size: 1rem;
  border-radius: 8px;
}
#infoReserva .btn {
  font-size: 1rem;
  border-radius: 8px;
  padding: 0.5rem 1.5rem;
}
#infoReserva .btn-warning {
  color: #222;
  font-weight: 600;
  background: #ffd600;
  border: none;
}
#infoReserva .btn-outline-dark {
  font-weight: 600;
  border: 1px solid #222;
}
#infoReserva .btn-success {
  font-weight: 700;
  font-size: 1.1rem;
  background: #43b581;
  border: none;
}
#infoReserva .total {
  font-size: 1.08rem;
  font-weight: 600;
  color: #222;
}
#infoReserva .notas textarea {
  width: 100%;
  resize: vertical;
  font-size: 1rem;
  border-radius: 8px;
  border: 1px solid #e0e0e0;
}
#infoReserva .small {
  font-size: 0.95rem;
  color: #555;
}
#infoReserva .form-check-input {
  margin-left: 0.5rem;
}
#infoReserva .form-control.w-50 {
  min-width: 120px;
}
#infoReserva .gap-3 > * {
  margin-right: 1rem !important;
}
#infoReserva .gap-3 > *:last-child {
  margin-right: 0 !important;
}
#infoReserva .list-unstyled {
  margin-bottom: 1.25rem;
}
#infoReserva .mb-3 {
  margin-bottom: 1.25rem !important;
}
#infoReserva .fw-semibold {
  font-weight: 600 !important;
}
#infoReserva .fst-italic {
  font-style: italic !important;
}
#infoReserva .text-center {
  text-align: center !important;
}
#infoReserva .d-flex {
  display: flex !important;
}
#infoReserva .justify-content-center {
  justify-content: center !important;
}
#infoReserva .w-100 {
  width: 100% !important;
}
#infoReserva .py-2 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}
#infoReserva .mt-3 {
  margin-top: 1rem !important;
}
#infoReserva .mb-2 {
  margin-bottom: 0.5rem !important;
}
#infoReserva .display-6 {
  font-size: 1.6rem !important;
}
.card h4, #infoReserva h4 {
  writing-mode: initial !important;
  text-orientation: initial !important;
  transform: none !important;
  letter-spacing: normal !important;
  word-break: normal !important;
  display: block !important;
}
.card {
  height: auto !important;
}
/* Elimina cualquier verticalidad forzada en el título */
