*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f6f8;--panel: #ffffff;--border: #e2e5ea;--accent: #4f46e5;--accent-h: #4338ca;--accent-l: #eef2ff;--text: #111827;--muted: #6b7280;--danger: #dc2626;--danger-h: #b91c1c;--success: #16a34a;--info: #0284c7;--sidebar-w: 220px;--topbar-h: 52px;--radius: 6px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.12);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace}html,body{height:100%}body{font-family:var(--font);font-size:14px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{height:var(--topbar-h);display:flex;align-items:center;padding:0 20px;font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--accent);border-bottom:1px solid var(--border);flex-shrink:0}.nav-group{padding:18px 20px 4px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.nav-item{display:flex;align-items:center;padding:8px 20px;font-size:13.5px;color:var(--text);text-decoration:none;border-radius:0;transition:background .12s,color .12s}.nav-item:hover{background:var(--bg);color:var(--accent)}.nav-item.router-link-active,.nav-item.router-link-exact-active{background:var(--accent-l);color:var(--accent);font-weight:600;border-right:3px solid var(--accent)}.main{display:flex;flex-direction:column;min-height:100vh;min-width:0}.topbar{height:var(--topbar-h);background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.spacer{flex:1}.user{font-size:13px;color:var(--muted);font-weight:500}.content{flex:1;padding:28px 28px 48px;overflow:auto}.page{max-width:1200px}.page-head{display:flex;align-items:center;gap:12px;margin-bottom:20px}.page-head h2{font-size:20px;font-weight:700;letter-spacing:-.2px;flex:1}button,.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;font:inherit;font-size:13.5px;font-weight:500;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:background .12s,border-color .12s,opacity .12s;white-space:nowrap;line-height:1}button:disabled,.btn:disabled{opacity:.45;cursor:default}button.primary,.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.primary:hover:not(:disabled),.btn.primary:hover:not(:disabled){background:var(--accent-h);border-color:var(--accent-h)}button.link,.btn.link{background:transparent;color:var(--accent);border-color:transparent;padding:7px 10px}button.link:hover:not(:disabled),.btn.link:hover:not(:disabled){background:var(--accent-l)}button.danger,.btn.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.danger:hover:not(:disabled),.btn.danger:hover:not(:disabled){background:var(--danger-h);border-color:var(--danger-h)}button.secondary,.btn.secondary{background:var(--panel);color:var(--text);border-color:var(--border)}button.secondary:hover:not(:disabled),.btn.secondary:hover:not(:disabled){background:var(--bg)}.grid{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse;font-size:13.5px}th{background:var(--bg);text-align:left;padding:10px 14px;font-size:11.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}th:hover{color:var(--text)}td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fafbfc}.actions-col{text-align:right;width:1%;white-space:nowrap}.field{display:flex;flex-direction:column;gap:4px}.field-label{font-size:12.5px;font-weight:600;color:var(--muted)}.req{color:var(--danger);font-style:normal;margin-left:2px}input[type=text],input[type=number],input[type=password],input[type=email],input[type=search],select,textarea{width:100%;padding:7px 10px;font:inherit;font-size:13.5px;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);color:var(--text);transition:border-color .12s,box-shadow .12s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51f}input::placeholder{color:var(--muted);opacity:.7}.field-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.field-err{font-size:12px;color:var(--danger);margin-top:1px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--panel);border-radius:10px;box-shadow:var(--shadow-md);width:560px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal.confirm{width:380px}.modal-head{padding:18px 22px 14px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:16px;font-weight:700;letter-spacing:-.1px}.modal-body{padding:20px 22px;overflow-y:auto;flex:1}.modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px}.pager{display:flex;align-items:center;gap:8px;margin-top:14px;font-size:13px;color:var(--muted)}.pager button{padding:5px 12px;background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:var(--radius)}.pager button:hover:not(:disabled){background:var(--bg)}.pager button:disabled{opacity:.4}.toast-host{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px;max-width:360px}.toast{padding:12px 18px;border-radius:var(--radius);box-shadow:var(--shadow-md);font-size:13.5px;font-weight:500;color:#fff;cursor:pointer;animation:toast-in .18s ease}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}.toast.info{background:var(--info)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px}.login h1{font-size:24px;font-weight:800;letter-spacing:-.4px;color:var(--accent);margin-bottom:6px}.login input{width:100%;max-width:320px}.login button{width:100%;max-width:320px;justify-content:center;background:var(--accent);color:#fff;border-color:var(--accent);padding:10px 16px;font-size:14px}.login button:hover{background:var(--accent-h);border-color:var(--accent-h)}.login .err{font-size:13px;color:var(--danger)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.text-muted{color:var(--muted)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.mono{font-family:var(--font-mono)}
