.login-page{min-height:100svh;background-color:#1b1917;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-bg-grain{inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E")}.login-ambient,.login-bg-grain{position:fixed;pointer-events:none;z-index:0}.login-ambient{top:-30%;left:50%;transform:translateX(-50%);width:60vw;height:60vw;max-width:800px;max-height:800px;border-radius:50%;background:radial-gradient(circle,rgba(179,167,152,.04) 0,transparent 70%)}.login-card{position:relative;z-index:1;width:100%;max-width:440px;background-color:#1f1d1b;border:1px solid rgba(179,167,152,.08);border-radius:1.5rem;padding:2.5rem;animation:loginFadeIn .7s cubic-bezier(.16,1,.3,1) forwards;opacity:0}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:2.5rem}.login-wordmark{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.login-wordmark-dot{width:8px;height:8px;border-radius:50%;background-color:var(--color-gold)}.login-wordmark p{font-family:DM Mono,monospace;font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--color-white)}.login-title{color:var(--base-100);font-size:2rem;font-weight:500;letter-spacing:-.05rem;line-height:1.1;margin-bottom:.5rem}.login-subtitle{color:var(--color-white);font-size:.9rem;font-weight:400}.login-role-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background-color:rgba(244,249,255,.03);border-radius:.75rem;padding:.25rem}.login-role-tab{flex:1 1;padding:.6rem 1rem;border-radius:.5rem;border:none;background:transparent;color:var(--base-350);font-family:Manrope,sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.login-role-tab.active{background-color:rgba(179,167,152,.1);color:var(--base-100)}.login-form{gap:1rem}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:.5rem}.login-label{font-family:DM Mono,monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--base-400)}.login-input{background-color:var(--color-white);border:1px solid rgba(45,41,38,.2);border-radius:.65rem;padding:.85rem 1rem;color:var(--color-black);font-family:Manrope,sans-serif;font-size:.95rem;font-weight:400;outline:none;transition:border-color .2s ease;width:100%;box-sizing:border-box;-webkit-text-size-adjust:100%}.login-input::placeholder{color:rgba(45,41,38,.35)}.login-input:focus{border-color:var(--color-black)}.login-input:-webkit-autofill,.login-input:-webkit-autofill:active,.login-input:-webkit-autofill:focus,.login-input:-webkit-autofill:hover{-webkit-box-shadow:0 0 0 9999px var(--color-white) inset!important;-webkit-text-fill-color:var(--color-black)!important;caret-color:var(--color-black)}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:.65rem;background-color:rgba(191,25,50,.08);border:1px solid rgba(191,25,50,.15)}.login-error p{color:#cf5c70;font-size:.85rem}.login-success{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:.65rem;background-color:rgba(240,192,90,.08);border:1px solid rgba(240,192,90,.15)}.login-success p{color:var(--color-gold);font-size:.85rem}.login-submit{margin-top:.5rem;width:100%;padding:.9rem 1.5rem;background-color:var(--base-250);border:none;border-radius:.65rem;color:#1b1917;font-family:Manrope,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,opacity .2s ease,transform .15s ease;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-submit:hover:not(:disabled){background-color:var(--base-200);transform:translateY(-1px)}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-spinner{width:16px;height:16px;border:2px solid rgba(45,41,38,.3);border-top-color:#1b1917;border-radius:50%;animation:loginSpin .7s linear infinite}@keyframes loginSpin{to{transform:rotate(1turn)}}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(179,167,152,.08);display:flex;justify-content:center}.login-footer p{font-size:.8rem;color:var(--base-400);text-align:center}.login-footer a{color:var(--base-250);font-size:.8rem}.login-footer a:hover{color:var(--base-100)}@media (max-width:480px){.login-page{align-items:flex-start;padding:2.5rem 1.25rem 1.25rem}.login-card{padding:1.75rem 1.25rem;border-radius:1rem}.login-header{margin-bottom:1.75rem}.login-wordmark{margin-bottom:1.5rem}.login-title{font-size:1.6rem}.login-role-tabs{margin-bottom:1.5rem}.login-input{font-size:1rem;padding:.9rem .875rem}.login-submit{padding:1rem 1.5rem;font-size:.95rem;min-height:48px}.login-footer{margin-top:1.5rem;padding-top:1.25rem}.login-footer a,.login-footer p{font-size:.85rem}}@media (max-width:390px){.login-page{padding:2rem 1rem 1rem}.login-card{padding:1.5rem 1rem}.login-title{font-size:1.45rem}.login-subtitle{font-size:.82rem}.login-role-tab{font-size:.78rem;padding:.55rem .5rem}}