.login-submit {
  display: grid;
  place-items: center;
  height: 55px;
  border-radius: 15px;
  background: linear-gradient(135deg, #0ca562 0%, #047842 100%);
  color: #fff;
  box-shadow: 0 18px 34px rgba(15, 139, 83, 0.2);
  font-size: 18px;
  font-weight: 900;
}

.login-submit:disabled {
  background: linear-gradient(135deg, #12a766 0%, #087c48 100%);
  color: rgba(255, 255, 255, 0.96);
  cursor: not-allowed;
}

.login-status {
  position: absolute;
  top: 224px;
  right: 24px;
  left: 24px;
  z-index: 2;
  padding: 5px 8px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.92);
  color: #69706c;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  pointer-events: none;
}

.login-status:empty {
  display: none;
}

.login-status[data-tone="ok"] {
  color: #0d8b58;
}

.login-status[data-tone="error"] {
  color: #c33d2a;
}

.login-divider {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  color: #979c98;
  font-size: 14px;
  font-weight: 800;
}

.login-divider::before,
.login-divider::after {
  height: 1px;
  background: rgba(17, 21, 19, 0.1);
  content: "";
}

.social-login-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.social-login {
  display: grid;
  justify-items: center;
  gap: 10px;
  color: #202523;
  font-size: 15px;
  font-weight: 800;
}

.social-icon {
  display: grid;
  place-items: center;
  width: 66px;
  height: 66px;
  border: 1px solid rgba(17, 21, 19, 0.08);
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 10px 24px rgba(54, 43, 30, 0.06);
}

.social-icon svg {
  width: 36px;
  height: 36px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.social-login-wechat .social-icon {
  color: #24bd38;
}

.social-login-wechat .social-icon svg {
  fill: currentColor;
  stroke-width: 0;
}

.social-login-apple .social-icon {
  color: #050505;
}

.social-login-apple .social-icon svg {
  fill: currentColor;
  stroke-width: 0;
}

.social-login-alipay .social-icon {
  color: #1d70f0;
}

.alipay-mark {
  color: currentColor;
  font-size: 38px;
  font-weight: 900;
  line-height: 1;
}

.login-privacy {
  display: inline-flex;
  gap: 7px;
  align-items: center;
  justify-content: center;
  color: #8a918d;
  font-size: 13px;
  font-weight: 700;
}

.login-privacy svg {
  width: 16px;
  height: 16px;
  color: rgba(13, 139, 88, 0.62);
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.login-back:hover,
.login-submit:hover,
.social-login:hover .social-icon,
#sendCodeButton:hover,
.login-support:hover {
  transform: translateY(-1px);
}

.login-submit:hover {
  box-shadow: 0 22px 38px rgba(15, 139, 83, 0.25);
}

.login-back:active,
.login-submit:active,
.social-login:active .social-icon,
#sendCodeButton:active,
.login-support:active {
  transform: translateY(0) scale(0.98);
}

@media (max-width: 420px) {
  .login-panel { gap: 15px; margin-top: 48px; }
  .login-hero { gap: 10px; }
  .login-benefits { gap: 8px; }
  .login-benefit { min-height: 46px; }
  .login-card { gap: 12px; padding: 20px 18px 17px; }
  .login-status { top: 206px; right: 18px; left: 18px; }
  .social-icon { width: 60px; height: 60px; }
  .social-icon svg { width: 33px; height: 33px; }
  .alipay-mark { font-size: 35px; }
  .social-login { gap: 8px; font-size: 14px; }
}

@media (max-width: 380px) {
  .login-view { padding-right: 19px; padding-left: 19px; padding-bottom: 12px; }
  .login-panel { gap: 14px; margin-top: 40px; }
  .login-hero { gap: 8px; }
  .login-logo { width: 40px; height: 40px; }
  .login-logo span { width: 25px; height: 25px; font-size: 21px; }
  .login-brand { font-size: 20px; }

  .login-brand-sub,
  .login-subtitle {
    font-size: 12px;
  }

  .login-hero h1 { font-size: 25px; }
  .login-benefits { gap: 6px; }
  .login-benefit { min-height: 42px; padding: 7px 6px; }
  .login-benefit svg { flex-basis: 24px; width: 24px; height: 24px; }
  .login-card { gap: 11px; padding: 18px 17px 15px; }
  .login-status { top: 198px; right: 17px; left: 17px; }
  .login-tabs { padding-bottom: 3px; }
  .field-shell { min-height: 50px; }
  .login-field input { height: 48px; }
  .agreement-row { font-size: 12px; line-height: 1.35; }
  .login-submit { height: 52px; }
  .login-divider { font-size: 12px; }
  .social-icon { width: 54px; height: 54px; }
  .social-icon svg { width: 31px; height: 31px; }
  .alipay-mark { font-size: 32px; }
  .social-login { gap: 7px; font-size: 12px; }
  .login-privacy { font-size: 11px; }
}
