/* login.html 专用样式 — 对齐首页 / 入驻页 */

.page-login .login-main {
  flex: 1;
  width: min(100% - 2rem, 440px);
  margin: 0 auto;
  padding: 1.25rem 0 2rem;
  text-align: center;
}

.page-login .login-title {
  margin: 0 0 0.5rem;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text);
}

.page-login .login-hint {
  margin: 0 0 0.75rem;
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--text-soft);
  text-align: left;
  padding: 0.65rem 0.75rem;
  background: rgba(46, 134, 222, 0.08);
  border-radius: 8px;
  border-left: 3px solid var(--blue);
}

.page-login .login-center-hint {
  margin: 0 0 1rem;
  font-size: 0.78rem;
  line-height: 1.5;
  color: var(--text-muted, #64748b);
  text-align: left;
}

.page-login .login-form {
  text-align: left;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(46, 134, 222, 0.18);
  border-radius: 12px;
  padding: 1.25rem 1.15rem 1.35rem;
  box-shadow: 0 4px 24px rgba(30, 41, 59, 0.08);
}

.page-login .form-row {
  margin-bottom: 0.9rem;
}

.page-login .form-row label {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text);
}

.page-login .form-row input {
  width: 100%;
  padding: 0.65rem 0.75rem;
  font-family: inherit;
  font-size: 0.92rem;
  color: var(--text);
  border: 1px solid rgba(148, 163, 184, 0.55);
  border-radius: 8px;
  background: #fff;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.page-login .form-row input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(46, 134, 222, 0.15);
}

.page-login .remember-row {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 1rem;
  font-size: 0.85rem;
  color: var(--text-soft);
  cursor: pointer;
  user-select: none;
}

.page-login .remember-row input {
  width: 1rem;
  height: 1rem;
  accent-color: var(--blue);
}

.page-login .btn-login {
  width: 100%;
  padding: 0.85rem 1rem;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--blue) 0%, #1e6bb8 100%);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(46, 134, 222, 0.35);
  transition: transform 0.15s, box-shadow 0.2s;
}

.page-login .btn-login:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(46, 134, 222, 0.4);
}

.page-login .btn-login:active {
  transform: translateY(0);
}

.page-login .login-links {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  margin-top: 1.15rem;
  align-items: center;
}

.page-login .link-btn {
  font-family: inherit;
  font-size: 0.88rem;
  color: var(--blue);
  background: none;
  border: none;
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  text-decoration: none;
  transition: color 0.2s;
}

.page-login .link-btn:hover {
  color: #1e6bb8;
  text-decoration: underline;
}

.page-login .link-accent {
  font-weight: 600;
  color: #0f766e;
}

.page-login .link-accent:hover {
  color: #0d9488;
}

.page-login .login-terms {
  margin: 1.25rem 0 0;
  font-size: 0.72rem;
  line-height: 1.55;
  color: var(--text-muted, #94a3b8);
  text-align: center;
}

.page-login .forgot-dialog {
  border: none;
  border-radius: 12px;
  padding: 0;
  max-width: min(92vw, 400px);
  box-shadow: 0 12px 40px rgba(30, 41, 59, 0.2);
}

.page-login .forgot-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}

.page-login .forgot-dialog-body {
  padding: 1.25rem 1.15rem 1.35rem;
  text-align: center;
}

.page-login .forgot-dialog-body h3 {
  margin: 0 0 0.65rem;
  font-size: 1.1rem;
  color: var(--text);
}

.page-login .forgot-dialog-body p {
  margin: 0 0 1rem;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--text-soft);
  text-align: left;
}

.page-login .toast {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  max-width: min(90vw, 360px);
  padding: 0.75rem 1rem;
  font-size: 0.88rem;
  color: #fff;
  background: rgba(30, 41, 59, 0.92);
  border-radius: 8px;
  z-index: 1000;
  opacity: 0;
  transition: transform 0.3s, opacity 0.3s;
  pointer-events: none;
}

.page-login .toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

@media (min-width: 480px) {
  .page-login .login-links {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem 1.25rem;
  }
}
