diff --git a/ui/page/auth/login.html b/ui/page/auth/login.html index e32a9d4..584c3f6 100644 --- a/ui/page/auth/login.html +++ b/ui/page/auth/login.html @@ -13,14 +13,13 @@ display: flex; justify-content: center; align-items: center; - font-family: var(--font-family-sans, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif); } h1 { font-weight: bold; margin: 0; margin-bottom: 15px; - color: var(--color-text, #1f2937); + color: var(--text-color); } p { @@ -29,33 +28,32 @@ line-height: 20px; letter-spacing: 0.5px; margin: 20px 0 30px; - color: var(--color-text, #1f2937); + color: var(--text-color); } span { font-size: 12px; margin: 15px 0; - color: var(--color-text-light, #6b7280); } a { - color: var(--color-primary, #4f46e5); + color: var(--color-primary); font-size: 14px; text-decoration: none; margin: 15px 0; } button { - border-radius: var(--border-radius, 8px); - border: 1px solid var(--color-primary, #4f46e5); - background-color: var(--color-primary, #4f46e5); - color: #ffffff; + border-radius: var(--radius-lg); + border: 1px solid var(--color-primary); + background-color: var(--color-primary); + color: var(--color-primary-text); font-size: 12px; font-weight: bold; padding: 12px 45px; letter-spacing: 1px; text-transform: uppercase; - transition: transform 80ms ease-in, background-color 0.2s; + transition: transform 80ms ease-in, background-color var(--transition-fast); cursor: pointer; overflow: hidden; } @@ -70,8 +68,8 @@ button.ghost { background-color: transparent; - border-color: #ffffff; - color: #ffffff; + border-color: #fff; + color: #fff; } button.ghost:hover { @@ -79,35 +77,33 @@ } button:disabled { - background-color: var(--color-border, #d1d5db); - border-color: var(--color-border, #d1d5db); + background-color: var(--text-color-disabled); + border-color: var(--text-color-disabled); cursor: not-allowed; } - /* Code input row */ .code-input-row { display: flex; - gap: 8px; + gap: var(--spacing-sm); align-items: center; } .code-input-row input { flex: 1; - margin: 8px 0; + margin: var(--spacing-sm) 0; } button.send-code-btn { width: auto; min-width: 90px; padding: 10px 14px; - margin: 8px 0; + margin: var(--spacing-sm) 0; white-space: nowrap; text-transform: none; font-size: 13px; letter-spacing: 0; } - /* Loading spinner */ .loading-spinner { position: absolute; top: 50%; @@ -116,7 +112,7 @@ width: 16px; height: 16px; border: 2px solid rgba(255, 255, 255, 0.3); - border-top: 2px solid #ffffff; + border-top: 2px solid #fff; border-radius: 50%; animation: spin 1s linear infinite; } @@ -136,7 +132,7 @@ } form { - background-color: var(--bg-color-secondary, #ffffff); + background-color: var(--bg-color-secondary); display: flex; align-items: center; justify-content: center; @@ -147,32 +143,40 @@ } input { - background-color: var(--bg-color-secondary, #ffffff); - border: 1px solid var(--color-border, #d1d5db); + background-color: var(--bg-color-secondary); + border: 1px solid var(--border-color); width: 100%; padding: 10px 12px; - margin: 8px 0; - border-radius: var(--border-radius, 8px); - color: var(--color-text, #1f2937); - transition: border-color 0.2s, box-shadow 0.2s; + margin: var(--spacing-sm) 0; + border-radius: var(--radius-lg); + color: var(--text-color); + transition: border-color var(--transition-fast), box-shadow var(--transition-fast); font-size: 14px; } input:focus { outline: none; - border-color: var(--color-primary, #4f46e5); - box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15); + border-color: var(--color-primary); + box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary), transparent 85%); } input::placeholder { - color: var(--color-text-light, #9ca3af); + color: var(--text-color-disabled); + } + + /* Chrome 自动填充覆盖 */ + input:-webkit-autofill, + input:-webkit-autofill:hover, + input:-webkit-autofill:focus { + -webkit-box-shadow: 0 0 0 30px var(--bg-color-secondary) inset !important; + -webkit-text-fill-color: var(--text-color) !important; } .container { position: relative; - background-color: var(--bg-color-secondary, #ffffff); + background-color: var(--bg-color-secondary); border-radius: 10px; - box-shadow: 0 14px 28px rgba(0, 0, 0, 0.15), 0 10px 10px rgba(0, 0, 0, 0.1); + box-shadow: var(--shadow-lg); overflow: hidden; width: 768px; max-width: 100%; @@ -227,12 +231,8 @@ .overlay { position: relative; - background: var(--color-primary, #4f46e5); - background: linear-gradient(to right, var(--color-secondary, #7c3aed), var(--color-primary, #4f46e5)); - background-repeat: no-repeat; - background-size: cover; - background-position: 0 0; - color: #ffffff; + background: linear-gradient(to right, var(--color-secondary), var(--color-primary)); + color: var(--color-primary-text); left: -100%; height: 100%; width: 200%; @@ -281,7 +281,7 @@ } .social-container a { - border: 1px solid #dddddd; + border: 1px solid var(--border-color); border-radius: 50%; display: inline-flex; justify-content: center; @@ -290,13 +290,13 @@ height: 40px; width: 40px; cursor: pointer; - transition: all 0.2s; + transition: all var(--transition-fast); overflow: hidden; font-size: 14px; } .social-container a:hover { - background-color: #f3f4f6; + background-color: var(--bg-color-tertiary); border-color: var(--color-primary); color: var(--color-primary); } @@ -311,16 +311,16 @@ } .error-message { - color: var(--color-danger, #ef4444); + color: var(--color-danger); font-size: 12px; - margin-top: 8px; + margin-top: var(--spacing-sm); min-height: 18px; } .login-tab { display: flex; margin-bottom: 15px; - border-bottom: 1px solid #eee; + border-bottom: 1px solid var(--border-color); width: 100%; } @@ -329,15 +329,15 @@ cursor: pointer; flex: 1; text-align: center; - color: #666; + color: var(--text-color-secondary); font-size: 13px; border-bottom: 2px solid transparent; - transition: all 0.3s; + transition: all var(--transition-base); } .tab-item.active { - color: var(--color-primary, #4f46e5); - border-bottom-color: var(--color-primary, #4f46e5); + color: var(--color-primary); + border-bottom-color: var(--color-primary); font-weight: 600; } @@ -350,7 +350,6 @@ margin-top: 10px; } - /* Responsive */ @media (max-width: 768px) { .container { width: 100%; @@ -389,7 +388,7 @@ display: block !important; margin-top: 20px; font-size: 14px; - color: var(--color-primary, #4f46e5); + color: var(--color-primary); cursor: pointer; } } @@ -406,7 +405,7 @@