:root{--bg: #ffffff;--bg-subtle: #f7f8fa;--bg-hover: #f0f2f5;--bg-elevated: #ffffff;--bg-overlay: rgba(0, 0, 0, .4);--border: #e4e6eb;--border-strong:#cfd2d8;--text: #1c1f25;--text-muted: #5a6068;--text-subtle: #8a9099;--text-inverse: #ffffff;--primary: #1e6cf0;--primary-hover: #1856c0;--primary-soft: #e7f0fe;--success: #168a3d;--success-soft: #e6f4ec;--warning: #b6691b;--warning-soft: #fcf2e3;--danger: #c0392b;--danger-soft: #fbe9e7;--neutral-soft: #eef0f3;--header-h: 56px;--radius: 6px;--radius-lg: 10px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .16);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace}@media(prefers-color-scheme:dark){:root[data-theme=dark]{--bg: #15171c;--bg-subtle: #1c1f26;--bg-hover: #232730;--bg-elevated: #1c1f26;--border: #2a2e38;--border-strong:#3a3f4b;--text: #e6e8ec;--text-muted: #a8aeb8;--text-subtle: #6a707a;--primary: #4d8fff;--primary-hover:#6ba0ff;--primary-soft: #1d2a48;--success-soft: #18331f;--warning-soft: #3a2a17;--danger-soft: #3a1d1a;--neutral-soft: #232730}}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%}body{font-family:var(--font-sans);font-size:14px;line-height:1.45;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.45rem .9rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);font-weight:500;font-size:13px;transition:background 80ms ease,border-color 80ms ease;white-space:nowrap}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:var(--text-inverse)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-danger{background:var(--danger);border-color:var(--danger);color:var(--text-inverse)}.btn-danger:hover{filter:brightness(1.1)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-hover);border-color:var(--border)}.btn-sm{padding:.3rem .65rem;font-size:12px}.input,.select,.textarea{display:block;width:100%;padding:.5rem .7rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.textarea{min-height:80px;resize:vertical}label{font-size:12px;font-weight:600;color:var(--text-muted);display:block;margin-bottom:.25rem}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:.85rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-body{padding:1rem}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .55rem;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.01em;border:1px solid var(--border);background:var(--neutral-soft);color:var(--text-muted)}.badge-primary{background:var(--primary-soft);color:var(--primary);border-color:transparent}.badge-success{background:var(--success-soft);color:var(--success);border-color:transparent}.badge-warning{background:var(--warning-soft);color:var(--warning);border-color:transparent}.badge-danger{background:var(--danger-soft);color:var(--danger);border-color:transparent}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:.6rem .75rem;border-bottom:1px solid var(--border);background:var(--bg-subtle);position:sticky;top:0;z-index:1}.table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);vertical-align:top}.table tr:hover td{background:var(--bg-hover);cursor:pointer}.row{display:flex;align-items:center;gap:.5rem}.row-between{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.col{display:flex;flex-direction:column;gap:.5rem}.gap-sm{gap:.35rem}.gap-md{gap:.75rem}.gap-lg{gap:1.25rem}.muted{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.right{margin-left:auto}.spinner{width:14px;height:14px;border:2px solid var(--neutral-soft);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.drawer-backdrop{position:fixed;inset:0;background:var(--bg-overlay);z-index:50;animation:fade-in .12s ease}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(640px,95vw);background:var(--bg);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:51;display:flex;flex-direction:column;animation:slide-in .18s cubic-bezier(.2,.7,.3,1)}.drawer-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.drawer-body{flex:1;overflow-y:auto;padding:1.25rem}.drawer-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.modal-backdrop{position:fixed;inset:0;background:var(--bg-overlay);z-index:60;display:flex;align-items:flex-start;justify-content:center;padding:5vh 1rem;animation:fade-in .12s ease}.modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:min(720px,100%);max-height:85vh;display:flex;flex-direction:column}.modal-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-body{flex:1;overflow-y:auto;padding:1.25rem}.modal-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.7rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--radius);box-shadow:var(--shadow-md);font-size:13px;min-width:240px;max-width:360px;animation:slide-in .2s ease}.toast-success{border-left-color:var(--success)}.toast-warning{border-left-color:var(--warning)}.toast-danger{border-left-color:var(--danger)}.empty-state{padding:3rem 1rem;text-align:center;color:var(--text-muted)}.empty-state h3{margin:0 0 .5rem;font-weight:500;color:var(--text)}.empty-state p{margin:0}.app-header{height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.25rem;position:sticky;top:0;z-index:40}.app-header h1{font-size:16px;font-weight:600;margin:0}.app-nav{display:flex;gap:1rem;margin-left:2rem}.app-nav a{color:var(--text-muted);font-size:13px;padding:.4rem .65rem;border-radius:var(--radius)}.app-nav a:hover{background:var(--bg-hover);text-decoration:none}.app-nav a.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.app-content{padding:1.25rem;max-width:1400px;margin:0 auto}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-grid-full{grid-column:1 / -1}.mono{font-family:var(--font-mono);font-size:12px}.text-sm{font-size:12px}.text-lg{font-size:16px}.fw-600{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-msg{color:var(--danger);font-size:12px;margin-top:.25rem}.field-row{margin-bottom:.85rem}
