main:has(.auth-form-wrap),
body #main:has(.auth-form-wrap) {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
  background: linear-gradient(160deg, #E8F5F0 0%, #F4F7F6 60%);
}

#login-page.pharmacy-theme main:has(.auth-form-wrap),
body[class*=pharmacy] main:has(.auth-form-wrap) {
  background: linear-gradient(160deg, #EAF0FF 0%, #F4F7F6 60%);
}

.auth-form-wrap {
  width: 100%;
  max-width: 480px;
}

.auth-form__head {
  text-align: center;
  margin-bottom: 28px;
}

.auth-form__title {
  font-size: 26px;
  font-weight: 900;
  color: #2C3E50;
  margin: 0 0 8px;
}

.auth-form__sub {
  font-size: 13px;
  color: #6B7C8F;
  margin: 0;
}

.auth-form__register {
  text-align: center;
  font-size: 13px;
  color: #6B7C8F;
  margin-top: 20px;
}

.auth-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 13px;
  margin-bottom: 16px;
}
.auth-alert--error {
  background: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}
.auth-alert--success {
  background: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}
.auth-alert--warning {
  background: #fff3cd;
  color: #856404;
  border: 1px solid #ffc107;
  align-items: flex-start;
}
.auth-alert i {
  flex-shrink: 0;
  margin-top: 2px;
}
.auth-alert ul {
  margin: 0;
  padding-left: 16px;
}

.resend-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1.5px solid currentColor;
  border-radius: 6px;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: 0.15s;
  color: inherit;
}
.resend-btn:hover {
  opacity: 0.75;
}

.complete-notice {
  background: #EAF0FF;
  color: #2A5FAB;
  border: 1px solid #C0D0F0;
  border-radius: 8px;
  padding: 12px 16px;
  font-size: 12px;
  line-height: 1.7;
  margin-top: 20px;
  text-align: left;
}
.complete-notice i {
  margin-right: 4px;
}

.auth-link {
  color: #2E8B6F;
  font-weight: 600;
}
.auth-link--bold {
  font-weight: 800;
}
.auth-link--sm {
  font-size: 12px;
}

.auth-form-wrap .auth-link {
  color: var(--theme-primary, #2E8B6F);
}

.form-field {
  margin-bottom: 16px;
}

.form-label {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: #2C3E50;
  margin-bottom: 6px;
}

.required {
  font-size: 10px;
  font-weight: 700;
  color: #dc3545;
  background: #FFF5F5;
  padding: 1px 5px;
  border-radius: 3px;
  margin-left: 4px;
}

.form-input-wrap {
  position: relative;
}

.form-input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid #D1DEE0;
  border-radius: 6px;
  font-size: 14px;
  color: #2C3E50;
  font-family: "Noto Sans JP", sans-serif;
  transition: border-color 0.15s;
  background: #fff;
}
.form-input:focus {
  outline: none;
  border-color: var(--theme-primary, #2E8B6F);
  box-shadow: 0 0 0 3px var(--theme-focus-shadow, rgba(46, 139, 111, 0.1));
}
.form-input--password {
  padding-right: 44px;
}

.form-field.has-error .form-input {
  border-color: #dc3545;
}

.form-input-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: #9BABB8;
  font-size: 15px;
  pointer-events: none;
}

.form-input-wrap .form-input {
  padding-left: 36px;
}

.form-input__eye {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: #9BABB8;
  font-size: 15px;
  padding: 2px;
}

.form-hint {
  font-size: 11px;
  color: #9BABB8;
  margin-top: 4px;
}

.form-error {
  font-size: 12px;
  color: #dc3545;
  margin-top: 4px;
}

.form-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.form-check {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
}
.form-check input {
  width: 15px;
  height: 15px;
  cursor: pointer;
  accent-color: var(--theme-primary, #2E8B6F);
}

.btn-auth {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: 0.18s ease;
  text-decoration: none;
}
.btn-auth--primary {
  background: var(--theme-primary, #2E8B6F);
  color: #fff;
}
.btn-auth--primary:hover {
  background: var(--theme-primary-dark, #1F6B52);
  color: #fff;
  text-decoration: none;
}
.btn-auth__loading {
  display: none;
  align-items: center;
  gap: 6px;
}
.btn-auth.is-loading .btn-auth__text {
  display: none;
}
.btn-auth.is-loading .btn-auth__loading {
  display: flex;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.spin {
  display: inline-block;
  animation: spin 0.8s linear infinite;
}

.password-strength {
  margin-top: 6px;
  height: 4px;
  border-radius: 2px;
  background: #E2EDE9;
  overflow: hidden;
}
.password-strength::after {
  content: "";
  display: block;
  height: 100%;
  transition: width 0.3s, background 0.3s;
  border-radius: 2px;
}
.password-strength[data-strength="1"]::after {
  width: 25%;
  background: #dc3545;
}
.password-strength[data-strength="2"]::after {
  width: 50%;
  background: #ffc107;
}
.password-strength[data-strength="3"]::after {
  width: 75%;
  background: #17a2b8;
}
.password-strength[data-strength="4"]::after {
  width: 100%;
  background: #28a745;
}

.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0;
  color: #9BABB8;
  font-size: 12px;
}
.auth-divider::before, .auth-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #D9E8E3;
}

.auth-form__brand {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
}

.auth-brand-logo {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  gap: 2px;
}
.auth-brand-logo__name {
  font-size: 20px;
  font-weight: 900;
  color: var(--theme-primary, #2E8B6F);
  letter-spacing: 0.05em;
}
.auth-brand-logo__sub {
  font-size: 11px;
  color: #9BABB8;
  letter-spacing: 0.02em;
}

.auth-back-top {
  font-size: 12px;
  color: #9BABB8;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 4px;
  transition: color 0.15s;
}
.auth-back-top:hover {
  color: var(--theme-primary, #2E8B6F);
}/*# sourceMappingURL=auth.css.map */