.elementor-15905 .elementor-element.elementor-element-7c4352f6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--border-radius:16px 16px 16px 16px;--padding-top:30px;--padding-bottom:30px;--padding-left:30px;--padding-right:30px;}.elementor-15905 .elementor-element.elementor-element-7f6f4dcd{text-align:center;}.elementor-15905 .elementor-element.elementor-element-7f6f4dcd .elementor-heading-title{font-size:28px;font-weight:500;color:rgba(255,255,255,0.92);}.elementor-15905 .elementor-element.elementor-element-5c86938c{font-size:15px;color:rgba(255,255,255,0.55);}.elementor-15905 .elementor-element.elementor-element-5ca4f1d7 > .elementor-widget-container{margin:-30px 0px 20px 0px;}#elementor-popup-modal-15905 .dialog-message{width:640px;height:auto;}#elementor-popup-modal-15905{justify-content:center;align-items:center;pointer-events:all;background-color:rgba(0,0,0,.8);}#elementor-popup-modal-15905 .dialog-close-button{display:flex;}#elementor-popup-modal-15905 .dialog-widget-content{animation-duration:0.2s;box-shadow:2px 8px 23px 3px rgba(0,0,0,0.2);}#elementor-popup-modal-15905 .dialog-close-button i{color:rgba(255,255,255,0.7);}#elementor-popup-modal-15905 .dialog-close-button svg{fill:rgba(255,255,255,0.7);}@media(min-width:768px){.elementor-15905 .elementor-element.elementor-element-7c4352f6{--width:640px;}}/* Start custom CSS for container, class: .elementor-element-7c4352f6 *//* ═══════════════════════════════════════════════════════════
   SHARED OVERLAY & MODAL STRUCTURE
═══════════════════════════════════════════════════════════ */

[id^="elementor-popup-modal"]:not([style*="display: none"]) {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
  padding: 20px !important;
  background-color: rgba(0, 0, 0, 0.15) !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
}

.elementor-popup-modal .dialog-widget-content {
  background: transparent !important;
  position: relative !important;
  left: auto !important;
  top: auto !important;
  transform: none !important;
  margin: 0 auto !important;
  width: 100% !important;
  max-width: 630px !important;
  border-radius: 30px !important;
  /* NO overflow hidden here — it traps scroll on iOS */
  overflow: visible !important;
  box-shadow: none !important;
  padding: 0 !important;
  height: auto !important;
  max-height: none !important;
  flex-shrink: 0 !important;
}

.elementor-popup-modal .elementor,
.elementor-popup-modal .elementor-section-wrap,
.elementor-popup-modal .e-con {
  border-radius: 30px !important;
  /* NO overflow hidden — clips content on mobile */
  overflow: visible !important;
}

.elementor-popup-modal .dialog-close-button {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  z-index: 9999 !important;
  color: rgba(255, 255, 255, 0.7) !important;
}

/* ═══════════════════════════════════════════════════════════
   MOBILE
═══════════════════════════════════════════════════════════ */

@media (max-width: 767px) {
  [id^="elementor-popup-modal"]:not([style*="display: none"]) {
    align-items: flex-start !important;
    padding: 12px !important;
  }

  .elementor-popup-modal .dialog-widget-content {
    position: relative !important;
    border-radius: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  .elementor-popup-modal .elementor,
  .elementor-popup-modal .elementor-section-wrap,
  .elementor-popup-modal .e-con {
    border-radius: 16px !important;
  }

  #popup-glass-restaurant,
  #popup-glass-packs-personalizados,
  #popup-glass-packs-fechados {
    border-radius: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 20px 16px !important;
  }

  .crf-row {
    grid-template-columns: 1fr !important;
  }

  .custom-reservation-form .wpcf7-checkbox,
  .custom-experiences-form .wpcf7-checkbox,
  .custom-experiences-form .wpcf7-radio {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   PER-POPUP BACKGROUND (only difference between popups)
═══════════════════════════════════════════════════════════ */

#popup-glass-restaurant {
  background-color:  rgba(44, 60, 69, 0.9) !important;
}

#popup-glass-packs-personalizados,
#popup-glass-packs-fechados {
  background-color: rgba(44, 60, 69, 0.9) !important;
}

/* ═══════════════════════════════════════════════════════════
   SHARED GLASS CONTAINER (all popup IDs)
═══════════════════════════════════════════════════════════ */

#popup-glass-restaurant,
#popup-glass-packs-personalizados,
#popup-glass-packs-fechados {
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-radius: 30px !important;
  padding: 28px 32px !important;
  width: 630px !important;
  max-width: 95vw !important;
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

/* ═══════════════════════════════════════════════════════════
   SHARED FORM RESET
═══════════════════════════════════════════════════════════ */

.custom-reservation-form *,
.custom-experiences-form *,
.custom-reservation-form *::before,
.custom-experiences-form *::before,
.custom-reservation-form *::after,
.custom-experiences-form *::after {
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
}

.custom-reservation-form br,
.custom-experiences-form br {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════
   SHARED FORM LAYOUT
═══════════════════════════════════════════════════════════ */

.custom-reservation-form,
.custom-experiences-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

.crf-header h3 {
  font-size: 17px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.95) !important;
  margin-bottom: 2px !important;
}

.crf-header p {
  font-size: 12px !important;
  color: rgba(255,255,255,0.4) !important;
  line-height: 1.4 !important;
  margin-bottom: 6px !important;
}

.custom-reservation-form h4,
.custom-experiences-form h4 {
  font-family: "Comfortaa", Sans-serif !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: #A27C5C !important;
  padding-bottom: 3px !important;
  border-bottom: 0.5px solid rgba(162,124,92,0.25) !important;
  margin-top: 10px !important;
}

.custom-reservation-form h4 span,
.custom-experiences-form h4 span {
  font-size: 10px !important;
  font-weight: 400 !important;
  color: rgba(255,255,255,0.3) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.crf-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

.crf-field {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  width: 100% !important;
}

.crf-label {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.5) !important;
  display: block !important;
  margin-bottom: 3px !important;
  text-align: left !important;
}

/* ═══════════════════════════════════════════════════════════
   SHARED LABELS
═══════════════════════════════════════════════════════════ */

.custom-reservation-form label,
.custom-experiences-form label {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 3px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.5) !important;
  width: 100% !important;
  min-width: 0 !important;
}

/* ═══════════════════════════════════════════════════════════
   SHARED INPUTS
═══════════════════════════════════════════════════════════ */

.custom-reservation-form input[type="text"],
.custom-reservation-form input[type="email"],
.custom-reservation-form input[type="tel"],
.custom-reservation-form input[type="date"],
.custom-reservation-form input[type="time"],
.custom-reservation-form input[type="number"],
.custom-reservation-form textarea,
.custom-reservation-form select,
.custom-experiences-form input[type="text"],
.custom-experiences-form input[type="email"],
.custom-experiences-form input[type="tel"],
.custom-experiences-form input[type="date"],
.custom-experiences-form input[type="time"],
.custom-experiences-form input[type="number"],
.custom-experiences-form textarea,
.custom-experiences-form select {
  display: block !important;
  background: rgba(255,255,255,0.07) !important;
  border: 0.5px solid rgba(255,255,255,0.15) !important;
  border-radius: 6px !important;
  padding: 7px 10px !important;
  color: rgba(255,255,255,0.85) !important;
  font-size: 13px !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  transition: border-color 0.2s ease !important;
  box-sizing: border-box !important;
}

.custom-reservation-form input:focus,
.custom-reservation-form textarea:focus,
.custom-reservation-form select:focus,
.custom-experiences-form input:focus,
.custom-experiences-form textarea:focus,
.custom-experiences-form select:focus {
  border-color: rgba(162,124,92,0.7) !important;
}

.custom-reservation-form input::placeholder,
.custom-reservation-form textarea::placeholder,
.custom-experiences-form input::placeholder,
.custom-experiences-form textarea::placeholder {
  color: rgba(255,255,255,0.2) !important;
}

.custom-reservation-form input[type="date"]::-webkit-calendar-picker-indicator,
.custom-reservation-form input[type="time"]::-webkit-calendar-picker-indicator,
.custom-experiences-form input[type="date"]::-webkit-calendar-picker-indicator,
.custom-experiences-form input[type="time"]::-webkit-calendar-picker-indicator {
  filter: invert(1) opacity(0.4) !important;
  cursor: pointer !important;
  background-color: transparent !important;
}

.custom-reservation-form input[type="number"]::-webkit-inner-spin-button,
.custom-reservation-form input[type="number"]::-webkit-outer-spin-button,
.custom-experiences-form input[type="number"]::-webkit-inner-spin-button,
.custom-experiences-form input[type="number"]::-webkit-outer-spin-button {
  filter: invert(1) opacity(0.4) !important;
  cursor: pointer !important;
}

.custom-reservation-form textarea,
.custom-experiences-form textarea {
  min-height: 44px !important;
  max-height: 70px !important;
  resize: none !important;
  line-height: 1.4 !important;
}

.custom-reservation-form .wpcf7-form-control-wrap,
.custom-experiences-form .wpcf7-form-control-wrap {
  display: block !important;
  width: 100% !important;
}

/* ═══════════════════════════════════════════════════════════
   SELECT ARROW
═══════════════════════════════════════════════════════════ */

.custom-reservation-form select,
.custom-experiences-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,0.4)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  padding-right: 30px !important;
}

.custom-reservation-form select option,
.custom-experiences-form select option {
  background: #2a2a2a !important;
  color: rgba(255,255,255,0.85) !important;
}

/* ═══════════════════════════════════════════════════════════
   CHECKBOXES & RADIO
═══════════════════════════════════════════════════════════ */

.custom-reservation-form .wpcf7-checkbox,
.custom-experiences-form .wpcf7-checkbox,
.custom-experiences-form .wpcf7-radio {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 4px !important;
}

.custom-reservation-form .wpcf7-list-item,
.custom-experiences-form .wpcf7-list-item {
  margin: 0 !important;
}

.custom-reservation-form .wpcf7-list-item label,
.custom-experiences-form .wpcf7-list-item label {
  flex-direction: row !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.6) !important;
  cursor: pointer !important;
}

.wpcf7-acceptance input[type="checkbox"],
.wpcf7-checkbox input[type="checkbox"],
.wpcf7-list-item input[type="checkbox"],
.wpcf7-list-item input[type="radio"] {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  width: 14px !important;
  min-width: 14px !important;
  height: 14px !important;
  border-radius: 3px !important;
  border: 1.5px solid rgba(162,124,92,0.6) !important;
  background-color: transparent !important;
  background-image: none !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  margin: 2px 0 0 0 !important;
  outline: none !important;
  box-shadow: none !important;
}

.wpcf7-list-item input[type="radio"] {
  border-radius: 50% !important;
}

.wpcf7-acceptance input[type="checkbox"]:checked,
.wpcf7-checkbox input[type="checkbox"]:checked,
.wpcf7-list-item input[type="checkbox"]:checked,
.wpcf7-list-item input[type="radio"]:checked {
  background-color: #A27C5C !important;
  border-color: #A27C5C !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M2.5 7l3 3 6-6' stroke='%23ffffff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-size: 10px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

/* ═══════════════════════════════════════════════════════════
   ACCEPTANCE
═══════════════════════════════════════════════════════════ */

.custom-reservation-form .wpcf7-acceptance .wpcf7-list-item,
.custom-experiences-form .wpcf7-acceptance .wpcf7-list-item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  margin: 4px 0 0 !important;
}

.custom-reservation-form .wpcf7-acceptance .wpcf7-list-item label,
.custom-experiences-form .wpcf7-acceptance .wpcf7-list-item label {
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 8px !important;
  font-size: 11px !important;
  color: rgba(255,255,255,0.45) !important;
  line-height: 1.5 !important;
  cursor: pointer !important;
}

.custom-reservation-form .wpcf7-acceptance a,
.custom-experiences-form .wpcf7-acceptance a {
  color: #A27C5C !important;
  text-decoration: none !important;
}

.custom-reservation-form .wpcf7-acceptance a:hover,
.custom-experiences-form .wpcf7-acceptance a:hover {
  text-decoration: underline !important;
}

/* ═══════════════════════════════════════════════════════════
   VALIDATION
═══════════════════════════════════════════════════════════ */

.custom-reservation-form .wpcf7-form-control.wpcf7-not-valid,
.custom-experiences-form .wpcf7-form-control.wpcf7-not-valid {
  border: 1px solid rgba(220,80,80,0.7) !important;
  box-shadow: 0 0 0 3px rgba(220,80,80,0.1) !important;
}

.custom-reservation-form .wpcf7-not-valid-tip,
.custom-experiences-form .wpcf7-not-valid-tip {
  display: block !important;
  color: #e07070 !important;
  font-size: 11px !important;
  margin-top: 3px !important;
  text-align: left !important;
}

/* ═══════════════════════════════════════════════════════════
   FOOTER & SUBMIT
═══════════════════════════════════════════════════════════ */

.crf-footer {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  margin-top: 8px !important;
}

.crf-footer p {
  font-size: 11px !important;
  color: rgba(255,255,255,0.25) !important;
  text-align: center !important;
}

.custom-reservation-form input[type="submit"],
.custom-experiences-form input[type="submit"] {
  font-family: "Comfortaa", Sans-serif !important;
  background: #A27C5C !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 10px 20px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  width: 100% !important;
  text-align: center !important;;
  text-transform: capitalize !important;
  transition: background 0.2s ease !important;
}

.custom-reservation-form input[type="submit"]:hover,
.custom-experiences-form input[type="submit"]:hover {
  background: #8f6b4c !important;
}

.custom-reservation-form input[type="submit"]:disabled,
.custom-experiences-form input[type="submit"]:disabled {
  background: rgba(162,124,92,0.4) !important;
  cursor: not-allowed !important;
  opacity: 0.6 !important;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSE OUTPUT
═══════════════════════════════════════════════════════════ */

.custom-reservation-form ~ .wpcf7-response-output,
.custom-experiences-form ~ .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.sent .wpcf7-response-output {
  display: block !important;
  position: static !important;
  margin: 6px 0 0 !important;
  padding: 8px 12px !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.8) !important;
  border: 0.5px solid rgba(162,124,92,0.4) !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
}

/* ═══════════════════════════════════════════════════════════
   HIDE JUNK
═══════════════════════════════════════════════════════════ */

.custom-reservation-form ~ .altEmail_container,
.custom-experiences-form ~ .altEmail_container,
.wpa-test-msg,
.wpa_hidden_field,
fieldset.hidden-fields-container {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════
   MOBILE
═══════════════════════════════════════════════════════════ */

@media (max-width: 767px) {
  [id^="elementor-popup-modal"]:not([style*="display: none"]) {
    padding: 16px !important;
  }

  .elementor-popup-modal .dialog-widget-content {
    border-radius: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  .elementor-popup-modal .elementor,
  .elementor-popup-modal .elementor-section-wrap,
  .elementor-popup-modal .e-con {
    border-radius: 16px !important;
  }

  #popup-glass-restaurant,
  #popup-glass-packs-personalizados,
  #popup-glass-packs-fechados {
    border-radius: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 20px 16px !important;
  }

  .crf-row {
    grid-template-columns: 1fr !important;
  }

  .custom-reservation-form .wpcf7-checkbox,
  .custom-experiences-form .wpcf7-checkbox,
  .custom-experiences-form .wpcf7-radio {
    grid-template-columns: 1fr !important;
  }
}/* End custom CSS */