@import url('/css/csp-utilities.css');

:root{
  --bg:#F5F5F7;--surface:#FFFFFF;--card:#FFFFFF;
  --border-v2:#E5E5EA;--border2:#D1D1D6;
  --accent-v2:#1B4FCC;
  --cream-v2:#1D1D1F;--c2:#3C3C43;--muted-v2:#86868B;
  --red:#C0392B;--rdim:#FFF1F0;
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.05);
}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--cream-v2);
  font-family:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.login-topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
  display:flex;
  align-items:center;
  min-height:52px;
  padding:10px max(20px, env(safe-area-inset-right)) 10px max(20px, env(safe-area-inset-left));
  background:rgba(245,245,247,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(28,26,20,.08);
}
.login-back{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  font-weight:600;
  color:var(--accent-v2);
  text-decoration:none;
  padding:8px 12px;
  margin:-8px -12px;
  border-radius:10px;
  transition:background .15s, color .15s;
}
.login-back:hover{background:rgba(27,79,204,.08);color:#1544b8}
#login-screen{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:72px 20px 20px;
}
.login-box{
  width:420px;
  max-width:100%;
  background:#FFFFFF;
  border:1px solid rgba(28,26,20,0.08);
  border-radius:16px;
  padding:40px;
  box-shadow:var(--shadow-md);
  animation:fadeUp .4s ease;
}
.login-logo{
  font-family:'Fraunces',Georgia,serif;
  font-weight:400;
  font-style:italic;
  font-size:32px;
  color:var(--cream-v2);
  letter-spacing:-.03em;
  margin-bottom:4px;
}
.login-sub{
  font-size:14px;
  color:var(--muted-v2);
  margin-bottom:28px;
}

/* Tabs : segmented control */
.auth-tabs{
  display:flex;
  gap:4px;
  padding:4px;
  background:#F5F5F7;
  border-radius:10px;
  margin-bottom:24px;
}
.login-tab{
  flex:1;
  padding:10px 14px;
  background:transparent;
  border:none;
  border-radius:8px;
  color:var(--muted-v2);
  font-family:inherit;
  font-size:13.5px;
  font-weight:600;
  letter-spacing:-0.01em;
  cursor:pointer;
  transition:background .2s ease, color .2s ease, box-shadow .2s ease;
}
.login-tab:hover:not(.active){color:var(--cream-v2)}
.login-tab.active{
  background:#FFFFFF;
  color:var(--cream-v2);
  box-shadow:0 1px 2px rgba(0,0,0,.04);
}

/* Tab sections */
.tab-section{display:none}
.tab-section.active{display:block}

/* Field block */
.field{margin-bottom:14px}
.field label{
  display:block;
  font-size:12px;
  font-weight:600;
  color:var(--c2);
  letter-spacing:.02em;
  margin-bottom:6px;
}
.field input{
  width:100%;
  background:#FFFFFF;
  border:1.5px solid #E0DDD8;
  border-radius:10px;
  padding:12px 14px;
  color:var(--cream-v2);
  font-family:inherit;
  font-size:14px;
  transition:border-color .15s, box-shadow .15s;
  outline:none;
}
.field input:focus{
  border-color:var(--accent-v2);
  box-shadow:0 0 0 3px rgba(27,79,204,.10);
}

/* Field row : label + lien "Oublié ?" */
.field-row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:6px;
}
.field-row label{margin-bottom:0}
.forgot-inline{
  font-size:12px;
  color:var(--muted-v2);
  text-decoration:none;
  transition:color .15s ease;
}
.forgot-inline:hover{color:var(--accent-v2)}

/* Submit */
.btn-login{
  width:100%;
  background:var(--accent-v2);
  border:none;
  border-radius:10px;
  padding:14px;
  color:#fff;
  font-family:inherit;
  font-size:15px;
  font-weight:600;
  cursor:pointer;
  margin-top:12px;
  transition:background .18s ease, transform .12s ease, box-shadow .18s ease;
}
.btn-login:hover{background:#1640A8;box-shadow:0 4px 12px rgba(27,79,204,.20)}
.btn-login:active{transform:scale(.98)}
.btn-login:disabled{opacity:.6;cursor:default;transform:none}

/* Status (erreur / succès) */
.login-status{
  margin-top:14px;
  padding:10px 14px;
  border-radius:8px;
  font-size:13px;
  line-height:1.5;
  display:none;
  text-align:center;
}
.login-status.err{
  background:var(--rdim);
  color:var(--red);
  border:1px solid rgba(192,57,43,0.18);
  display:block;
}
.login-status.ok{
  background:rgba(27,79,204,0.08);
  color:var(--accent-v2);
  border:1px solid rgba(27,79,204,0.18);
  display:block;
}

/* Footnote */
.auth-footnote{
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid var(--border-v2);
  font-size:13px;
  text-align:center;
  color:var(--muted-v2);
}
.auth-footnote a{
  color:var(--accent-v2);
  text-decoration:none;
  font-weight:600;
}
.auth-footnote a:hover{text-decoration:underline}

/* Modal reset mot de passe */
.reset-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.35);
  z-index:1000;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.reset-overlay.open{display:flex}
.reset-modal{
  background:#fff;
  border-radius:16px;
  padding:32px;
  width:100%;max-width:380px;
  box-shadow:0 8px 40px rgba(0,0,0,.18);
}
.reset-modal h3{
  font-size:18px;font-weight:700;
  letter-spacing:-0.02em;
  color:var(--cream-v2);
  margin-bottom:6px;
}
.reset-modal p{font-size:13px;color:var(--muted-v2);margin-bottom:16px;line-height:1.5}
.reset-modal input{
  width:100%;border:1.5px solid #E0DDD8;
  border-radius:10px;padding:12px 14px;
  font-family:inherit;font-size:14px;
  color:var(--cream-v2);outline:none;
  transition:border-color .15s,box-shadow .15s;
  margin-bottom:12px;
}
.reset-modal input:focus{border-color:var(--accent-v2);box-shadow:0 0 0 3px rgba(27,79,204,.10)}
.reset-modal-btns{display:flex;gap:8px}
.reset-modal-btns button{
  flex:1;padding:11px;border-radius:10px;
  font-family:inherit;font-size:14px;font-weight:600;
  cursor:pointer;border:none;transition:background .15s;
}
.btn-reset-cancel{background:#F5F5F7;color:var(--c2)}
.btn-reset-cancel:hover{background:#E5E5EA}
.btn-reset-send{background:var(--accent-v2);color:#fff}
.btn-reset-send:hover{background:#1640A8}
.btn-reset-send:disabled{opacity:.6;cursor:default}
.reset-msg{font-size:12.5px;margin-top:10px;text-align:center}
.reset-msg.ok{color:var(--accent-v2)}
.reset-msg.err{color:var(--red)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:0.01ms !important;animation-duration:0.01ms !important}
