/* siteLogin.css – vollständige, stabile Version
   - Layout wie vorher
   - Container-Füllung kommt über .data-card (app.css)
   - Button-Farben korrekt für Light & Dark
*/

.site-login-page{
  min-height:100vh;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:78px 12px 24px;
}

.site-login-card{
  width:100%;
  max-width:560px;
}

.site-login-head{
  display:flex;
  gap:12px;
  margin-bottom:12px;
}

.site-login-brand{
  font-weight:800;
  font-size:20px;
}

.site-login-sub{
  font-size:13px;
  opacity:.8;
}

.site-login-form{
  display:grid;
  gap:10px;
}

.site-login-input{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
}

.dark .site-login-input{
  background:rgba(15,23,42,.4);
  border-color:rgba(255,255,255,.14);
  color:#fff;
}

.site-login-actions{
  display:flex;
  justify-content:flex-end;
}

/* Primary Button – stabil */
.site-login-btn{
  padding:10px 14px;
  border-radius:12px;
  background:#16a34a;
  color:#fff;
  font-weight:800;
  border:none;
  cursor:pointer;
}

.site-login-btn:hover{
  background:#15803d;
}

.site-login-btn:active{
  background:#166534;
}

/* Darkmode identisch */
.dark .site-login-btn{
  background:#16a34a;
  color:#fff;
}

.dark .site-login-btn:hover{
  background:#15803d;
}

.site-login-alert{
  margin-bottom:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(239,68,68,.35);
  background:rgba(239,68,68,.1);
}

/* a11y */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
}
