/* OFFISS Reservation form assets – v3.42.0 */

/* OFFISS 3.42.0: Reservierungsformular finaler UX-/Design-Polish */
#reservation .subtitle { margin-bottom: 18px; }
#reservation .reservation-form {
  float: none;
  background: rgba(0,0,0,.46);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 16px;
  padding: 22px 18px 16px;
  box-shadow: 0 12px 32px rgba(0,0,0,.24);
  backdrop-filter: blur(3px);
}
#night-booking-form .form-group {
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
#night-booking-form .form-group:last-child { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }
#night-booking-form .control-label { color: #fff; font-weight: 700; letter-spacing: .01em; }
#night-booking-form input.form-control,
#night-booking-form select.form-control {
  min-height: 44px;
  border-radius: 9px 0 0 9px;
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.94);
  color: #111;
  box-shadow: none;
}
#night-booking-form input.form-control:focus,
#night-booking-form select.form-control:focus {
  border-color: #ffda00;
  box-shadow: 0 0 0 2px rgba(255,218,0,.22);
}
#night-booking-form .input-group-addon { min-width: 43px; border-color: rgba(255,255,255,.24); background: rgba(255,218,0,.96); color: #111; }
#night-booking-form .btn-booking {
  min-width: 230px;
  min-height: 46px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: .035em;
  text-transform: uppercase;
  transition: transform .16s ease, filter .16s ease, opacity .16s ease;
}
#night-booking-form .btn-booking:not([disabled]):hover,
#night-booking-form .btn-booking:not([disabled]):focus { transform: translateY(-1px); filter: brightness(1.05); }
#night-booking-form .btn-booking.is-loading::after {
  content: '';
  display: inline-block;
  width: 13px;
  height: 13px;
  margin-left: 8px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  vertical-align: -2px;
  animation: offissReservationSpin .8s linear infinite;
}
@keyframes offissReservationSpin { to { transform: rotate(360deg); } }
.formOverlay { backdrop-filter: blur(2px); }
.formOverlay .loading-text { background:#111; border:1px solid rgba(255,218,0,.35); color:#ffda00; }
@media (max-width: 767px) {
  #reservation .reservation-form { margin-left: 12px; margin-right: 12px; padding: 16px 12px 14px; border-radius: 14px; }
  #night-booking-form .form-group { margin-bottom: 13px; padding-bottom: 12px; }
  #night-booking-form .control-label { margin-bottom: 7px; text-align: left; }
  #night-booking-form .input-field,
  #night-booking-form .text-center { padding-left: 0; padding-right: 0; }
  #night-booking-form .btn-booking { width: 100%; min-width: 0; }
  #night-booking-form input.form-control,
  #night-booking-form select.form-control { font-size: 16px; }
}


/* OFFISS 3.42.0: Formular-Icon-Fix und einheitliche Feldoptik */
#night-booking-form .input-group-addon { display: none !important; }
#night-booking-form .input-group { display: block; width: 100%; }
#night-booking-form input.form-control,
#night-booking-form select.form-control {
  width: 100%;
  border-radius: 9px;
  background: rgba(0,0,0,.72);
  color: #fff;
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
#night-booking-form input.form-control::placeholder { color: rgba(255,255,255,.62); }
#night-booking-form select.form-control { appearance: auto; }
#night-booking-form input[type="date"].form-control { color-scheme: dark; }
#night-booking-form input.form-control:hover,
#night-booking-form select.form-control:hover { border-color: rgba(255,218,0,.48); }
#night-booking-form input.form-control:focus,
#night-booking-form select.form-control:focus {
  background: rgba(0,0,0,.86);
  color: #fff;
  border-color: #ffda00;
  box-shadow: 0 0 0 2px rgba(255,218,0,.24);
  outline: none;
}
#night-booking-form .cf-turnstile { max-width: 100%; }
#night-booking-form .offiss-privacy-hint { margin-top: 8px; opacity: .86; }
@media (max-width: 767px) {
  #night-booking-form input.form-control,
  #night-booking-form select.form-control { min-height: 46px; }
}

/* OFFISS 3.42.0: Conversion Boost */
#night-booking-form .offiss-reservation-trust {
  margin: 10px 0 0;
  color: rgba(255,255,255,.76);
  font-size: 13px;
  line-height: 1.35;
  letter-spacing: .01em;
}
#night-booking-form .btn-booking:not([disabled]):active { transform: translateY(1px) scale(.99); }
@media (max-width: 767px) {
  #night-booking-form .offiss-reservation-trust { font-size: 12px; padding: 0 8px; }
}

/* OFFISS 4.4.1: Mobiles Gast-Formular kompakter und klarer */
@media (max-width: 767px) {
  #reservation .reservation-form { margin: 10px 8px 0 !important; padding: 12px 10px 12px !important; border-radius: 14px !important; background: rgba(0,0,0,.58) !important; }
  .offiss-reservation-context { margin: 0 8px 10px !important; padding: 9px 10px !important; border-radius: 12px !important; font-size: 13px !important; line-height: 1.3 !important; }
  #night-booking-form .form-group { margin-bottom: 9px !important; padding-bottom: 9px !important; border-bottom-color: rgba(255,255,255,.075) !important; }
  #night-booking-form .control-label { margin-bottom: 5px !important; font-size: 13px !important; line-height: 1.25 !important; font-weight: 800 !important; }
  #night-booking-form input.form-control, #night-booking-form select.form-control { min-height: 42px !important; padding: 10px 12px !important; border-radius: 10px !important; font-size: 16px !important; }
  #night-booking-form .cf-turnstile { transform: scale(.92); transform-origin: left top; margin-bottom: -8px; }
  #night-booking-form .offiss-privacy-hint { margin: 1px 0 0 !important; font-size: 11px !important; line-height: 1.3 !important; opacity: .72 !important; }
  #night-booking-form .btn-booking { width: 100% !important; min-height: 44px !important; border-radius: 999px !important; font-size: 14px !important; letter-spacing: .03em !important; }
  #night-booking-form .offiss-reservation-trust { margin-top: 7px !important; padding: 0 !important; font-size: 11.5px !important; line-height: 1.3 !important; }
}


/* OFFISS 4.5.0: Leichter Sprachumschalter im Gast-Reservierungsflow */
.offiss-lang-switch {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 0 auto 16px;
  color: #d8d8d8;
  font-size: 13px;
}
.offiss-lang-switch button {
  border: 1px solid rgba(255, 218, 0, .45);
  background: rgba(0,0,0,.36);
  color: #ffda00;
  border-radius: 999px;
  padding: 6px 12px;
  font-weight: 800;
  cursor: pointer;
}
.offiss-lang-switch button.is-active {
  background: #ffda00;
  color: #181000;
}
