*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --purple:#7B2FFF;--purple-dark:#5A1FCC;--pink:#FF3CAC;--pink-light:#FF6EC7;
  --navy:#0D0B1F;--navy2:#13102B;--navy3:#1A1640;
  --white:#FFFFFF;--gray:#9899A6;--card-bg:rgba(255,255,255,0.04);
  --card-border:rgba(255,255,255,0.08);--font:'Plus Jakarta Sans',sans-serif;
}
html{scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--navy);color:var(--white);min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;overflow-x:hidden;position:relative;}

body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle,rgba(123,47,255,0.1) 1px,transparent 1px);background-size:28px 28px;z-index:0;pointer-events:none;}

.orb{position:fixed;border-radius:50%;filter:blur(100px);z-index:0;pointer-events:none;}
.orb1{width:500px;height:500px;background:rgba(123,47,255,0.1);top:-150px;right:-100px;animation:floatOrb 12s ease-in-out infinite;}
.orb2{width:400px;height:400px;background:rgba(255,60,172,0.07);bottom:-100px;left:-100px;animation:floatOrb 10s ease-in-out infinite reverse;}
@keyframes floatOrb{0%,100%{transform:translate(0,0);}50%{transform:translate(20px,-20px);}}

.scan{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--purple),var(--pink),transparent);animation:scan 3s ease-in-out infinite;z-index:1;opacity:.4;}
@keyframes scan{0%{top:0;opacity:.4;}50%{opacity:.6;}100%{top:100vh;opacity:0;}}

.card{position:relative;z-index:2;background:var(--navy2);border:1px solid rgba(123,47,255,0.2);border-radius:24px;padding:3rem 2.5rem;max-width:440px;width:100%;box-shadow:0 40px 100px rgba(0,0,0,0.5),0 0 0 1px rgba(123,47,255,0.1);}
.card::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--purple),var(--pink),transparent);}

.logo-wrap{margin-bottom:1.8rem;display:flex;justify-content:center;}
.logo-wrap img{height:38px;width:auto;object-fit:contain;}

h1{font-family:'Syne',sans-serif;font-size:1.8rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.4rem;text-align:center;background:linear-gradient(135deg,#fff,rgba(255,255,255,0.75));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.subtitle{font-size:.88rem;color:var(--gray);text-align:center;margin-bottom:2rem;}

.form-group{margin-bottom:1.2rem;}
label{display:block;font-size:.82rem;font-weight:600;color:rgba(255,255,255,0.7);margin-bottom:.5rem;}
input{width:100%;padding:.85rem 1.1rem;background:rgba(255,255,255,0.04);border:1px solid var(--card-border);border-radius:12px;color:#fff;font-family:var(--font);font-size:.92rem;transition:border-color .2s,background .2s;}
input:focus{outline:none;border-color:var(--purple);background:rgba(123,47,255,0.06);}
input::placeholder{color:rgba(255,255,255,0.25);}

.btn{display:block;width:100%;padding:1rem;background:linear-gradient(135deg,var(--purple),var(--pink));border:none;border-radius:50px;color:#fff;font-family:var(--font);font-size:.98rem;font-weight:700;cursor:pointer;box-shadow:0 8px 24px rgba(123,47,255,0.3);transition:transform .2s,box-shadow .2s;margin-top:.5rem;}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(123,47,255,0.45);}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;}

.switch-link{text-align:center;margin-top:1.5rem;font-size:.85rem;color:var(--gray);}
.switch-link a{color:var(--pink-light);font-weight:600;text-decoration:none;}
.switch-link a:hover{text-decoration:underline;}

.error-msg{background:rgba(255,60,90,0.1);border:1px solid rgba(255,60,90,0.25);color:#ff8a9b;border-radius:10px;padding:.7rem 1rem;font-size:.82rem;margin-bottom:1.2rem;display:none;}
.error-msg.show{display:block;}

.success-msg{background:rgba(0,230,130,0.1);border:1px solid rgba(0,230,130,0.25);color:#4fffb0;border-radius:10px;padding:.7rem 1rem;font-size:.82rem;margin-bottom:1.2rem;display:none;}
.success-msg.show{display:block;}

.back-link{position:absolute;top:-2.5rem;left:0;font-size:.82rem;color:var(--gray);text-decoration:none;display:flex;align-items:center;gap:.4rem;transition:color .2s;}
.back-link:hover{color:#fff;}

@media(max-width:480px){
  .card{padding:2rem 1.5rem;}
  h1{font-size:1.5rem;}
}

/* Password field with eye toggle */
.password-wrap{position:relative;}
.password-wrap input{padding-right:3rem;}
.eye-btn{position:absolute;right:.9rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray);cursor:pointer;padding:.2rem;display:flex;align-items:center;transition:color .2s;}
.eye-btn:hover{color:#fff;}

/* Forgot password link */
.forgot-link{display:block;text-align:right;font-size:.8rem;color:var(--gray);text-decoration:none;margin-top:-.6rem;margin-bottom:1.2rem;transition:color .2s;}
.forgot-link:hover{color:var(--pink-light);}
