/* ============================================================
   LOGIN.CSS — Login-Seite
   ============================================================ */

body.light {
  background: #ede6d6;
  color: #2a2a2a;
}
body.light::before { opacity: 0.015; }

.nav-light { mix-blend-mode: normal; }
.nav-light .nav-logo,
.nav-light .nav-links a { color: #2a2a2a; }
.nav-light .nav-links a::after { background: #2a2a2a; }

body.light .cursor { background: #2a2a2a; }
body.light .cursor-ring { border-color: rgba(42,42,42,0.4); }

/* ── MAIN ── */
.login-main {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 120px 24px 80px;
}

/* ── LOGIN BOX ── */
.login-box {
  width: 100%;
  max-width: 400px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.login-title {
  font-family: var(--serif);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 400;
  font-style: italic;
  color: #1a1a1a;
  line-height: 1;
}

.login-sub {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #999;
  margin-top: -20px;
}

/* ── FORM ── */
.login-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.login-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.login-field label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #888;
}

.login-field input {
  font-family: var(--sans);
  font-size: 15px;
  color: #2a2a2a;
  background: rgba(42,42,42,0.05);
  border: 1px solid rgba(42,42,42,0.15);
  padding: 14px 16px;
  outline: none;
  width: 100%;
  transition: border-color .2s;
  -webkit-appearance: none;
}

.login-field input:focus {
  border-color: #2a2a2a;
}

.login-field input::placeholder {
  color: rgba(42,42,42,0.3);
}

/* ── ERROR ── */
.login-error {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: #c0392b;
  min-height: 16px;
}

/* ── BUTTON ── */
.login-btn {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  background: #2a2a2a;
  color: #f5f2ec;
  border: none;
  padding: 16px 24px;
  cursor: pointer;
  width: 100%;
  transition: opacity .2s;
  margin-top: 8px;
}
.login-btn:hover { opacity: 0.75; }
.login-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── FOOTER ── */
.footer-light {
  background: #ede6d6;
  border-top: 1px solid rgba(42,42,42,0.1);
}
.footer-light .footer-copy { color: rgba(42,42,42,0.4); }
.footer-light .footer-legal a {
  color: rgba(42,42,42,0.5);
  text-decoration: none;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  transition: color .3s;
}
.footer-light .footer-legal a:hover { color: #2a2a2a; }

/* ── MOBILE ── */
@media (max-width: 768px) {
  .cursor, .cursor-ring { display: none; }
  body { cursor: auto; }
  .login-main { padding: 100px 24px 60px; }
}
