.toast-container[data-v-f4d7ea67]{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;max-width:400px;display:flex;position:fixed;top:20px;right:20px}.toast-item[data-v-f4d7ea67]{background-color:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border-left:4px solid var(--primary-color);pointer-events:auto;align-items:center;gap:12px;padding:12px 16px;display:flex}.toast-item.success[data-v-f4d7ea67]{border-left-color:var(--success-color)}.toast-item.success .toast-icon[data-v-f4d7ea67]{color:var(--success-color)}.toast-item.error[data-v-f4d7ea67]{border-left-color:var(--danger-color)}.toast-item.error .toast-icon[data-v-f4d7ea67]{color:var(--danger-color)}.toast-item.warning[data-v-f4d7ea67]{border-left-color:var(--warning-color)}.toast-item.warning .toast-icon[data-v-f4d7ea67]{color:var(--warning-color)}.toast-item.info[data-v-f4d7ea67]{border-left-color:var(--info-color)}.toast-item.info .toast-icon[data-v-f4d7ea67]{color:var(--info-color)}.toast-icon[data-v-f4d7ea67]{flex-shrink:0;width:20px;height:20px}.toast-icon svg[data-v-f4d7ea67]{width:100%;height:100%}.toast-message[data-v-f4d7ea67]{color:var(--text-primary);flex:1;font-size:.875rem;line-height:1.4}.toast-close[data-v-f4d7ea67]{width:20px;height:20px;color:var(--text-muted);cursor:pointer;opacity:.6;background:0 0;border:none;flex-shrink:0;padding:0;transition:opacity .2s}.toast-close[data-v-f4d7ea67]:hover{opacity:1}.toast-close svg[data-v-f4d7ea67]{width:100%;height:100%}.toast-enter-active[data-v-f4d7ea67],.toast-leave-active[data-v-f4d7ea67]{transition:all .3s}.toast-enter-from[data-v-f4d7ea67],.toast-leave-to[data-v-f4d7ea67]{opacity:0;transform:translate(100%)}@media (width<=576px){.toast-container[data-v-f4d7ea67]{max-width:none;left:16px;right:16px}}.confirm-overlay[data-v-cc136190]{z-index:10000;padding:var(--spacing-lg);background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-modal[data-v-cc136190]{background-color:var(--surface-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:var(--spacing-xl);text-align:center}.confirm-icon[data-v-cc136190]{width:56px;height:56px;margin:0 auto var(--spacing-lg);border-radius:50%;justify-content:center;align-items:center;display:flex}.confirm-icon svg[data-v-cc136190]{width:28px;height:28px}.confirm-icon.danger[data-v-cc136190]{color:var(--danger-color);background-color:#ef44441a}.confirm-icon.warning[data-v-cc136190]{color:var(--warning-color);background-color:#f59e0b1a}.confirm-icon.info[data-v-cc136190]{color:var(--primary-color);background-color:#3b82f61a}.confirm-title[data-v-cc136190]{color:var(--text-primary);margin-bottom:var(--spacing-sm);font-size:1.125rem;font-weight:600}.confirm-message[data-v-cc136190]{color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-size:.875rem;line-height:1.6}.confirm-actions[data-v-cc136190]{gap:var(--spacing-sm);justify-content:center;display:flex}.confirm-actions .btn[data-v-cc136190]{min-width:100px}.modal-enter-active[data-v-cc136190],.modal-leave-active[data-v-cc136190]{transition:opacity .2s}.modal-enter-active .confirm-modal[data-v-cc136190],.modal-leave-active .confirm-modal[data-v-cc136190]{transition:transform .2s}.modal-enter-from[data-v-cc136190],.modal-leave-to[data-v-cc136190]{opacity:0}.modal-enter-from .confirm-modal[data-v-cc136190],.modal-leave-to .confirm-modal[data-v-cc136190]{transform:scale(.95)}@media (width<=576px){.confirm-modal[data-v-cc136190]{padding:var(--spacing-lg)}.confirm-actions[data-v-cc136190]{flex-direction:column}.confirm-actions .btn[data-v-cc136190]{width:100%}}:root{--primary-color:#3b82f6;--primary-hover:#2563eb;--primary-light:#dbeafe;--secondary-color:#64748b;--success-color:#22c55e;--warning-color:#f59e0b;--danger-color:#ef4444;--info-color:#06b6d4;--bg-color:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--surface-color:#fff;--border-color:#e2e8f0;--border-light:#f1f5f9;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--text-inverse:#fff;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-full:9999px;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:"SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--sidebar-width:260px;--header-height:60px;--footer-height:50px}[data-theme=dark]{--primary-color:#3b82f6;--primary-hover:#60a5fa;--primary-light:#1e3a5f;--bg-color:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--surface-color:#1e293b;--border-color:#334155;--border-light:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:.875rem;line-height:1.5}a{color:var(--primary-color);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-hover)}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}img{max-width:100%;height:auto}.app-container{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background-color:var(--surface-color);border-right:1px solid var(--border-color);z-index:100;height:100vh;transition:transform var(--transition-normal);position:fixed;top:0;left:0;overflow-y:auto}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.sidebar-header .logo{align-items:center;gap:var(--spacing-sm);color:var(--text-primary);font-size:1.25rem;font-weight:600;display:flex}.sidebar-header .logo img{width:32px;height:32px}.sidebar-header .logo .logo-icon{color:#fff;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-header .logo .logo-icon svg{width:20px;height:20px}.sidebar-nav{padding:var(--spacing-md)}.sidebar-nav .nav-section{margin-bottom:var(--spacing-lg)}.sidebar-nav .nav-section .nav-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-sm) var(--spacing-md);font-size:.75rem;font-weight:600}.sidebar-nav .nav-section .nav-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.sidebar-nav .nav-section .nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav .nav-section .nav-item.active{background-color:var(--primary-light);color:var(--primary-color)}.sidebar-nav .nav-section .nav-item .icon{width:20px;height:20px}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.header{height:var(--header-height);background-color:var(--surface-color);border-bottom:1px solid var(--border-color);padding:0 var(--spacing-lg);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header .header-left,.header .header-right{align-items:center;gap:var(--spacing-md);display:flex}.header .page-title{color:var(--text-primary);font-size:1.125rem;font-weight:600}.content-wrapper{padding:var(--spacing-lg);flex:1}.card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.card-header .card-title{color:var(--text-primary);font-size:1rem;font-weight:600}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);background-color:var(--bg-tertiary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.btn{justify-content:center;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:var(--text-inverse)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-success{background-color:var(--success-color);color:var(--text-inverse)}.btn-success:hover:not(:disabled){opacity:.9}.btn-danger{background-color:var(--danger-color);color:var(--text-inverse)}.btn-danger:hover:not(:disabled){opacity:.9}.btn-warning{background-color:var(--warning-color);color:var(--text-inverse)}.btn-warning:hover:not(:disabled){opacity:.9}.btn-ghost{color:var(--text-secondary);background-color:#0000}.btn-ghost:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.btn-block{width:100%}.btn .icon{width:16px;height:16px}.form-group{margin-bottom:var(--spacing-md)}.form-group label{color:var(--text-primary);margin-bottom:var(--spacing-xs);font-size:.875rem;font-weight:500;display:block}.form-group .form-control{width:100%;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);font-size:.875rem}.form-group .form-control:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-group .form-control::placeholder{color:var(--text-muted)}.form-group .form-control:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.form-group select.form-control{cursor:pointer}.form-group textarea.form-control{resize:vertical;min-height:100px}.form-group .form-hint{color:var(--text-muted);margin-top:var(--spacing-xs);font-size:.75rem}.form-group .form-error{color:var(--danger-color);margin-top:var(--spacing-xs);font-size:.75rem}.table-container{overflow-x:auto}.table-container table{border-collapse:collapse;width:100%}.table-container table th,.table-container table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}.table-container table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background-color:var(--bg-tertiary);font-size:.75rem;font-weight:600}.table-container table td{color:var(--text-primary);font-size:.875rem}.table-container table tbody tr{transition:background-color var(--transition-fast)}.table-container table tbody tr:hover{background-color:var(--bg-secondary)}.badge{border-radius:var(--radius-full);align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.badge-primary{background-color:var(--primary-light);color:var(--primary-color)}.badge-success{color:var(--success-color);background-color:#22c55e1a}.badge-warning{color:var(--warning-color);background-color:#f59e0b1a}.badge-danger{color:var(--danger-color);background-color:#ef44441a}.badge-info{color:var(--info-color);background-color:#06b6d41a}.badge-secondary{background-color:var(--bg-tertiary);color:var(--text-secondary)}.pagination{justify-content:center;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);display:flex}.pagination .page-item{min-width:32px;height:32px;color:var(--text-secondary);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:.875rem;display:flex}.pagination .page-item:hover:not(.disabled):not(.active){background-color:var(--bg-tertiary);color:var(--text-primary)}.pagination .page-item.active{background-color:var(--primary-color);color:var(--text-inverse);border-color:var(--primary-color)}.pagination .page-item.disabled{opacity:.5;cursor:not-allowed}.pagination .page-info{color:var(--text-muted);margin:0 var(--spacing-md);font-size:.875rem}.search-box{position:relative}.search-box input{width:100%;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding-left:2.5rem;font-size:.875rem}.search-box input:focus{border-color:var(--primary-color);outline:none}.search-box .search-icon{left:var(--spacing-sm);width:16px;height:16px;color:var(--text-muted);position:absolute;top:50%;transform:translateY(-50%)}.filter-bar{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.filter-bar .filter-item{flex:1;min-width:200px}.filter-bar .filter-actions{gap:var(--spacing-sm);display:flex}.view-toggle{border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;overflow:hidden}.view-toggle .view-btn{padding:var(--spacing-sm);background-color:var(--surface-color);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border:none}.view-toggle .view-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.view-toggle .view-btn.active{background-color:var(--primary-color);color:var(--text-inverse)}.view-toggle .view-btn .icon{width:16px;height:16px}.empty-state{padding:var(--spacing-2xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state .empty-icon{width:64px;height:64px;color:var(--text-muted);margin-bottom:var(--spacing-md)}.empty-state .empty-title{color:var(--text-primary);margin-bottom:var(--spacing-sm);font-size:1rem;font-weight:600}.empty-state .empty-desc{color:var(--text-muted);margin-bottom:var(--spacing-lg);font-size:.875rem}.loading-spinner{border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{z-index:1000;padding:var(--spacing-lg);background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay .modal{background-color:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-overlay .modal-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-overlay .modal-header .modal-title{color:var(--text-primary);font-size:1rem;font-weight:600}.modal-overlay .modal-header .modal-close{padding:var(--spacing-xs);color:var(--text-muted);cursor:pointer;background:0 0;border:none}.modal-overlay .modal-header .modal-close:hover{color:var(--text-primary)}.modal-overlay .modal-body{padding:var(--spacing-lg)}.modal-overlay .modal-footer{justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);display:flex}.dropdown{position:relative}.dropdown .dropdown-menu{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:180px;box-shadow:var(--shadow-lg);z-index:100;padding:var(--spacing-xs) 0;position:absolute;top:100%;right:0}.dropdown .dropdown-menu .dropdown-item{align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-size:.875rem;display:flex}.dropdown .dropdown-menu .dropdown-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.dropdown .dropdown-menu .dropdown-item.danger{color:var(--danger-color)}.dropdown .dropdown-menu .dropdown-divider{background-color:var(--border-color);height:1px;margin:var(--spacing-xs) 0}.toast{top:var(--spacing-lg);right:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:2000;align-items:center;gap:var(--spacing-sm);display:flex;position:fixed}.toast-success{border-left:4px solid var(--success-color)}.toast-error{border-left:4px solid var(--danger-color)}.toast-warning{border-left:4px solid var(--warning-color)}.toast-info{border-left:4px solid var(--info-color)}.grid{gap:var(--spacing-lg);display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-center{justify-content:center;align-items:center}.flex-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary-color)}.text-success{color:var(--success-color)}.text-danger{color:var(--danger-color)}.text-warning{color:var(--warning-color)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}@media (width<=1200px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media (width<=992px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.filter-bar{flex-direction:column}.filter-bar .filter-item{min-width:100%}.header{padding:0 var(--spacing-md)}.content-wrapper,.card-body{padding:var(--spacing-md)}}@media (width<=576px){html{font-size:14px}.modal{margin:var(--spacing-sm);max-height:calc(100vh - var(--spacing-md))}}
