:root{--primary:#4f46e5;--primary-light:#6366f1;--primary-dark:#3730a3;--secondary:#0ea5e9;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--sidebar-width:240px;--header-height:60px;--border-radius:8px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;color:var(--gray-800);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.5}#app{height:100%}a{color:inherit;text-decoration:none}input,select,button,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0003}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-200)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{color:var(--primary);border:1px solid var(--primary);background:0 0}.btn-outline:hover{background:#eff6ff}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:10px 20px;font-size:15px}.form-label{color:var(--gray-700);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-label .required{color:var(--danger);margin-left:2px}.form-control{border:1px solid var(--gray-300);width:100%;color:var(--gray-800);background:#fff;border-radius:6px;outline:none;padding:9px 12px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-control::placeholder{color:var(--gray-400)}textarea.form-control{resize:vertical;min-height:80px}.form-hint{color:var(--gray-500);margin-top:4px;font-size:12px}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:11.5px;font-weight:500;display:inline-flex}.badge-success{color:#065f46;background:#d1fae5}.badge-danger{color:#991b1b;background:#fee2e2}.badge-warning{color:#92400e;background:#fef3c7}.badge-info{color:#1e40af;background:#dbeafe}.toggle{width:40px;height:22px;display:inline-block;position:relative}.toggle input{display:none}.toggle-slider{cursor:pointer;background:var(--gray-300);border-radius:11px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";width:16px;height:16px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:all .3s;position:absolute;bottom:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.form-group{margin-bottom:20px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.card{border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--gray-100);background:#fff;overflow:hidden}.card-header{border-bottom:1px solid var(--gray-100);align-items:center;gap:12px;padding:16px 20px;display:flex}.card-title{color:var(--gray-800);font-size:15px;font-weight:600}.card-subtitle{color:var(--gray-500);margin-top:1px;font-size:12px}.card-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.card-body{padding:20px}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--gray-50);text-align:left;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--gray-200);white-space:nowrap;padding:10px 16px;font-size:12px;font-weight:600}tbody td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:12px 16px;font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--gray-50)}.search-bar{align-items:center;display:inline-flex;position:relative}.search-bar input{border:1px solid var(--gray-300);color:var(--gray-700);background:#fff;border-radius:6px;outline:none;width:220px;padding:8px 12px 8px 36px;font-size:13px;transition:border-color .15s}.search-bar input:focus{border-color:var(--primary)}.search-bar .search-icon{color:var(--gray-400);pointer-events:none;font-size:14px;position:absolute;left:10px}.pagination{border-top:1px solid var(--gray-100);align-items:center;gap:4px;padding:16px 20px;display:flex}.pagination-info{color:var(--gray-500);margin-right:auto;font-size:13px}.page-btn{border:1px solid var(--gray-200);cursor:pointer;width:32px;height:32px;color:var(--gray-600);background:#fff;border-radius:6px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.page-btn:hover{background:var(--gray-50)}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.show{display:flex}.modal{box-shadow:var(--shadow-lg);background:#fff;border-radius:12px;width:560px;max-width:90vw;max-height:85vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--gray-100);align-items:center;gap:12px;padding:20px 24px 16px;display:flex}.modal-title{color:var(--gray-900);font-size:16px;font-weight:600}.modal-close{background:var(--gray-100);cursor:pointer;width:28px;height:28px;color:var(--gray-500);border:none;border-radius:6px;justify-content:center;align-items:center;margin-left:auto;font-size:16px;transition:background .15s;display:flex}.modal-close:hover{background:var(--gray-200)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--gray-100);background:#fff;align-items:flex-start;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.stat-icon.blue{background:#eff6ff}.stat-icon.green{background:#f0fdf4}.stat-icon.orange{background:#fff7ed}.stat-icon.purple{background:#f5f3ff}.stat-value{color:var(--gray-900);font-size:24px;font-weight:700;line-height:1.2}.stat-label{color:var(--gray-500);margin-top:2px;font-size:12px}.stat-change{align-items:center;gap:3px;margin-top:4px;font-size:12px;display:flex}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}.progress-bar{background:var(--gray-200);border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .3s}.alert{border-radius:8px;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.alert-info{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.alert-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.alert-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.alert-danger{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.success-toast[data-v-8eb1425f]{z-index:10050;border-radius:var(--border-radius,8px);color:var(--success,#10b981);box-shadow:var(--shadow-lg,0 10px 15px -3px #0000001a);pointer-events:none;background:#fff;border:1px solid #10b98140;padding:10px 20px;font-size:14px;font-weight:500;position:fixed;top:24px;left:50%;transform:translate(-50%)}.success-toast-enter-active[data-v-8eb1425f],.success-toast-leave-active[data-v-8eb1425f]{transition:opacity .2s,transform .2s}.success-toast-enter-from[data-v-8eb1425f],.success-toast-leave-to[data-v-8eb1425f]{opacity:0;transform:translate(-50%)translateY(-8px)}
