@import "https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@400,0&display=swap";:root{--surface:#0b0e11;--surface-container-lowest:#000;--surface-container-low:#101417;--surface-container:#161a1e;--surface-container-high:#1c2024;--surface-container-highest:#22272b;--surface-bright:#282d31;--primary:#b1ffce;--primary-container:#00ffa3;--on-primary:#000;--surface-tint:#b1ffce;--on-surface:#f8f9fe;--on-surface-variant:#8b9199;--secondary-container:#1a3028;--on-secondary-container:#b1ffce;--tertiary:#7ab8ff;--error:#f55;--error-dim:#c0392b;--outline-variant:#45484c;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-full:9999px;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-7:1.75rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--font-display:"Manrope", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"Courier New", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background-color:var(--surface);color:var(--on-surface);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--surface-container-low)}::-webkit-scrollbar-thumb{background:var(--surface-container-highest);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--outline-variant)}#app{height:100vh}.page{padding:var(--spacing-6);gap:var(--spacing-6);flex-direction:column;min-height:100%;display:flex}.page-header{justify-content:space-between;align-items:flex-end;gap:var(--spacing-4);flex-wrap:wrap;display:flex}.page-title{font-family:var(--font-display);color:var(--on-surface);letter-spacing:-.03em;font-size:1.75rem;font-weight:800;line-height:1.1}.page-desc{color:var(--on-surface-variant);margin-top:var(--spacing-1);font-size:.875rem}.stats-row{gap:var(--spacing-4);flex-wrap:wrap;display:flex}.stat-card{background-color:var(--surface-container);border-radius:var(--radius-xl);min-width:140px;padding:var(--spacing-4) var(--spacing-5);flex:1}.stat-primary{border-left:3px solid var(--primary)}.stat-active{border-left:3px solid var(--tertiary)}.stat-deleted{border-left:3px solid var(--error)}.stat-label{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:600}.stat-value{font-family:var(--font-display);color:var(--on-surface);letter-spacing:-.04em;margin-top:var(--spacing-1);font-size:2rem;font-weight:800;line-height:1.1}.table-section{background-color:var(--surface-container-low);border-radius:var(--radius-xl);overflow:hidden}.table-wrap{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{padding:var(--spacing-3) var(--spacing-4);text-align:left;color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-bottom:1px solid #45484c33;font-size:.75rem;font-weight:700}.table td{padding:var(--spacing-4) var(--spacing-4);color:var(--on-surface);vertical-align:middle;font-size:.875rem}.row-even{background-color:#0000}.row-odd{background-color:var(--surface-container)}.btn-primary{align-items:center;gap:var(--spacing-2);padding:.625rem var(--spacing-4);background:linear-gradient(135deg, var(--primary), var(--primary-container));color:var(--on-primary);border-radius:var(--radius-lg);font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;font-size:.875rem;font-weight:700;transition:opacity .15s;display:inline-flex}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{padding:.625rem var(--spacing-4);color:var(--on-surface-variant);border-radius:var(--radius-lg);font-family:var(--font-body);cursor:pointer;background:0 0;border:1px solid #45484c33;align-items:center;font-size:.875rem;font-weight:600;transition:background-color .15s,color .15s;display:inline-flex}.btn-ghost:hover{background-color:var(--surface-container);color:var(--on-surface)}.btn-danger{padding:.625rem var(--spacing-4);background-color:var(--error);color:#fff;border-radius:var(--radius-lg);font-family:var(--font-body);cursor:pointer;border:none;align-items:center;font-size:.875rem;font-weight:700;display:inline-flex}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.icon-btn{border-radius:var(--radius-lg);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:28px;height:28px;transition:background-color .15s,color .15s;display:flex}.icon-edit{color:var(--on-surface-variant)}.icon-edit:hover{background-color:color-mix(in srgb, var(--primary) 12%, transparent);color:var(--primary)}.icon-delete{color:var(--on-surface-variant)}.icon-delete:hover{background-color:color-mix(in srgb, var(--error) 12%, transparent);color:var(--error)}.panel-backdrop{z-index:300;background:#00000080;position:fixed;inset:0}.panel{background-color:var(--surface-container-low);z-index:301;border-left:1px solid #45484c33;flex-direction:column;width:480px;max-width:100%;height:100%;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 32px #0000004d}.panel-header{padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid #45484c33;justify-content:space-between;align-items:center;display:flex}.panel-title{font-family:var(--font-display);color:var(--on-surface);font-size:1.125rem;font-weight:800}.panel-close{border-radius:var(--radius-lg);cursor:pointer;width:32px;height:32px;color:var(--on-surface-variant);background:0 0;border:none;justify-content:center;align-items:center;transition:background-color .15s,color .15s;display:flex}.panel-close:hover{background-color:var(--surface-container);color:var(--on-surface)}.panel-body{padding:var(--spacing-6);gap:var(--spacing-5);flex-direction:column;flex:1;display:flex;overflow-y:auto}.panel-footer{justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);border-top:1px solid #45484c33;display:flex}.field{gap:var(--spacing-2);flex-direction:column;display:flex}.field-label{color:var(--on-surface-variant);font-size:.8125rem;font-weight:700}.field-opt{opacity:.6;margin-left:4px;font-weight:500}.required{color:var(--error);margin-left:2px}.field-input{background-color:var(--surface-container-lowest);border-radius:var(--radius-lg);padding:.625rem var(--spacing-3);font-family:var(--font-body);color:var(--on-surface);box-sizing:border-box;border:1px solid #45484c33;outline:none;width:100%;font-size:.875rem;transition:border-color .15s}.field-input:focus{border-color:var(--primary)}.field-input::placeholder{color:var(--on-surface-variant);opacity:.4}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:400;padding:var(--spacing-4);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:color-mix(in srgb, var(--surface-bright) 70%, transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--radius-xl);padding:var(--spacing-6);align-items:center;gap:var(--spacing-3);text-align:center;border:1px solid #45484c4d;flex-direction:column;width:100%;max-width:380px;display:flex}.modal-icon{border-radius:var(--radius-full);background-color:color-mix(in srgb, var(--error) 12%, transparent);width:48px;height:48px;color:var(--error);justify-content:center;align-items:center;display:flex}.modal-title{font-family:var(--font-display);color:var(--on-surface);font-size:1.125rem;font-weight:800}.modal-desc{color:var(--on-surface-variant);font-size:.875rem;line-height:1.6}.modal-actions{gap:var(--spacing-3);margin-top:var(--spacing-2);display:flex}.skeleton{border-radius:var(--radius-md);background:linear-gradient(90deg, var(--surface-container) 25%, var(--surface-container-high) 50%, var(--surface-container) 75%);background-size:200% 100%;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-cell{text-align:center;padding:var(--spacing-10)!important}.empty-state{align-items:center;gap:var(--spacing-3);color:var(--on-surface-variant);opacity:.5;flex-direction:column;font-size:.875rem;display:flex}.panel-enter-active,.panel-leave-active{transition:transform .28s cubic-bezier(.4,0,.2,1)}.panel-enter-from,.panel-leave-to{transform:translate(100%)}.panel-backdrop-enter-active,.panel-backdrop-leave-active{transition:opacity .28s}.panel-backdrop-enter-from,.panel-backdrop-leave-to{opacity:0}.modal-enter-active,.modal-leave-active{transition:opacity .2s}.modal-enter-from,.modal-leave-to{opacity:0}.toast-wrap[data-v-8f5da7cf]{z-index:9999;pointer-events:none;flex-direction:column;gap:.625rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast[data-v-8f5da7cf]{border-radius:var(--radius-xl);pointer-events:all;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #0000;align-items:flex-start;gap:.75rem;min-width:260px;max-width:360px;padding:.875rem 1.125rem;display:flex;box-shadow:0 8px 24px #0000004d}.toast.success[data-v-8f5da7cf]{background:#1c2024f2;border-color:#b1ffce33}.toast.error[data-v-8f5da7cf]{background:#1c2024f2;border-color:#ff555540}.toast.warn[data-v-8f5da7cf]{background:#1c2024f2;border-color:#ffc85040}.toast.info[data-v-8f5da7cf]{background:#1c2024f2;border-color:#7ab8ff40}.toast-icon[data-v-8f5da7cf]{flex-shrink:0;margin-top:1px;font-family:Material Symbols Outlined;font-size:1.25rem}.toast.success .toast-icon[data-v-8f5da7cf]{color:var(--primary)}.toast.error .toast-icon[data-v-8f5da7cf]{color:var(--error)}.toast.warn .toast-icon[data-v-8f5da7cf]{color:#ffc850}.toast.info .toast-icon[data-v-8f5da7cf]{color:var(--tertiary)}.toast-body[data-v-8f5da7cf]{flex-direction:column;gap:2px;display:flex}.toast-summary[data-v-8f5da7cf]{color:var(--on-surface);font-size:.875rem;font-weight:600}.toast-detail[data-v-8f5da7cf]{color:var(--on-surface-variant);font-size:.8125rem}.toast-enter-active[data-v-8f5da7cf]{transition:all .25s}.toast-leave-active[data-v-8f5da7cf]{transition:all .2s}.toast-enter-from[data-v-8f5da7cf],.toast-leave-to[data-v-8f5da7cf]{opacity:0;transform:translate(1rem)}
