:root{color-scheme:light;--surface-base: #f6f7f9;--surface-raised: #ffffff;--surface-sunken: #eef0f3;--surface-hover: #eef1f6;--fg: #111827;--fg-muted: #6b7280;--fg-subtle: #9ca3af;--fg-on-accent: #ffffff;--border: #e5e7eb;--border-strong: #cbd5e1;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: #e0ecff;--accent-ring: rgba(37, 99, 235, .25);--ok: #15803d;--ok-soft: #dcfce7;--warn: #b45309;--warn-soft: #fef3c7;--danger: #b91c1c;--danger-soft: #fee2e2;--info: #0369a1;--info-soft: #e0f2fe;--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 40px rgba(15, 23, 42, .16);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;color:var(--fg);background:var(--surface-base)}h1,h2,h3,h4{color:var(--fg);font-weight:600;letter-spacing:-.01em;line-height:1.25;margin:0 0 .5rem}h1{font-size:1.5rem}h2{font-size:1.2rem}h3{font-size:1.05rem}p{margin:0 0 .75rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}input,select,textarea{font:inherit;padding:.45rem .65rem;border:1px solid var(--border);background:var(--surface-raised);color:var(--fg);border-radius:var(--radius-sm);width:100%;transition:border-color .12s,box-shadow .12s}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}input:disabled,select:disabled,textarea:disabled{background:var(--surface-sunken);color:var(--fg-muted);cursor:not-allowed}label{display:block;font-size:.85rem;color:var(--fg-muted);margin-bottom:.3rem;font-weight:500}.field{margin-bottom:.85rem}button{font:inherit;font-weight:500;padding:.45rem 1rem;border:1px solid var(--border);background:var(--surface-raised);color:var(--fg);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s,border-color .12s,color .12s;display:inline-flex;align-items:center;gap:.4rem;line-height:1.3}button:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-strong)}button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}button.primary{background:var(--accent);color:var(--fg-on-accent);border-color:transparent}button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:transparent}button.danger{background:var(--danger);color:var(--fg-on-accent);border-color:transparent}button.danger:hover:not(:disabled){background:#991515}button.ghost{background:transparent;border-color:transparent;color:var(--fg-muted)}button.ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--fg)}button:disabled{opacity:.55;cursor:not-allowed}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.card{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.card>h2:first-child,.card>h3:first-child{margin-top:0}.page-header{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1.25rem}.page-header h1{margin:0}.page-header .page-subtitle{color:var(--fg-muted);font-size:.95rem}.toolbar{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-bottom:1rem}.toolbar .spacer{flex:1}.toolbar .inline{display:inline-flex;align-items:center;gap:.4rem;margin:0;color:var(--fg-muted);font-size:.9rem}.toolbar .inline select,.toolbar .inline input{width:auto;min-width:9rem}.toolbar .search{min-width:14rem}.table-wrap{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.55rem .85rem;border-bottom:1px solid var(--border);vertical-align:middle}thead th{font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted);background:var(--surface-sunken)}tbody tr:hover{background:var(--surface-hover)}tbody tr:last-child td{border-bottom:none}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}td.actions{text-align:right;white-space:nowrap}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .55rem;border-radius:999px;font-size:.78rem;font-weight:500;line-height:1.4;background:var(--surface-sunken);color:var(--fg-muted);white-space:nowrap}.badge.ok{background:var(--ok-soft);color:var(--ok)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.badge.accent{background:var(--accent-soft);color:var(--accent)}.ok{color:var(--ok)}.warn{color:var(--warn)}.danger{color:var(--danger)}.muted{color:var(--fg-muted)}.error{color:var(--danger);font-size:.9rem;margin-top:.5rem}.row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.row.end{justify-content:flex-end}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:50;padding:1rem}.modal-panel{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem 1.4rem 1.2rem;width:min(460px,100%);box-shadow:var(--shadow-lg)}.modal-panel.wide{width:min(640px,100%)}.modal-panel header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.modal-panel header h2,.modal-panel header h3{margin:0}.modal-panel footer{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--border)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:40;padding:.3rem}.dropdown-menu .dropdown-header{padding:.5rem .75rem .35rem;color:var(--fg-muted);font-size:.8rem;border-bottom:1px solid var(--border);margin-bottom:.3rem}.dropdown-menu .dropdown-header strong{color:var(--fg);font-weight:600;display:block;margin-bottom:.1rem;font-size:.92rem}.dropdown-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-sm);background:transparent;border:0;text-align:left;color:var(--fg);font-size:.92rem;cursor:pointer;width:100%;text-decoration:none}.dropdown-item:hover{background:var(--surface-hover);text-decoration:none}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-soft)}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--fg-muted);cursor:pointer}.icon-button:hover{background:var(--surface-hover);color:var(--fg)}.icon-button.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:2rem;background:radial-gradient(circle at 10% 0%,var(--accent-soft),transparent 45%),radial-gradient(circle at 100% 100%,#eef6ff,transparent 40%),var(--surface-base)}.auth-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:420px;box-shadow:var(--shadow)}.auth-card.wide{max-width:520px}.auth-card h1{margin:0 0 .2rem;font-size:1.4rem}.auth-card .subtitle{color:var(--fg-muted);margin-bottom:1.4rem;font-size:.95rem}.empty{padding:2.5rem 1rem;text-align:center;color:var(--fg-muted);border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface-raised)}.progress{position:relative;width:72px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress>span{display:block;height:100%;background:var(--accent);transition:width .5s linear,background .3s}.progress.warn>span{background:var(--warn)}.progress.danger>span{background:var(--danger)}
