#root{padding:0rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.login-page{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 1rem;overflow:hidden;position:relative;width:100%;min-height:100vh}.login-card{width:100%;max-width:420px;background:#afc799a3;border-radius:12px;padding:28px;box-shadow:0 12px 30px #061e0a1f;border:1px solid rgba(20,120,20,.06);position:relative;z-index:2}.login-header{text-align:center;margin-bottom:18px}.login-header .logo-wrap{display:flex;justify-content:center}.login-header .logo-img{width:110px;height:auto}.login-header h1{margin:8px 0 4px;color:#0b6b17;font-size:1.1rem;font-weight:700}.login-header p{margin:0;color:#0c7c1bdd;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:10px}.login-form label{color:#0b6b17;font-weight:500;text-align:left;margin:0;font-size:.95rem}.login-form .input-field{border-radius:8px;width:100%;border:1px solid rgba(15,90,15,.12);padding:.7rem .9rem;font-size:.95rem;background-color:#f9f9f9;color:#2d3748}.login-form .input-field:focus{outline:none;box-shadow:0 0 0 4px #14781412;border-color:#106e1029}.login-form .input-field.error{border-color:#dc3545;background-color:#fff8f8}.login-form .input-field.error:focus{box-shadow:0 0 0 4px #dc354540}.login-form .error-message{color:#dc3545;font-size:.85rem;margin-top:-5px;text-align:left;padding-left:.5rem}.login-form .btn-primary{margin-top:12px;background:linear-gradient(180deg,#16a34a,#0f7a2a);border-radius:10px;padding:.75rem;border:none;cursor:pointer;color:#fff;font-weight:600}.login-form .btn-primary:hover{filter:brightness(.95)}.login-form .btn-primary:disabled{opacity:.6;cursor:not-allowed}.container-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:6px}.container-bottom .remember{display:flex;gap:8px;align-items:center;font-size:.92rem;color:#000000b3}.container-bottom .remember input{width:16px;height:16px}.container-bottom .forgot{color:#0b6b17;text-decoration:underline;font-size:.92rem}.footer-note{margin-top:14px;color:#ffffff8c;font-size:.9rem;text-align:center}.loader{border:2px solid #f3f3f3;border-top:2px solid #16a34a;border-radius:50%;width:16px;height:16px;animation:spin 1s linear infinite;display:inline-block;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
