.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5}.login-page .captcha-container{display:flex;justify-content:center;margin:15px 0}.login-page .loading-captcha{display:flex;justify-content:center;align-items:center;height:78px;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;font-size:14px;color:#666}.login-page .invisible-captcha{position:absolute;bottom:-9999px;left:-9999px;visibility:hidden}.login-page .loading-spinner{display:flex;justify-content:center;align-items:center;height:100px;margin:20px 0}.login-page .spinner{border-radius:50%;border:4px solid rgba(0,0,0,.1);border-top-color:#4285f4;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-page .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;z-index:1000}.login-page .modal-content{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.2);max-width:500px;width:90%;text-align:center}.login-page .modal-content h2{margin-top:0;margin-bottom:10px;color:#333}.login-page .modal-content p{margin-bottom:20px;color:#666}.login-page .modal-actions{display:flex;justify-content:center;margin-top:20px}.login-page .cancel-button{padding:10px 20px;border:none;border-radius:4px;background-color:#f5f5f5;color:#333;font-weight:500;cursor:pointer;transition:background-color .2s}.login-page .cancel-button:hover:not(:disabled){background-color:#e0e0e0}.login-page .login-container{width:100%;max-width:400px;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.login-page .login-container h1{margin-bottom:.5rem;color:#333;text-align:center}.login-page .login-container p{margin-bottom:1.5rem;color:#666;text-align:center}.login-page .login-form{display:flex;flex-direction:column;gap:1rem}.login-page .form-group{display:flex;flex-direction:column;gap:.5rem}.login-page .form-group label{font-weight:500;color:#333;font-size:.9rem}.login-page .form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.login-page .form-group input:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.2)}.login-page .form-actions{display:flex;gap:1rem;margin-top:1rem}.login-page .login-button,.login-page .register-button{flex:1 1;padding:.75rem;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.login-page .login-button{background-color:#4285f4;color:#fff}.login-page .login-button:hover:not(:disabled){background-color:#3367d6}.login-page .register-button{background-color:#f5f5f5;color:#333;border:1px solid #ddd}.login-page .register-button:hover:not(:disabled){background-color:#ebebeb}.login-page button:disabled{opacity:.6;cursor:not-allowed}.login-page .error-message,.login-page .success-message{padding:1rem;margin-bottom:1rem;border-radius:4px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.login-page .error-message{background-color:#ffebee;color:#d32f2f}.login-page .err-msg{font-weight:700;font-size:.8rem;color:#d32f2f}.login-page .success-message{background-color:#e8f5e9;color:#2e7d32}.login-page .error-message button,.login-page .success-message button{padding:.4rem .8rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background-color .2s}.login-page .error-message button{background-color:#d32f2f;color:#fff}.login-page .error-message button:hover{background-color:#b71c1c}.login-page .success-message button{background-color:#2e7d32;color:#fff}.login-page .success-message button:hover{background-color:#1b5e20}