*{box-sizing:border-box;margin:0;padding:0}.portal-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.login-container{background:#fff;border-radius:1rem;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 20px 25px -5px #0003}.login-header{text-align:center;margin-bottom:2rem}.login-header .logo{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:1rem;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;font-size:2.5rem;display:flex;overflow:hidden}.login-header .logo img{width:100%;height:auto}.login-header h1{color:#0f172a;margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.login-header p{color:#64748b;font-size:.9375rem}.tabs{border-bottom:2px solid #e2e8f0;gap:.5rem;margin-bottom:1.5rem;display:flex}.tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:.875rem;font-size:1rem;font-weight:600;transition:all .3s}.tab.active{color:#667eea;border-bottom-color:#667eea}.form-group{margin-bottom:1.5rem}.form-group label{color:#0f172a;margin-bottom:.5rem;font-size:.9375rem;font-weight:500;display:block}.input-wrapper{position:relative}.input-wrapper i{color:#64748b;font-size:1.125rem;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.form-control{border:2px solid #e2e8f0;border-radius:.5rem;width:100%;padding:.875rem 1rem .875rem 3rem;font-size:.9375rem;transition:all .3s}.form-control:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.btn-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.875rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-submit:active{transform:translateY(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.alert{border-radius:.5rem;margin-bottom:1.5rem;padding:.875rem 1rem;display:none}.alert.show{display:block}.alert-error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.alert-success{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;color:#64748b;margin-top:2rem;font-size:.875rem}.form-container{display:none}.form-container.active{display:block}.forgot-password{text-align:right;margin-bottom:1rem}.forgot-password a{color:#667eea;font-size:.875rem;text-decoration:none}.forgot-password a:hover{text-decoration:underline}.setup-header{text-align:center;border-bottom:2px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.5rem}.setup-icon{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;margin:0 auto 1rem;font-size:2rem;display:flex;box-shadow:0 8px 16px #667eea4d}.setup-header h3{color:#0f172a;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.setup-description{color:#64748b;font-size:.9rem}.setup-steps{background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-radius:.75rem;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;display:flex}.step{opacity:.4;align-items:center;gap:.75rem;transition:all .3s;display:flex}.step.active{opacity:1}.step.completed{opacity:.7}.step-number{color:#64748b;background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;transition:all .3s;display:flex}.step.active .step-number{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 12px #667eea4d}.step.completed .step-number{color:#fff;background:#667eea}.step.completed .step-number:after{content:"";font-family:"Font Awesome 6 Free";font-weight:900}.step-divider{background:#e2e8f0;flex:1;height:2px;margin:0 .5rem}.setup-step-content{display:none}.setup-step-content.active{animation:.4s fadeInUp;display:block}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group label i{color:#667eea;margin-right:.5rem}.input-hint{color:#64748b;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.8125rem;display:flex}.input-hint i{color:#3b82f6}.otp-sent-indicator{color:#3730a3;background:#e0e7ff;border:2px solid #a5b4fc;border-radius:.5rem;align-items:center;gap:.5rem;margin-top:1rem;padding:.875rem;font-weight:600;animation:.3s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.otp-sent-indicator i{color:#667eea}.otp-input{text-align:center;letter-spacing:.5rem;font-size:1.5rem;font-weight:600}.toggle-password{color:#64748b;cursor:pointer;background:0 0;border:none;padding:.5rem;transition:all .2s;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.toggle-password:hover{color:#667eea}.button-group{gap:1rem;margin-top:1.5rem;display:flex}.btn-back{color:#64748b;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:.5rem;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.875rem;font-size:.9375rem;font-weight:600;transition:all .3s;display:flex}.btn-back:hover{color:#667eea;border-color:#667eea}.btn-next{flex:2}@media (max-width:768px){.step-divider{margin:0 .25rem}}@media (max-width:480px){.login-container{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}.setup-steps{padding:1rem}.step-number{width:36px;height:36px;font-size:.875rem}.button-group{flex-direction:column}.btn-back,.btn-next{flex:1}}
