.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6}.login-box{background-color:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 4px 6px rgba(0,0,0,.1);width:100%;max-width:24rem}.login-title{font-size:1.5rem;font-weight:700;color:#1d4ed8}.login-subtitle,.login-title{text-align:center;margin-bottom:1.5rem}.login-subtitle{color:#4b5563;margin-top:.5rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;color:#374151;margin-bottom:.5rem}.form-input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.25rem}.form-input:focus{outline:none;ring:2px;ring-color:#2563eb}.form-hint{font-size:.75rem;color:#6b7280;margin-top:.25rem}.btn{width:100%;background-color:#2563eb;color:#fff;padding:.5rem 1rem;border-radius:.25rem;transition:background-color .2s}.btn:hover{background-color:#1d4ed8}.btn:disabled{background-color:#93c5fd}.message{padding:1rem;margin-bottom:1rem;border-left-width:4px}.message-success{background-color:#d1fae5;border-color:#10b981;color:#047857}.message-error{background-color:#fee2e2;border-color:#ef4444;color:#b91c1c}.message-info{background-color:#dbeafe;border-color:#3b82f6;color:#1e40af}