:root{
  --blue:#0B4F92;
  --text:#1f2937;
  --muted:#6b7280;
  --bg:#eef2f3;   /* gris/vert clair comme la capture */
  --line:#e5e7eb;
  --card:#ffffff;
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
}

/* a11y helper */
.sr-only{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* Top bar */
.login-top{
  background:#fff;
  border-bottom:1px solid var(--line);
}
.login-top__inner{
  height:72px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.login-top__logo{
  height:30px;
  display:block;
}

/* Page layout */
.login-page{
  min-height: calc(100vh - 72px);
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:48px 16px 60px;
  gap:26px;
}

/* White card */
.login-card{
  width:min(520px, 100%);
  background:var(--card);
  border:1px solid var(--line);
  border-radius:2px;           /* très léger, comme screenshot */
  padding:34px 44px 28px;
}

.login-title{
  font-size:34px;
  font-weight:700;
  color:#3b3b3b;
  margin-bottom:18px;
}

/* Form */
.login-form{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.field input{
  width:100%;
  height:52px;
  padding:0 16px;
  border:1px solid #cfcfcf;
  border-radius:3px;
  font-size:18px;
  outline:none;
  background:#fff;
}
.field input:focus{
  border-color:#9aa8b5;
  box-shadow:0 0 0 3px rgba(11,79,146,.12);
}

.remember{
  display:flex;
  align-items:center;
  gap:14px;
  color:#3f3f3f;
  font-size:16px;
}
.remember input{
  width:18px;height:18px;
}

/* LOG IN button (wide, light gray) */
.btn-login{
  width:100%;
  height:42px;
  border:1px solid #e6e6e6;
  background:#f2f2f2;
  color:#2f2f2f;
  font-weight:700;
  letter-spacing:.04em;
  cursor:pointer;
}
.btn-login:hover{
  background:#ededed;
}

/* Links under button */
.login-links{
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:2px;
  font-size:15px;
  color:#3f3f3f;
}
.login-links a{
  color:#0b61d8;
  text-decoration:underline;
}

/* Bottom CTA button */
.cta-wrap{
  width:min(520px, 100%);
}
.btn-open{
  display:flex;
  align-items:center;
  justify-content:center;
  height:44px;
  border:2px solid var(--blue);
  color:var(--blue);
  text-decoration:none;
  font-weight:800;
  letter-spacing:.02em;
  background:transparent;
}
.btn-open:hover{
  background:rgba(11,79,146,.06);
}

.login-error{
  margin: 10px 0 14px;
  padding: 10px 12px;
  border: 1px solid #f1b4b4;
  background: #fff1f1;
  color: #8a1f1f;
  font-size: 14px;
  border-radius: 8px;
}



/* Responsive */
@media (max-width:560px){
  .login-card{padding:26px 18px}
  .login-title{font-size:28px}
  .field input{font-size:16px}
}
