#view-login {
  align-items: center; justify-content: center;
  min-height: 100vh; background: var(--bg);
}
.login-card {
  background: var(--surface); border-radius: var(--radius-lg);
  padding: 40px 36px; width: 100%; max-width: 380px;
  box-shadow: var(--shadow);
}
.login-brand {
  font-family: var(--font-serif); font-size: 22px;
  color: var(--text-primary); margin-bottom: 4px;
}
.login-brand em { font-style: italic; color: var(--sage); }
.login-sub {
  font-size: 11px; color: var(--text-secondary);
  letter-spacing: .05em; margin-bottom: 32px;
}
.btn-google {
  width: 100%; display: flex; align-items: center; justify-content: center;
  gap: 10px; padding: 11px 16px; margin-bottom: 16px;
  background: #fff; border: 1.5px solid #dadce0; border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 600; color: #3c4043;
  cursor: pointer; transition: background .15s, box-shadow .15s;
}
.btn-google:hover { background: #f8f9fa; box-shadow: 0 1px 3px rgba(0,0,0,.12); }
.login-divider {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 16px; color: var(--text-secondary); font-size: 11px;
}
.login-divider::before, .login-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.login-field { margin-bottom: 14px; }
.login-error {
  font-size: 11px; color: var(--overdue);
  margin-bottom: 12px; display: none;
}
.login-error.visible { display: block; }
.login-btn {
  width: 100%; margin-top: 8px;
  padding: 12px; font-size: 12px;
}
