/* ---------- Login (harmonized with register) ---------- */
:root{
  --bg:#f6f7fb; --ink:#0e1220; --muted:#667085; --line:#d7deea; --card:#ffffff;
  --brand:#d4a11d; --brand-600:#bd8f18; --ok:#16a34a; --err:#dc2626; --info:#0ea5e9; --info-600:#0284c7;
  --ring:0 0 0 4px rgba(212,161,29,.18); --shadow:0 18px 40px rgba(15,23,42,.08);
  --r:16px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--ink);
  font:15px/1.6 Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial;
  background:linear-gradient(180deg,#fbfcff 0,#f3f5fb 360px);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}

.wrap{max-width:520px;margin:56px auto;padding:0 18px}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:22px;
}

.head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.title{font-size:22px;font-weight:800;letter-spacing:.2px}
.sub{color:var(--muted);font-size:13.5px;margin:2px 0 14px}

.alert{
  display:flex;align-items:center;gap:10px;
  background:#fff4f2;border:1px solid #fec8bf;color:#b42318;
  padding:10px 12px;border-radius:12px;margin:0 0 12px;font-size:14px
}
.alert .count{font-weight:900;margin-left:6px}

/* ---------- Fields: visible & contrasted ---------- */
.fld{margin:0 0 12px}
.fld label{display:block;margin:0 0 6px;font-weight:800;font-size:14px;color:#0b1220}
.control{position:relative}

.input{
  width:100%;
  border:1px solid #c8d1e3;           /* stronger than --line */
  background:#fff;
  color:var(--ink);
  border-radius:12px;
  padding:12px 42px 12px 12px;        /* room for eye button */
  font:inherit;
  transition:border .18s, box-shadow .18s, background .18s, color .18s;
  outline:0;
  min-height:42px;
}
.input::placeholder{color:#9aa6bf}
.input:disabled{background:#f3f6fb;color:#8a96ad;border-color:#d5dceb;cursor:not-allowed}

/* Focus */
.input:focus{
  border-color:#e0c36f;
  box-shadow:var(--ring);
  background:#fff;
}

/* Invalid state */
.is-invalid{
  border-color:var(--err)!important;
  box-shadow:0 0 0 3px rgba(220,38,38,.14)!important;
  background:#fff5f5;
}

/* Password eye */
.pw-toggle{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  display:grid;place-items:center;width:36px;height:36px;border:none;background:transparent;
  border-radius:10px;cursor:pointer
}
.pw-toggle:hover{background:#f7f3e6}
.pw-toggle svg{width:20px;height:20px;stroke:#4b5563}

/* Actions */
.actions{margin-top:6px}
.btn{
  width:100%;
  background:var(--brand);color:#fff;border:none;border-radius:12px;padding:12px 18px;
  font-weight:900;cursor:pointer;
  box-shadow:0 10px 22px rgba(212,161,29,.18);
  transition:background .18s,transform .04s,opacity .18s
}
.btn:hover{background:var(--brand-600)}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.6;pointer-events:none}

/* Row links */
.row{display:flex;justify-content:space-between;align-items:center;margin-top:12px;gap:12px;flex-wrap:wrap}
.link{font-size:13px;color:var(--brand);font-weight:800;text-decoration:none}
.link:hover{text-decoration:underline}
.hint{color:var(--muted);font-size:13px;margin-top:6px}

/* Hint below button (optional) */
.login-hint{margin-top:12px;text-align:center;font-size:14px;color:var(--muted)}
.login-hint a{color:var(--brand);font-weight:800;text-decoration:none}
.login-hint a:hover{text-decoration:underline;color:var(--brand-600)}

/* Small screens */
@media (max-width:560px){
  .wrap{margin:28px auto}
  .card{padding:18px}
  .head{gap:6px; margin-bottom:10px; flex-wrap:wrap; align-items:flex-start}
  .title{font-size:18px; line-height:1.25; font-weight:900; letter-spacing:.1px}
}

/* Utility */
.hidden{display:none!important}
