:root{
  --brand:#ff7a00;    /* Orange */
  --brand2:#ff9e3a;   /* Hell-Orange */
  --bg1:#0d1117;      /* Schwarzblau-Hintergrund */
  --bg2:#1a2230;      /* Dunkelblau */
  --text:#e0e0e0;     /* Hellgrau-Text */
  --muted:#9ca3af;    /* Dezenter Text */
  --card: rgba(30,34,48,.85); /* Dunkles Card-Panel */
  --border: rgba(255,255,255,.08);
  --shadow: 0 25px 60px rgba(0,0,0,.4);
  --radius:20px;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font:16px/1.55 system-ui,Segoe UI,Roboto,Arial;
  color:var(--text);
  background:
    radial-gradient(1200px 1200px at -10% -10%, #1f2b3a 0%, transparent 60%),
    radial-gradient(1200px 1200px at 110% 110%, #1f2b3a 0%, transparent 60%),
    linear-gradient(160deg,var(--bg1),var(--bg2));
  overflow:auto;
}
.bg-anim{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(600px 600px at 20% 0%, #222e42 0%, transparent 60%),
    radial-gradient(700px 700px at 100% 80%, #222e42 0%, transparent 60%);
  filter: blur(30px);
  animation: float 12s ease-in-out infinite alternate;
}
@keyframes float { from{transform:translateY(-6px)} to{transform:translateY(6px)} }

.wrap{
  min-height:100%;
  display:grid; place-items:center; padding:28px;
}
.card{
  width:100%; max-width:520px;
  background:var(--card); backdrop-filter: blur(14px);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:26px 24px 22px;
  transform: translateY(8px);
  animation: enter .5s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes enter { to{ transform: translateY(0) } }

.brand{
  display:flex; align-items:center; gap:14px; margin-bottom:10px;
}
.brand .logo{
  width:56px; height:56px; border-radius:16px; flex:0 0 56px;
  display:grid;place-items:center; overflow:hidden;
  background: conic-gradient(from 210deg,var(--brand),var(--brand2));
  box-shadow:0 8px 20px rgba(255,122,0,.35);
}
.brand .logo img{ width:100%; height:100%; object-fit:contain }
.brand h1{ margin:0; font-size:22px; font-weight:800; letter-spacing:.2px }

.sub{ margin:2px 0 16px; color:var(--muted) }

label{display:block; font-size:.95rem; margin:12px 0 6px}

.input {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 12px;
  background: rgba(26, 34, 48, 0.85); /* leicht transparentes Dunkelblau */
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.4);
  padding: 0 12px;
  height: 50px;
  transition: border-color 0.25s, box-shadow 0.25s, background 0.25s;
}

.input input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--text);
  font-size: 16px;
}

.input input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.input:focus-within {
  border-color: var(--brand); /* Orange-Rahmen */
  background: rgba(26, 34, 48, 0.95); /* etwas kräftiger beim Fokus */
  box-shadow: 0 0 8px rgba(255, 122, 0, 0.4); /* Orange Glow */
}

.eye{ cursor:pointer; user-select:none; font-size:1rem; color:#9ca3af }

.row{ display:flex; align-items:center; gap:10px; justify-content:space-between; margin-top:14px }
.left{ display:flex; align-items:center; gap:10px; color:#777; font-size:.9rem }

.btn{
  appearance:none; border:0; cursor:pointer; font-weight:700;
  padding:16px 18px; border-radius:14px; box-shadow: var(--shadow);
  transition: transform .06s ease, filter .15s ease;
}
.btn:active{ transform: translateY(1px) }
.btn.primary{ background:linear-gradient(180deg,var(--brand),var(--brand2)); color:#fff }
.btn.ghost{ background:#1a2230; border:1px solid var(--brand); color:#fff }

.err{
  margin-top:10px; padding:12px 14px; border-radius:12px;
  background:rgba(255,122,0,0.1); color:var(--brand); border:1px solid var(--brand);
}

.footer{ margin-top:14px; text-align:center; color:#868b94; font-size:.9rem }
.footer a{ color:var(--brand); text-decoration:none }
.footer a:hover{ text-decoration:underline }

@media (max-width:480px){
  .card{ padding:20px 16px }
  .btn{ width:100% }
  .row{ flex-direction:column; align-items:stretch; gap:8px }
}
/* ========== Mobile & Safe-Area Basics ========== */
html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

:root{
  /* nutzt iOS Notch-Safe-Areas, fällt auf 0 zurück wo nicht vorhanden */
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
}

.wrap{
  /* oben/unten etwas mehr Luft + Safe-Area berücksichtigen */
  padding: calc(24px + var(--safe-top)) 28px calc(24px + var(--safe-bottom));
}

.btn {
  min-height: 48px;         /* größere Touch-Ziele */
  touch-action: manipulation;
}
.eye{ padding: 8px; }        /* leichter zu treffen */
/* Tastaturfokus sichtbarer, ohne Hover zu stören */
.input:focus-within,
.btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255,122,0,.35);
}
@media (prefers-reduced-motion: reduce){
  *{ animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
@media (max-width: 480px){
  .card{
    max-width: 560px;
    width: 100%;
    margin: 0 auto;
    padding: 20px 16px;
    backdrop-filter: blur(8px);     /* etwas weniger Blur für Performance */
  }

  .brand h1{ font-size: 20px; line-height: 1.2; }
  .sub{ font-size: .95rem; }

  label{ font-size: .95rem; }
  .input{ height: 52px; gap: 10px; }
  .input input{ font-size: 16px; }  /* gegen iOS-Zoom */

  .row{ flex-direction: column; align-items: stretch; gap: 10px; }
  .btn{ width: 100%; }
}
@media (max-width: 768px){
  .card{ border-radius: 18px; }
  .brand .logo{ width: 52px; height: 52px; border-radius: 14px; }
}
/* Chrome/Edge Autofill dunkel darstellen */
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px rgba(26,34,48,.92) inset !important;
  -webkit-text-fill-color: var(--text) !important;
  caret-color: var(--text) !important;
}
