.login-page { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--primary-gradient); padding: 20px; }
.login-logo { width: 80px; height: 80px; background: #fff; border-radius: 20px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; box-shadow: 0 8px 32px rgba(0,0,0,0.15); }
.login-title { color: #fff; font-size: 22px; font-weight: 600; margin-bottom: 6px; }
.login-subtitle { color: rgba(255,255,255,0.8); font-size: 14px; margin-bottom: 32px; }
.login-card { width: 100%; max-width: 380px; background: #fff; border-radius: var(--radius-lg); padding: 32px 24px; box-shadow: var(--shadow-lg); }
.login-card h2 { font-size: 20px; margin-bottom: 24px; text-align: center; color: var(--primary); }
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-size: 13px; color: var(--ink-muted); margin-bottom: 6px; }
.form-group input, .form-group select { width: 100%; height: 46px; border: 1.5px solid var(--border); border-radius: 10px; padding: 0 14px; font-size: 15px; transition: border-color 0.3s; outline: none; background: #fafbfc; }
.form-group input:focus { border-color: var(--primary); background: #fff; }
.login-btn { width: 100%; height: 48px; background: var(--primary-gradient); color: #fff; border: none; border-radius: 10px; font-size: 16px; font-weight: 600; cursor: pointer; margin-top: 8px; transition: opacity 0.3s; }
.login-btn:active { opacity: 0.85; }
.login-btn-outline { background: #fff; color: var(--primary); border: 1.5px solid var(--primary); margin-top: 12px; }
.login-error { color: var(--danger); font-size: 13px; text-align: center; margin-top: 12px; padding: 8px; background: #fef2f2; border-radius: 8px; }
