*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-d:#1d4ed8;--primary-light:#eff6ff;--primary-ring:rgba(37,99,235,.25);--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--red:#ef4444;--red-light:#fef2f2;--red-d:#dc2626;--green:#22c55e;--green-light:#f0fdf4;--green-d:#16a34a;--yellow:#f59e0b;--yellow-light:#fffbeb;--yellow-d:#d97706;--blue:#3b82f6;--blue-light:#eff6ff;--purple:#8b5cf6;--purple-light:#f5f3ff;--white:#fff;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--sidebar-w:240px;--sidebar-bg:#0f172a;--sidebar-hover:hsla(0,0%,100%,.07);--sidebar-active:rgba(37,99,235,.85);--radius-sm:6px;--radius:10px;--radius-lg:14px;--shadow-sm:0 1px 2px rgba(0,0,0,.06);--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);--shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.05);--shadow-lg:0 10px 25px rgba(0,0,0,.1),0 4px 8px rgba(0,0,0,.06);--transition:0.15s ease}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;color:var(--gray-800);background:var(--bg);-webkit-font-smoothing:antialiased}h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--gray-900)}h2{font-size:1.2rem;font-weight:650;letter-spacing:-.01em}h3{font-size:1rem}h3,h4{font-weight:600}h4{font-size:.875rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;line-height:1.4;transition:all var(--transition);white-space:nowrap;text-decoration:none;position:relative}.btn:focus-visible{outline:3px solid var(--primary-ring);outline-offset:2px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn:active:not(:disabled){transform:translateY(0) scale(.97)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 3px rgba(37,99,235,.35)}.btn-primary:hover:not(:disabled){background:var(--primary-d);border-color:var(--primary-d);box-shadow:0 4px 12px rgba(37,99,235,.4);transform:translateY(-1px)}.btn-success{background:var(--green-d);color:#fff;border-color:var(--green-d);box-shadow:0 1px 3px rgba(22,163,74,.35)}.btn-success:hover:not(:disabled){background:#15803d;border-color:#15803d;box-shadow:0 4px 12px rgba(22,163,74,.4);transform:translateY(-1px)}.btn-danger{background:var(--red-d);color:#fff;border-color:var(--red-d);box-shadow:0 1px 3px rgba(220,38,38,.35)}.btn-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c;box-shadow:0 4px 12px rgba(220,38,38,.4);transform:translateY(-1px)}.btn-warning{background:var(--yellow-d);color:#fff;border-color:var(--yellow-d)}.btn-warning:hover:not(:disabled){background:#b45309;border-color:#b45309}.btn-ghost{background:var(--white);color:var(--gray-600);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--gray-50);color:var(--gray-800);border-color:var(--gray-300)}.btn-ghost-danger{background:transparent;color:var(--red);border-color:var(--border)}.btn-ghost-danger:hover:not(:disabled){background:var(--red-light);border-color:var(--red)}.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}.btn-outline:hover:not(:disabled){background:var(--primary-light)}.btn-outline-success{background:transparent;color:var(--green-d);border-color:var(--green-d)}.btn-outline-success:hover:not(:disabled){background:var(--green-light);transform:translateY(-1px)}.btn-outline-danger{background:transparent;color:var(--red-d);border-color:var(--red-d)}.btn-outline-danger:hover:not(:disabled){background:var(--red-light);transform:translateY(-1px)}.btn-outline-warning{background:transparent;color:var(--yellow-d);border-color:var(--yellow-d)}.btn-outline-warning:hover:not(:disabled){background:var(--yellow-light)}.btn-xs{padding:.2rem .45rem;font-size:.7rem;border-radius:4px;gap:.2rem;line-height:1.3}.btn-sm{padding:.35rem .7rem;font-size:.78rem}.btn-lg{padding:.65rem 1.35rem;font-size:.95rem}.btn-icon{padding:.35rem;border-radius:var(--radius-sm);line-height:1}.btn-icon svg{display:block;width:16px;height:16px}.btn-icon.btn-xs{padding:.2rem}.btn-icon.btn-xs svg{width:14px;height:14px}.form-group{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.form-group label{font-size:.8rem;font-weight:500;color:var(--gray-700)}.form-group small{font-size:.75rem;color:var(--gray-400);margin-top:.15rem}input,select,textarea{font-family:inherit;font-size:.85rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--gray-800);transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}input:disabled,select:disabled,textarea:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed}.input{font-family:inherit;font-size:.85rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--gray-800);transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}textarea{resize:vertical;min-height:60px}select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.card-title{font-size:.95rem;font-weight:600;color:var(--gray-800);margin-bottom:.2rem}.card-subtitle{font-size:.8rem;color:var(--gray-500);margin-bottom:1rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}thead th{text-align:left;padding:.6rem .75rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);border-bottom:2px solid var(--border);white-space:nowrap}tbody td{padding:.55rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:hover{background:var(--gray-50)}td.num{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.td-actions{display:flex;justify-content:flex-end;gap:.3rem}.badge,.td-actions{align-items:center;white-space:nowrap}.badge{display:inline-flex;gap:.25rem;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#15803d}.badge-red{background:#fee2e2;color:#b91c1c}.badge-yellow{background:#fef3c7;color:#b45309}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-purple{background:#ede9fe;color:#7c3aed}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem;margin-bottom:1.25rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;box-shadow:var(--shadow-sm)}.stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:.3rem}.stat-value{font-weight:600;font-size:.95rem;color:var(--gray-700)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem;gap:.75rem;flex-wrap:wrap}.page-title{font-size:1.35rem;font-weight:700;letter-spacing:-.01em;color:var(--gray-900)}.page-subtitle{font-size:.85rem;color:var(--gray-500);margin-top:.1rem}.toolbar{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.search-box{position:relative}.search-box input{padding-left:2.1rem;min-width:220px}.search-box svg{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;z-index:1000;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:540px;padding:1.5rem;animation:modalIn .15s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem}.modal-title{font-size:1.05rem;font-weight:600;color:var(--gray-900)}.modal-close{background:none;border:none;font-size:1.4rem;color:var(--gray-400);cursor:pointer;line-height:1;padding:0}.modal-close:hover{color:var(--gray-600)}.modal-footer{justify-content:flex-end;gap:.6rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.alert,.modal-footer{display:flex;align-items:center}.alert{padding:.7rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:1rem;gap:.5rem}.alert-error{background:var(--red-light);color:var(--red-d);border:1px solid #fecaca}.alert-success{background:var(--green-light);color:var(--green-d);border:1px solid #bbf7d0}.alert-info{background:var(--blue-light);color:var(--primary-d);border:1px solid #bfdbfe}.alert-warning{background:var(--yellow-light);color:#92400e;border:1px solid #fde68a}.empty-state{text-align:center;padding:2rem 1rem;color:var(--gray-400)}.empty-state p{font-size:.85rem}.loading-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem;color:var(--gray-400)}.spinner{width:28px;height:28px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%}.spinner,.spinner-sm{animation:spin .6s linear infinite}.spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%}@keyframes spin{to{transform:rotate(1turn)}}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);overflow-x:auto}.tab{background:none;padding:.6rem 1rem;font-size:.85rem;font-weight:500;color:var(--gray-500);cursor:pointer;white-space:nowrap;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color var(--transition),border-color var(--transition);font-family:inherit}.tab:hover{color:var(--gray-700)}.tab-active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}@media (max-width:768px){.page-header{flex-direction:column}h1{font-size:1.25rem}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}