*{margin:0;padding:0;box-sizing:border-box}:root{--primary:#10b981;--primary-dark:#059669;--primary-light:#34d399;--secondary:#f59e0b;--background:#f8fafc;--surface:#ffffff;--surface-light:#f1f5f9;--text:#0f172a;--text-muted:#64748b;--error:#ef4444;--success:#22c55e;--border:rgba(0,0,0,0.1)}.bg-gradient{position:fixed;inset:0;background:radial-gradient(circle at 20% 50%,rgba(16,185,129,.2) 0,transparent 50%),radial-gradient(circle at 80% 80%,rgba(245,158,11,.15) 0,transparent 50%),radial-gradient(circle at 40% 20%,rgba(139,92,246,.1) 0,transparent 50%)}.bg-gradient,.orb{pointer-events:none}.orb{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5;animation:float 20s ease-in-out infinite}.orb1{width:300px;height:300px;background:var(--primary);top:-150px;left:-150px;animation-delay:0s}.orb2{width:200px;height:200px;background:var(--secondary);bottom:-100px;right:-100px;animation-delay:5s}.orb3{width:250px;height:250px;background:#8b5cf6;top:50%;left:50%;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.shell{position:relative;z-index:10;width:100%;max-width:500px;margin:72px auto 24px;background:rgba(255,255,255,.8);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:24px;padding:2.5rem;box-shadow:0 20px 25px -5px rgba(0,0,0,.3),0 10px 10px -5px rgba(0,0,0,.04),inset 0 1px 0 0 rgba(255,255,255,.1);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04)}.brand{text-align:center;margin-bottom:2rem;flex-direction:column;gap:1rem}.brand,.logo{display:flex;align-items:center}.logo{width:80px;height:80px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:20px;justify-content:center;box-shadow:0 10px 30px -5px rgba(16,185,129,.3);position:relative;overflow:hidden;padding:10px}.logo:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);transform:translateX(-100%);animation:shimmer 3s infinite}@keyframes shimmer{to{transform:translateX(100%)}}.logo svg{width:100%;height:100%;position:relative;z-index:1;color:#fff}.logo svg path{fill:white!important;stroke:white!important}.logo{color:#fff}.brand h1{font-size:1.875rem;font-weight:700;margin:0;background:linear-gradient(135deg,var(--primary-light),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand p{color:var(--text-muted);font-size:.875rem;margin:0}form{display:flex;flex-direction:column;gap:1.5rem}.subtitle{margin:0 0 12px}.successState{gap:12px}.field,.successState{display:flex;flex-direction:column}.field{gap:.5rem}.field label{font-size:.875rem;font-weight:500;color:var(--text)}.control{position:relative;display:flex;align-items:center;background:var(--surface);border:2px solid transparent;border-radius:12px;transition:all .3s ease;overflow:hidden}.control:focus-within{border-color:var(--primary);background:var(--surface-light);box-shadow:0 0 0 4px rgba(16,185,129,.1)}.control input{flex:1 1;padding:.75rem 1rem;background:transparent;border:none;outline:none;color:var(--text);font-size:1rem}.control input::placeholder{color:var(--text-muted)}.control-pass{padding-right:.5rem}.reveal{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.reveal:hover{color:var(--text);background:rgba(255,255,255,.05)}.rowSign{justify-content:space-between;margin:-.5rem 0}.remember,.rowSign{display:flex;align-items:center}.remember{gap:.5rem;font-size:.875rem;color:var(--text)}.remember input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary);cursor:pointer}.rowSign a{color:var(--primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s}.rowSign a:hover{color:var(--primary-light);text-decoration:underline}.btn{width:100%;padding:.875rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:white;box-shadow:0 10px 20px -5px rgba(16,185,129,.4)}.btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 30px -5px rgba(16,185,129,.5)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.7;cursor:not-allowed}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:active:not(:disabled):before{width:300px;height:300px}.or{position:relative;text-align:center;margin:.5rem 0;color:var(--text-muted);font-size:.75rem}.or:after,.or:before{content:"";position:absolute;top:50%;width:calc(50% - 2rem);height:1px;background:var(--surface-light)}.or:before{left:0}.or:after{right:0}.alt{display:flex;flex-direction:column;gap:1rem}.btn-alt{width:100%;padding:.875rem;background:var(--surface);color:var(--text);border:1px solid var(--surface-light);border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-alt:hover{background:var(--surface-light);transform:translateY(-2px);box-shadow:0 5px 15px -3px rgba(0,0,0,.3)}.legal{text-align:center;color:var(--text-muted);font-size:.75rem;margin-top:1rem}.legal a{color:var(--primary);text-decoration:none}.legal a:hover{text-decoration:underline}.footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--surface-light);color:var(--text-muted);font-size:.875rem}.error-message{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--error);padding:.75rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error{color:#b91c1c}.error,.ok{font-size:15px}.ok{color:#065f46}.error.compact{margin-top:4px}.actions{display:flex;align-items:center;gap:12px}.actions.between{justify-content:space-between}.actions.end{justify-content:flex-end}.actions.spaced{margin-top:4px}@keyframes spin{to{transform:rotate(1turn)}}.spinner{display:inline-block;width:20px;height:20px;border-radius:50%;border:3px solid rgba(255,255,255,.3);border-top-color:white;animation:spin .8s linear infinite}@media (max-width:480px){.shell{padding:2rem 1.5rem;margin:64px 12px 16px}.brand h1{font-size:1.5rem}.logo{width:60px;height:60px}}