:root{--primary: #0c679b;--primary-hover: #0a5682;--primary-light: #e6f1f7;--primary-mid: #b3d1e2;--success: #10b981;--success-light: #ecfdf5;--warning: #f59e0b;--warning-light: #fffbeb;--danger: #ef4444;--danger-light: #fef2f2;--info: #0ea5e9;--info-light: #f0f9ff;--bg: #f8fafc;--bg-card: #ffffff;--bg-hover: #f1f5f9;--border: #e2e8f0;--border-mid: #cbd5e1;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-white: #ffffff;--sidebar-bg: #1e293b;--sidebar-text: #94a3b8;--sidebar-active: #60a5fa;--sidebar-hover: rgba(255, 255, 255, .06);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .12);--shadow-card: 0 2px 8px rgba(0, 0, 0, .06);--radius-sm: .5rem;--radius: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;font-family:Inter,system-ui,-apple-system,sans-serif}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;font-size:16px}body.widget-mode{background:#fff;margin:0;padding:0;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:700;line-height:1.2}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:inherit;font-size:.95rem;font-weight:600;border-radius:var(--radius);border:1px solid transparent;padding:.75rem 1.4rem;cursor:pointer;transition:all .18s ease;white-space:nowrap;line-height:1}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--text-white);border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 16px #2563eb4d;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-mid)}.btn-danger{background:var(--danger-light);color:var(--danger);border-color:#ef444433}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#059669;box-shadow:0 4px 14px #10b9814d;transform:translateY(-1px)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:.9rem 1.85rem;font-size:1.1rem}.btn-icon{padding:.5rem;border-radius:var(--radius-sm)}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em}.form-control{width:100%;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);transition:border-color .18s,box-shadow .18s;outline:none}.form-control::placeholder{color:var(--text-muted)}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.form-control:disabled{background:var(--bg);color:var(--text-muted);cursor:not-allowed}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:90px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em}.badge-success{background:var(--success-light);color:var(--success)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-info{background:var(--info-light);color:var(--info)}.badge-neutral{background:var(--bg-hover);color:var(--text-secondary)}.badge-primary{background:var(--primary-light);color:var(--primary)}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse;background:var(--bg-card);font-size:.95rem}.table th{padding:1.1rem 1.25rem;text-align:left;font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--bg);border-bottom:1px solid var(--border)}.table td{padding:1.2rem 1.25rem;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-hover)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header-text h1{font-size:1.6rem;font-weight:800;color:var(--text-primary)}.page-header-text p{color:var(--text-secondary);font-size:1rem;margin-top:.35rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-card);transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.stat-icon.blue{background:var(--primary-light)}.stat-icon.green{background:var(--success-light)}.stat-icon.yellow{background:var(--warning-light)}.stat-icon.sky{background:var(--info-light)}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:.9rem;color:var(--text-muted);margin-top:.4rem;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:modal-in .22s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 1rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.1rem;font-weight:700}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.25rem;width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:1.5rem 1.75rem}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.75rem 1.5rem;border-top:1px solid var(--border)}.alert{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--radius);border:1px solid;font-size:.875rem;margin-bottom:1rem}.alert-error{background:var(--danger-light);border-color:#ef444433;color:#dc2626}.alert-success{background:var(--success-light);border-color:#10b98133;color:#059669}.alert-info{background:var(--info-light);border-color:#0ea5e933;color:#0284c7}.search-wrap{position:relative;display:inline-flex;align-items:center}.search-wrap svg{position:absolute;left:.8rem;color:var(--text-muted);pointer-events:none}.search-wrap input{padding-left:2.5rem;min-width:240px}.empty-state{text-align:center;padding:4rem 2rem}.empty-state-icon{font-size:3.5rem;margin-bottom:1rem}.empty-state h3{font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem}.empty-state p{color:var(--text-muted);font-size:.875rem}.loading-dots{display:flex;gap:5px;align-items:center;justify-content:center}.loading-dots span{width:7px;height:7px;background:currentColor;border-radius:50%;animation:ld-bounce 1.1s infinite ease-in-out}.loading-dots span:nth-child(2){animation-delay:.18s}.loading-dots span:nth-child(3){animation-delay:.36s}@keyframes ld-bounce{0%,80%,to{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}
