:root{--indigo: #4f46e5;--ink: #1f2937;--muted: #6b7280;--line: #e5e7eb;--bg: #f9fafb}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg)}a{color:inherit;text-decoration:none}.muted{color:var(--muted)}.error{color:#b91c1c}.shell{display:flex;min-height:100vh}.sidebar{width:220px;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:1rem}.brand{font-weight:700;font-size:1.05rem;margin-bottom:1.25rem}.sidebar nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.nav-link{padding:.5rem .6rem;border-radius:.375rem;color:var(--muted)}.nav-link:hover{background:var(--bg);color:var(--ink)}.nav-link.router-link-exact-active{background:#eef2ff;color:var(--indigo);font-weight:600}.sidebar-footer{border-top:1px solid var(--line);padding-top:.75rem}.who{font-size:.85rem;margin-bottom:.25rem}.link-button{background:none;border:none;color:var(--indigo);cursor:pointer;padding:0;font:inherit}.content{flex:1;padding:1.5rem 2rem}.page h1{margin-top:0}.login-wrap{display:flex;min-height:100vh;align-items:center;justify-content:center}.login-card{width:22rem;background:#fff;border:1px solid var(--line);border-radius:.5rem;padding:1.5rem;display:flex;flex-direction:column}.login-card h1{margin:0 0 .25rem;font-size:1.25rem}.login-card label{margin:.85rem 0 .25rem;font-size:.85rem}.login-card input{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem}.login-card button{margin-top:1.25rem;padding:.6rem;background:var(--indigo);color:#fff;border:0;border-radius:.375rem;cursor:pointer}.login-card button:disabled{opacity:.6;cursor:default}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem}.page-head h1{margin:0}.toolbar{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem}.btn{padding:.45rem .8rem;border-radius:.375rem;border:1px solid var(--line);background:#fff;cursor:pointer;font:inherit}.btn:hover{background:var(--bg)}.btn-primary{background:var(--indigo);color:#fff;border-color:var(--indigo)}.btn-primary:hover{filter:brightness(1.05);background:var(--indigo)}.btn-danger{color:#b91c1c;border-color:#fecaca}.btn:disabled{opacity:.6;cursor:default}.btn-sm{padding:.25rem .5rem;font-size:.85rem}input,select,textarea{font:inherit;padding:.45rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff}textarea{width:100%;min-height:8rem;font-family:ui-monospace,monospace}.field{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.field label{font-size:.85rem;color:var(--muted)}.row{display:flex;gap:.75rem;flex-wrap:wrap}.row>.field{flex:1;min-width:12rem}table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:.5rem;overflow:hidden}th,td{text-align:left;padding:.55rem .7rem;border-bottom:1px solid var(--line);font-size:.9rem}th{background:#fafafa;color:var(--muted);font-weight:600}tr:last-child td{border-bottom:none}.actions{display:flex;gap:.4rem}.badge{display:inline-block;padding:.1rem .45rem;border-radius:999px;font-size:.72rem;background:#eef2ff;color:var(--indigo)}.badge-gray{background:#f3f4f6;color:var(--muted)}.badge-green{background:#ecfdf5;color:#047857}.badge-red{background:#fef2f2;color:#b91c1c}.badge-amber{background:#fffbeb;color:#b45309}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(9rem,1fr));gap:.75rem;margin-bottom:1rem}.stat{background:#fff;border:1px solid var(--line);border-radius:.5rem;padding:.8rem 1rem}.stat .n{font-size:1.5rem;font-weight:700}.stat .l{font-size:.8rem;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:flex-start;justify-content:center;padding:3rem 1rem;z-index:50;overflow-y:auto}.modal{background:#fff;border-radius:.5rem;width:36rem;max-width:100%}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--line)}.modal-head h2{margin:0;font-size:1.05rem}.modal-body{padding:1.25rem}.state{padding:1.25rem;color:var(--muted)}.split{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.preview-pane{border:1px solid var(--line);border-radius:.5rem;padding:1rem;background:#fff;min-height:10rem}.mono{font-family:ui-monospace,monospace;font-size:.82rem;word-break:break-all}.pager{display:flex;gap:.5rem;align-items:center;margin-top:.75rem}hr.sep{border:none;border-top:1px solid var(--line);margin:1.25rem 0}
