/* ==========================================================================
   HEIMISH TRAVEL — Login & Register Modals (Global)
   Targets: #user_login_modal, #user_register_modal
   These appear site-wide inside Fancybox modals.
   ========================================================================== */


/* ==========================================================================
   SHARED MODAL FORM STYLES
   ========================================================================== */

.hp-form--user-login,
.hp-form--user-register {
  padding: 0 !important;
}

/* Fields stack */
.hp-form--user-login .hp-form__fields,
.hp-form--user-register .hp-form__fields {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

.hp-form--user-login .hp-form__field,
.hp-form--user-register .hp-form__field {
  margin-bottom: var(--space-s) !important;
}

/* Labels */
.hp-form--user-login .hp-form__label,
.hp-form--user-register .hp-form__label {
  font-size: var(--text-s) !important;
  font-weight: 600 !important;
  color: var(--primary) !important;
  margin-bottom: var(--space-xs) !important;
  display: block !important;
}

.hp-form--user-register .hp-form__label small {
  font-weight: 400 !important;
  color: var(--neutral) !important;
}

/* Text / email / password inputs */
.hp-form--user-login .hp-field--text,
.hp-form--user-login .hp-field--password,
.hp-form--user-register .hp-field--email,
.hp-form--user-register .hp-field--password {
  width: 100% !important;
  border: 1px solid rgba(0, 0, 0, 0.12) !important;
  border-radius: var(--radius) !important;
  padding: var(--space-xs) !important;
  font-size: var(--text-s) !important;
  color: var(--primary) !important;
  transition: border-color 0.15s ease !important;
}

.hp-form--user-login .hp-field--text:focus,
.hp-form--user-login .hp-field--password:focus,
.hp-form--user-register .hp-field--email:focus,
.hp-form--user-register .hp-field--password:focus {
  border-color: var(--primary) !important;
  outline: none !important;
}

/* Show/hide password toggle */
.hp-form--user-login .hp-field__icon,
.hp-form--user-register .hp-field__icon {
  color: var(--neutral) !important;
  font-size: var(--text-s) !important;
  transition: color 0.15s ease !important;
  cursor: pointer !important;
}

.hp-form--user-login .hp-field__icon:hover,
.hp-form--user-register .hp-field__icon:hover {
  color: var(--primary) !important;
}

/* Password field wrapper — position toggle icon */
.hp-form--user-login .hp-form__field--password,
.hp-form--user-register .hp-form__field--password {
  position: relative !important;
}

.hp-form--user-login .hp-form__field--password .hp-field__icon,
.hp-form--user-register .hp-form__field--password .hp-field__icon {
  position: absolute !important;
  right: var(--space-xs) !important;
  top: 50% !important;
  transform: translateY(25%) !important;
}


/* ==========================================================================
   TERMS CHECKBOX (Register only)
   ========================================================================== */

.hp-form--user-register .hp-form__field--checkbox {
  margin-bottom: var(--space-s) !important;
}

.hp-form--user-register .hp-field--checkbox {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.4em !important;
  font-size: var(--text-s) !important;
  color: var(--primary) !important;
  cursor: pointer !important;
}

.hp-form--user-register .hp-field--checkbox input[type="checkbox"] {
  accent-color: var(--primary) !important;
  width: 1.1em !important;
  height: 1.1em !important;
  margin-top: 0.15em !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}

.hp-form--user-register .hp-field--checkbox a {
  color: var(--primary) !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}

.hp-form--user-register .hp-field--checkbox a:hover {
  text-decoration: underline !important;
}


/* ==========================================================================
   SUBMIT BUTTON
   ========================================================================== */

.hp-form--user-login .hp-form__footer,
.hp-form--user-register .hp-form__footer {
  padding-top: var(--space-s) !important;
  border-top: 1px solid rgba(0, 0, 0, 0.06) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-s) !important;
}

.hp-form--user-login .hp-form__button,
.hp-form--user-register .hp-form__button {
  width: 100% !important;
  border-radius: 999px !important;
  padding: var(--space-xs) var(--space-s) !important;
  font-size: var(--text-s) !important;
  font-weight: 600 !important;
  background: var(--primary) !important;
  color: var(--white, #fff) !important;
  border: none !important;
  cursor: pointer !important;
  transition: opacity 0.15s ease !important;
  text-align: center !important;
}

.hp-form--user-login .hp-form__button:hover,
.hp-form--user-register .hp-form__button:hover {
  opacity: 0.85 !important;
}


/* ==========================================================================
   FOOTER ACTIONS (Register link, Sign In link, Forgot password)
   ========================================================================== */

.hp-form--user-login .hp-form__actions,
.hp-form--user-register .hp-form__actions {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: var(--space-xs) !important;
}

.hp-form--user-login .hp-form__action,
.hp-form--user-register .hp-form__action {
  font-size: var(--text-s) !important;
  color: var(--neutral) !important;
  margin: 0 !important;
}

.hp-form--user-login .hp-form__action a,
.hp-form--user-register .hp-form__action a {
  color: var(--primary) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}

.hp-form--user-login .hp-form__action a:hover,
.hp-form--user-register .hp-form__action a:hover {
  text-decoration: underline !important;
}

/* Forgot password — subtle */
.hp-form__action--user-password-request {
  font-size: var(--text-s) !important;
  color: var(--neutral) !important;
  text-decoration: none !important;
}

.hp-form__action--user-password-request:hover {
  color: var(--primary) !important;
}


/* ==========================================================================
   ERROR / SUCCESS MESSAGES
   ========================================================================== */

.hp-form--user-login .hp-form__messages,
.hp-form--user-register .hp-form__messages {
  font-size: var(--text-s) !important;
  margin-bottom: var(--space-xs) !important;
}
