/* Login Modal im Stil der Willkommen-Seite */

.hidden { display: none !important; }

.login-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1200; /* über Topbar und Content */
  display: grid;
  place-items: center;
  background: rgba(0,0,0,0.35);
  -webkit-backdrop-filter: blur(6px) saturate(120%);
  backdrop-filter: blur(6px) saturate(120%);
}

.login-modal {
  width: min(420px, 92vw);
  border-radius: 18px;
  background: rgba(20, 23, 28, 0.70);
  border: 1px solid rgba(255,255,255,0.30);
  -webkit-backdrop-filter: blur(22px) saturate(120%);
  backdrop-filter: blur(22px) saturate(120%);
  color: #eef1f5;
  box-shadow: 0 18px 50px -25px rgba(0,0,0,0.55);
  padding: 18px 18px 16px;
}

.login-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.login-title {
  margin: 0;
  font: 700 20px/1.3 "Inter", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  color: #eef1f5;
}
.login-close-btn {
  appearance: none;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: #e8eaed;
  width: 32px; height: 32px;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: 160ms ease;
}
.login-close-btn:hover { filter: brightness(1.08); }
.login-close-btn:active { transform: translateY(1px); }

.login-body { margin-top: 10px; }
.login-subtext { margin: 6px 0 12px; color: #dbe0e6; font: 500 14px/1.5 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial; }

.login-form { display: grid; gap: 10px; }
.login-field { display: grid; gap: 6px; }
.login-label { font: 600 12px/1.2 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial; color: #e8eaed; }
.login-input {
  height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.10);
  color: #eef1f5;
  outline: none;
}
.login-input::placeholder { color: #c9cfd6; }
.login-input:focus { border-color: rgba(255,255,255,0.30); box-shadow: 0 0 0 2px rgba(255,255,255,0.08) inset; }

.login-actions { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 6px; }
.login-btn-primary {
  display: inline-flex; align-items: center; justify-content: center;
  height: 38px; padding: 0 14px; border-radius: 12px;
  text-decoration: none; font: 600 14px/1 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  letter-spacing: 0.2px; transition: 160ms ease;
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(255,255,255,0.16);
  color: #eef1f5;
  box-shadow: 0 10px 26px -14px rgba(0,0,0,0.55);
}
.login-btn-primary:hover { filter: brightness(1.08); }
.login-btn-primary:active { transform: translateY(1px); }
.login-btn-primary[disabled] { opacity: 0.7; cursor: not-allowed; }

.login-message { min-height: 18px; font: 600 12.5px/1.4 "Inter", system-ui; color: #ffdbdb; }
.login-message.ok { color: #d7ffd7; }

@media (max-width: 560px) {
  .login-modal { width: min(480px, 94vw); padding: 16px 14px 14px; border-radius: 14px; }
}

@media (prefers-reduced-motion: reduce) {
  .login-close-btn, .login-btn-primary { transition: none; }
}
