*{margin:0;padding:0;box-sizing:border-box}*,*::before,*::after{box-sizing:inherit}html{box-sizing:border-box;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;font-size:1rem;font-weight:400;line-height:1.6;color:#1f2937;background-color:#f5f7fa;min-height:100vh;padding-bottom:60px}ul,ol{list-style:none}a{text-decoration:none;color:inherit}button{background:none;border:none;padding:0;font:inherit;cursor:pointer;outline:inherit}img{max-width:100%;height:auto;display:block}input,textarea,select,button{font:inherit;color:inherit}input:focus,textarea:focus,select:focus{outline:none}table{border-collapse:collapse;border-spacing:0;width:100%}body{font-family:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;background:linear-gradient(135deg, #A30711 0%, #63040A 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.5);width:100%;max-width:450px;overflow:hidden;border:3px solid hsla(0,0%,100%,.3)}.login-header{background:linear-gradient(135deg, #A30711 0%, #63040A 100%);color:#fff;padding:2.5rem 2rem;text-align:center}.login-header .logo{font-size:2.5rem;margin-bottom:.5rem}.login-header h1{font-size:1.8rem;font-weight:300;margin-bottom:.5rem}.login-header p{opacity:.9;font-size:.95rem}.login-body{padding:2.5rem 2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:#374151;font-weight:500;margin-bottom:.5rem;font-size:.95rem}.input-wrapper{position:relative}.input-wrapper .input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:1.1rem}.input-wrapper input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;transition:all .3s}.input-wrapper input:focus{outline:none;border-color:#e20917;box-shadow:0 0 0 3px rgba(226,9,23,.1)}.input-wrapper input::placeholder{color:#9ca3af}.checkbox-group{display:flex;align-items:center;margin-bottom:1.5rem}.checkbox-group input[type=checkbox]{width:18px;height:18px;margin-right:.5rem;cursor:pointer}.checkbox-group label{color:#4b5563;font-size:.9rem;cursor:pointer;user-select:none;margin:0}.forgot-password{text-align:center;margin-bottom:1.5rem}.forgot-password a{color:#e20917;text-decoration:none;font-size:.9rem;transition:color .3s}.forgot-password a:hover{color:#a30711;text-decoration:underline}.login-button{width:100%;padding:1rem;background:linear-gradient(135deg, #A30711 0%, #E20917 100%);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px rgba(163,7,17,.3)}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(226,9,23,.4)}.login-button:active{transform:translateY(0)}.login-button.loading{position:relative;pointer-events:none;font-size:0}.login-button.loading .spinner{display:inline-block}.login-button .spinner{display:none;width:20px;height:20px;border:3px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.divider{display:flex;align-items:center;justify-content:center;margin:2rem 0;color:#9ca3af;font-size:.9rem}.divider::before,.divider::after{content:"";flex:1;height:1px;background:#e5e7eb}.divider span{padding:0 1rem}.signup-link{text-align:center;color:#4b5563;font-size:.95rem}.signup-link a{color:#e20917;text-decoration:none;font-weight:600;transition:color .3s}.signup-link a:hover{color:#a30711;text-decoration:underline}.back-home{text-align:center;margin-top:1.5rem}.back-home a{color:#6b7280;text-decoration:none;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem;transition:color .3s}.back-home a:hover{color:#374151}.alert{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;display:none}.alert.show{display:block}.alert.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}@media(max-width: 480px){body{padding:1rem}.login-header{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}.login-body{padding:2rem 1.5rem}}
