/* ============================================================
   RentyQ — login.css
   Écran d'authentification, panel de connexion, formulaires
   ============================================================ */

/* ── Auth screen (écran plein) ── */
#auth-screen{display:none;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:#F5F4FF}

#auth-screen.rq-auth-screen{
  display:none;
  min-height:100vh;
  width:100vw;
  position:relative;
  overflow:hidden;
  color:#fff;
  background-color:#040319;
  background-image:url('../assets/bg-login-v2.png');
  background-size:100% 100%;
  background-position:center center;
  background-repeat:no-repeat;
  background-attachment:scroll;
  margin:0;
  padding:0;
  isolation:isolate;
}

#auth-screen.rq-auth-screen::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background:
    linear-gradient(90deg,rgba(4,2,18,.72) 0%,rgba(4,2,18,.36) 30%,rgba(4,2,18,.02) 62%,rgba(15,7,40,.74) 100%),
    radial-gradient(circle at 80% 45%,rgba(236,72,153,.16),transparent 32%);
  pointer-events:none;
}

#auth-screen.rq-auth-screen::after{display:none}

/* ── Login panel ── */
.rq-login-panel{
  position:absolute;
  z-index:2;
  top:clamp(18px,3vh,34px);
  bottom:clamp(18px,3vh,34px);
  left:clamp(28px,2vw,44px);
  height:auto;
  max-height:calc(100vh - 36px);
  width:clamp(440px,31vw,560px);
  min-width:0;
  padding:clamp(28px,3.2vh,42px) clamp(32px,2.9vw,58px);
  display:flex;
  flex-direction:column;
  border-radius:26px;
  background:#040319;
  border:1px solid rgba(168,85,247,.48);
  box-shadow:0 28px 90px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  overflow:hidden;
  scrollbar-width:thin;
}

/* ── Logo login (classe unique, sans inline style) ── */
.login-logo{
  width:100%;
  max-width:360px;
  height:auto;
  display:block;
  margin:0 auto 12px auto;
  clip-path:none;
  filter:drop-shadow(0 14px 28px rgba(236,72,153,.28));
}

/* Conteneur du logo dans le panel */
.rq-brand{
  display:block;
  margin-bottom:clamp(18px,2.8vh,34px);
  width:100%;
}

/* ── Texte intro ── */
.rq-auth-copy p{
  font-size:clamp(13px,1.05vw,15px);
  line-height:1.55;
  margin-bottom:clamp(18px,2.6vh,28px);
  color:rgba(255,255,255,.76);
}

/* ── Champs ── */
.rq-form-block{width:100%}
.rq-field{margin-bottom:clamp(12px,1.7vh,18px)}
.rq-field label,.rq-label-row label{display:block;color:#fff;font-size:14px;font-weight:500;margin-bottom:9px;text-transform:none;letter-spacing:0}
.rq-input-wrap{position:relative;display:flex;align-items:center}
.rq-input-wrap i{position:absolute;left:16px;font-size:20px;color:#A855F7;opacity:.95;pointer-events:none}
.rq-input-wrap input{
  width:100%;height:clamp(46px,5.4vh,54px);padding:0 48px 0 50px;border-radius:11px;
  border:1px solid rgba(255,255,255,.25);background:rgba(8,8,30,.54);color:#fff;
  font-size:16px;font-family:inherit;outline:none;transition:border-color .15s,background .15s,box-shadow .15s;
}
.rq-input-wrap input::placeholder{color:rgba(255,255,255,.46)}
.rq-input-wrap input:-webkit-autofill,
.rq-input-wrap input:-webkit-autofill:hover,
.rq-input-wrap input:-webkit-autofill:focus{
  -webkit-text-fill-color:#fff !important;
  caret-color:#fff !important;
  box-shadow:0 0 0 1000px rgba(6,8,25,.92) inset !important;
  transition:background-color 9999s ease-in-out 0s !important;
}
.rq-eye{position:absolute;right:13px;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:0;background:transparent;color:rgba(255,255,255,.46);cursor:pointer;border-radius:8px}
.rq-eye:hover{background:rgba(255,255,255,.06);color:#fff}
.rq-eye i{position:static;font-size:19px;color:currentColor;opacity:1;pointer-events:auto}

/* ── Options (remember me / forgot) ── */
.rq-options{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 clamp(16px,2.2vh,24px)}
.rq-check{display:flex;align-items:center;gap:9px;font-size:14px;color:rgba(255,255,255,.78);cursor:pointer;user-select:none}
.rq-check input{width:15px;height:15px;appearance:none;border:1px solid #A78BFA;background:transparent;border-radius:4px;display:grid;place-content:center;accent-color:#A855F7}
.rq-check input:checked{background:#8B5CF6;box-shadow:inset 0 0 0 3px rgba(8,3,24,.9)}
.rq-options button,.rq-request button,.rq-back{border:0;background:transparent;color:#C084FC;font-family:inherit;font-size:14px;cursor:pointer;text-decoration:none}
.rq-options button:hover,.rq-request button:hover,.rq-back:hover{text-decoration:underline;color:#F0ABFC}

/* ── Bouton principal ── */
.rq-primary{
  width:100%;height:clamp(48px,5.8vh,56px);border:0;border-radius:11px;
  background:var(--rq-grad);
  color:white;font-size:16px;
  font-family:'Sora',sans-serif;font-weight:800;
  cursor:pointer;
  box-shadow:0 14px 36px rgba(109,40,217,.28),0 8px 24px rgba(236,72,153,.22);
  transition:transform .15s,filter .15s,opacity .15s;
}
.rq-primary:hover{transform:translateY(-1px);filter:brightness(1.05)}
.rq-primary:disabled{opacity:.65;cursor:not-allowed;transform:none}

/* ── Séparateur ── */
.rq-separator{display:flex;align-items:center;gap:18px;margin:clamp(16px,2.1vh,22px) 0;color:rgba(255,255,255,.72);font-size:14px}
.rq-separator span{height:1px;flex:1;background:rgba(255,255,255,.17)}
.rq-separator em{font-style:normal;color:rgba(255,255,255,.72)}

/* ── Bouton Google ── */
.rq-google{
  width:100%;height:clamp(46px,5.4vh,54px);border-radius:11px;border:1px solid rgba(255,255,255,.23);
  background:rgba(2,6,23,.38);color:#fff;font-size:15px;font-weight:540;font-family:inherit;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:12px;transition:background .15s,border-color .15s;
}
.rq-google:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.34)}

/* ── Spacer + footer ── */
.rq-spacer{flex:1 1 auto;min-height:8px}
.rq-request{text-align:center;color:rgba(255,255,255,.72);font-size:15px;margin-top:clamp(12px,2vh,24px)}
.rq-request button{font-size:15px;margin-left:14px;color:#F0ABFC;font-weight:700}
.rq-back{width:100%;margin-top:14px;padding:10px 0;color:rgba(255,255,255,.62)}
.rq-register{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.10)}

/* ── Messages ── */
.rq-message{
  margin-top:12px;padding:12px;border-radius:10px;font-size:13px;
  border:1px solid rgba(244,114,182,.22);background:rgba(244,114,182,.12);color:#FDA4AF;
}
.auth-success.rq-message{border-color:rgba(16,185,129,.25);background:rgba(16,185,129,.12);color:#86EFAC}

/* ── Stats décoratives (desktop) ── */
.rq-side-stats{
  display:none;
  position:absolute;z-index:3;
  top:clamp(42px,6vh,72px);right:clamp(34px,3.2vw,64px);bottom:clamp(42px,6vh,72px);
  width:clamp(150px,10vw,196px);
  display:grid;grid-template-rows:repeat(4,minmax(0,1fr));gap:clamp(14px,2vh,22px);
  pointer-events:none;
}
.rq-stat-card{
  border:1px solid rgba(168,85,247,.28);border-radius:20px;
  background:linear-gradient(180deg,rgba(21,13,48,.58),rgba(8,7,28,.72));
  box-shadow:0 18px 50px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:#fff;padding:12px 8px;
}
.rq-stat-card i{font-size:clamp(34px,2.8vw,48px);color:#A855F7;margin-bottom:clamp(8px,1vh,12px);filter:drop-shadow(0 0 18px rgba(168,85,247,.38))}
.rq-stat-card strong{font-size:clamp(26px,2.1vw,36px);line-height:1.05;font-weight:850;letter-spacing:-.8px}
.rq-stat-card span{font-size:clamp(14px,1.1vw,17px);line-height:1.35;color:rgba(255,255,255,.86);margin-top:6px}

/* ── Old auth-card (fallback) ── */
.auth-card{background:white;border-radius:14px;padding:2rem;width:100%;max-width:380px;border:1px solid #E8E8EE}
.auth-logo{font-size:26px;font-weight:700;margin-bottom:2px}
.auth-logo span{background:#534AB7;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-tagline{font-size:13px;color:#8A8A99;margin-bottom:1.5rem;font-style:italic}

/* ══ ONBOARDING RentyQ — Bienvenue ══ */
.rq-onb-panel{
  background:#0F172A;
  border:1px solid rgba(168,85,247,.38);
  border-radius:24px;
  padding:clamp(28px,4vh,44px) clamp(28px,3.5vw,48px);
  width:100%;max-width:520px;
  box-shadow:0 32px 100px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08);
  position:relative;
  overflow:hidden;
}
.rq-onb-panel::after{
  content:'';position:absolute;right:-80px;top:-80px;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(236,72,153,.15),transparent 60%);
  pointer-events:none;
}
.rq-onb-progress-wrap{
  height:3px;background:rgba(255,255,255,.1);border-radius:3px;margin-bottom:10px;
}
.rq-onb-progress-fill{
  height:100%;background:linear-gradient(90deg,#6D28D9,#EC4899);border-radius:3px;
  transition:width .4s ease;width:0%;
}
.rq-onb-step-label{
  font-size:11px;font-weight:700;color:rgba(255,255,255,.35);
  text-transform:uppercase;letter-spacing:.6px;margin-bottom:20px;min-height:16px;
}
.rq-onb-step{
  display:flex;flex-direction:column;align-items:stretch;
}
.rq-onb-eva-intro{
  display:flex;align-items:center;gap:10px;
  background:rgba(109,40,217,.18);border:1px solid rgba(168,85,247,.22);
  border-radius:12px;padding:10px 14px;margin-bottom:22px;
  font-size:13px;color:rgba(255,255,255,.75);line-height:1.4;
}
.rq-onb-eva-dot{
  width:8px;height:8px;border-radius:50%;background:#A855F7;flex-shrink:0;
  box-shadow:0 0 0 4px rgba(168,85,247,.2);
  animation:rqOnbPulse 1.5s infinite;
}
@keyframes rqOnbPulse{0%,100%{box-shadow:0 0 0 4px rgba(168,85,247,.2)}50%{box-shadow:0 0 0 8px rgba(168,85,247,.06)}}
.rq-onb-title{
  font-family:'Sora',sans-serif;font-size:clamp(20px,2.4vw,26px);font-weight:900;
  color:#fff;letter-spacing:-.5px;line-height:1.2;margin:0 0 10px 0;
}
.rq-onb-sub{
  font-size:14px;color:rgba(255,255,255,.65);line-height:1.6;margin:0 0 22px 0;
}
.rq-onb-choices{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.rq-onb-choice{
  display:flex;align-items:center;gap:14px;
  border:1.5px solid rgba(255,255,255,.12);border-radius:14px;
  padding:13px 16px;cursor:pointer;
  background:rgba(255,255,255,.04);
  transition:border-color .15s,background .15s;
}
.rq-onb-choice:hover{border-color:rgba(168,85,247,.5);background:rgba(109,40,217,.14);}
.rq-onb-choice--active{border-color:#7C3AED;background:rgba(109,40,217,.22);}
.rq-onb-choice-icon{font-size:20px;flex-shrink:0;width:30px;text-align:center;}
.rq-onb-choice-label{font-size:14px;font-weight:700;color:#fff;}
.rq-onb-choice-desc{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px;}
.rq-onb-cta{
  width:100%;height:50px;border:none;border-radius:14px;
  background:linear-gradient(135deg,#6D28D9,#EC4899);
  color:#fff;font-size:15px;font-weight:800;font-family:'Sora',sans-serif;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 8px 24px rgba(109,40,217,.28);
  transition:filter .15s,transform .15s,opacity .15s;
  margin-bottom:10px;
}
.rq-onb-cta:hover:not(:disabled){filter:brightness(1.07);transform:translateY(-1px);}
.rq-onb-cta:disabled{opacity:.35;cursor:not-allowed;transform:none;}
.rq-onb-cta-final{background:linear-gradient(135deg,#4C1D95,#6D28D9,#EC4899);}
.rq-onb-skip{
  width:100%;border:none;background:transparent;
  font-size:12px;color:rgba(255,255,255,.3);cursor:pointer;
  font-family:inherit;padding:6px 0;
  transition:color .15s;
}
.rq-onb-skip:hover{color:rgba(255,255,255,.55);}
.rq-onb-eva-badge{
  display:inline-block;background:linear-gradient(135deg,#F3E8FF,#FCE7F3);
  color:#6D28D9;font-size:12px;font-weight:800;border-radius:999px;
  padding:5px 14px;letter-spacing:.3px;margin-bottom:16px;align-self:flex-start;
}
.rq-onb-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:22px;}
.rq-onb-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:14px;text-align:center;
}
.rq-onb-card-icon{font-size:24px;margin-bottom:8px;}
.rq-onb-card-title{font-size:13px;font-weight:800;color:#fff;margin-bottom:5px;font-family:'Sora',sans-serif;}
.rq-onb-card-desc{font-size:11px;color:rgba(255,255,255,.5);line-height:1.45;}
