/*
 * Heart of Hope — Auth (Login, Register, Member)
 */

/* Login card */
.hoh-login-card {
  background: #ffffff;
  border-radius: var(--hoh-radius-lg);
  padding: 32px;
  margin: 40px auto;
  max-width: 420px;
  box-shadow: var(--hoh-shadow-deep);
  border: 1px solid var(--hoh-border-soft);
  font-family: var(--hoh-font-sans);
  animation: hohFadeIn 0.4s ease-out;
}

@keyframes hohFadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hoh-login-card label {
  display: block;
  font-size: 14px;
  margin-bottom: 6px;
  color: var(--hoh-text-main);
}

.hoh-login-card input[type="text"],
.hoh-login-card input[type="password"] {
  width: 100%;
  padding: 12px 14px;
  border-radius: var(--hoh-radius-sm);
  border: 1px solid #cccccc;
  background: #fafafa;
  margin-bottom: 16px;
  font-size: 16px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.hoh-login-card input[type="text"]:focus,
.hoh-login-card input[type="password"]:focus {
  outline: none;
  border-color: var(--hoh-purple);
  background: #ffffff;
  box-shadow: 0 0 0 3px rgba(90, 62, 166, 0.15);
}

.hoh-login-card input[type="submit"] {
  width: 100%;
  padding: 12px;
  background: var(--hoh-purple);
  color: #ffffff;
  border: none;
  border-radius: var(--hoh-radius-sm);
  cursor: pointer;
  font-size: 16px;
  transition: background 0.2s ease;
}

.hoh-login-card input[type="submit"]:hover {
  background: #4A2E8C;
}

.hoh-login-card p {
  margin-bottom: 18px;
}

/* Remember Me */
.hoh-login-card .login-remember label {
  display: flex;
  align-items: center;
  gap: 8px;
}

.hoh-login-card .login-remember input[type="checkbox"] {
  margin: 0;
  width: 18px;
  height: 18px;
}

/* Login links */
.hoh-login-links {
  margin-top: 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.hoh-login-links a {
  color: var(--hoh-purple);
  font-size: 14px;
  text-decoration: none;
}

.hoh-login-links a:hover {
  text-decoration: underline;
}

/* Member home */
.hoh-member-home {
  max-width: 600px;
  margin: 60px auto;
  text-align: center;
  font-family: var(--hoh-font-sans);
}

.hoh-welcome {
  font-size: 20px;
  margin-bottom: 24px;
  color: var(--hoh-text-main);
}

.hoh-logout-btn {
  display: inline-block;
  padding: 12px 24px;
  background: var(--hoh-purple);
  color: #ffffff;
  border-radius: var(--hoh-radius-sm);
  text-decoration: none;
  font-size: 16px;
  transition: background 0.2s ease;
}

.hoh-logout-btn:hover {
  background: #4A2E8C;
}

/* Register card */
.hoh-register-wrapper {
  padding: 40px 20px;
  display: flex;
  justify-content: center;
}

.hoh-register-card {
  background: #ffffff;
  border-radius: var(--hoh-radius-lg);
  padding: 36px;
  margin: 40px auto;
  max-width: 420px;
  box-shadow: var(--hoh-shadow-deep);
  border: 1px solid var(--hoh-border-soft);
  font-family: var(--hoh-font-sans);
  animation: hohFadeIn 0.4s ease-out;
  text-align: center;
  position: relative;
}

.hoh-register-card::before {
  content: "";
  position: absolute;
  top: -20px;
  left: -20px;
  right: -20px;
  bottom: -20px;
  background: radial-gradient(
    circle at center,
    rgba(90, 62, 166, 0.12),
    rgba(90, 62, 166, 0) 70%
  );
  border-radius: var(--hoh-radius-halo);
  z-index: -1;
}

.hoh-register-title {
  font-size: 22px;
  margin-bottom: 8px;
  color: var(--hoh-text-main);
}

.hoh-register-scripture {
  font-size: 14px;
  color: var(--hoh-text-muted);
  margin-bottom: 24px;
  font-style: italic;
}

.hoh-register-card form {
  text-align: center;
}

.hoh-register-card label {
  display: block;
  text-align: left;
  margin: 0 auto 6px auto;
  max-width: 320px;
}

/* Unified inputs */
.hoh-register-card input[type="text"],
.hoh-register-card input[type="email"],
.hoh-register-card input[type="password"] {
  display: block;
  width: 100%;
  max-width: 320px;
  margin: 0 auto 16px auto;
  padding: 12px 14px;
  height: 20px;
  border-radius: var(--hoh-radius-sm);
  border: 1px solid #cccccc;
  background: #fafafa;
  font-size: 16px;
  text-align: left;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.hoh-register-card input[type="text"]:focus,
.hoh-register-card input[type="email"]:focus,
.hoh-register-card input[type="password"]:focus {
  outline: none;
  border-color: var(--hoh-purple);
  background: #ffffff;
  box-shadow: 0 0 0 3px rgba(90, 62, 166, 0.15);
}

.hoh-register-card input[type="submit"] {
  width: 100%;
  padding: 12px;
  background: var(--hoh-purple);
  color: #ffffff;
  border: none;
  border-radius: var(--hoh-radius-sm);
  cursor: pointer;
  font-size: 16px;
  transition: background 0.2s ease;
}

.hoh-register-card input[type="submit"]:hover {
  background: #4A2E8C;
}

.hoh-register-links {
  margin-top: 20px;
}

.hoh-register-links a {
  color: var(--hoh-purple);
  font-size: 14px;
  text-decoration: none;
}

.hoh-register-links a:hover {
  text-decoration: underline;
}

/* Register messages */
.hoh-error-message {
  background: #ffe5e5;
  border: 1px solid #ffb3b3;
  color: #a33;
  padding: 12px 16px;
  border-radius: var(--hoh-radius-sm);
  margin-bottom: 20px;
  text-align: center;
}

.hoh-success-message {
  background: #e7f7e7;
  border: 1px solid #b6e3b6;
  color: #2d7a2d;
  padding: 12px 16px;
  border-radius: var(--hoh-radius-sm);
  margin-bottom: 20px;
  text-align: center;
}
