*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#0f1012;--surf:#17191d;--surf2:#1f2228;--surf3:#272b33;--oak:#c8965a;--oak-light:rgba(200,150,90,0.12);--blue:#3b9eff;--green:#22c55e;--red:#ef4444;--text:#e4e6ea;--muted:#6b7280;--border:rgba(255,255,255,0.08);--r:8px}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:14px;overflow:hidden}
.grid-bg{position:fixed;inset:0;background-image:linear-gradient(rgba(200,150,90,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(200,150,90,0.035) 1px,transparent 1px);background-size:46px 46px;pointer-events:none}
.glow{position:fixed;width:620px;height:620px;border-radius:50%;top:20%;left:50%;transform:translateX(-50%);background:radial-gradient(circle,rgba(200,150,90,0.09),transparent 66%);pointer-events:none}
.wrap{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:1rem}
.panel{width:100%;max-width:430px;background:var(--surf);border:1px solid var(--border);border-radius:12px;overflow:hidden;position:relative}
.panel::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--accent,var(--oak)),transparent)}
.head{padding:2rem 2rem 1.25rem;text-align:center;border-bottom:1px solid var(--border)}
.logo{font-family:'Orbitron',sans-serif;font-size:1.25rem;font-weight:700;letter-spacing:0.08em}
.logo span{color:var(--accent,var(--oak))}
.badge{display:inline-flex;margin-top:0.65rem;padding:0.2rem 0.55rem;border:1px solid color-mix(in srgb,var(--accent,var(--oak)) 35%,transparent);border-radius:999px;color:var(--accent,var(--oak));font-size:0.58rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase}
.body{padding:1.45rem 2rem 1.8rem}
.field{margin-bottom:0.95rem}
.field label{display:block;font-size:0.6rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:0.32rem}
.field input{width:100%;background:var(--surf2);border:1px solid var(--border);border-radius:var(--r);color:var(--text);font-family:'Inter',sans-serif;font-size:0.88rem;padding:0.68rem 0.85rem;outline:none}
.field input:focus{border-color:var(--accent,var(--oak))}
.submit{width:100%;border:none;border-radius:var(--r);background:var(--accent,var(--oak));color:#000;padding:0.88rem;font-family:'Orbitron',sans-serif;font-weight:700;font-size:0.78rem;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;margin-top:0.35rem}
.submit:hover{opacity:0.9}
.err{display:none;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.25);color:var(--red);border-radius:var(--r);font-size:0.75rem;padding:0.58rem 0.75rem;margin-bottom:0.9rem}
.hint{margin-top:1rem;background:var(--surf2);border:1px solid var(--border);border-radius:var(--r);padding:0.78rem 0.9rem;font-size:0.7rem;color:var(--muted);line-height:1.65}
.hint strong{color:var(--text)}
.links{display:flex;justify-content:space-between;gap:0.7rem;margin-top:1rem;flex-wrap:wrap}
.links a{font-size:0.72rem;color:var(--muted);text-decoration:none}
.links a:hover{color:var(--accent,var(--oak))}
.remember{display:flex;align-items:center;gap:0.45rem;font-size:0.72rem;color:var(--muted);margin-bottom:0.8rem}
.remember input{accent-color:var(--accent,var(--oak))}
.toast{position:fixed;bottom:1.1rem;left:50%;transform:translateX(-50%);display:none;background:var(--surf);border:1px solid var(--accent,var(--oak));color:var(--accent,var(--oak));border-radius:999px;padding:0.62rem 1.05rem;font-size:0.78rem;font-weight:600;z-index:20}
.toast.show{display:block}
body[data-login-role="merchandiser"]{--accent:var(--blue)}
body[data-login-role="management"]{--accent:var(--oak)}
