input[data-v-cb79bd8a],button[data-v-cb79bd8a]{padding:6px 8px}table[data-v-cb79bd8a]{border-collapse:collapse}th[data-v-cb79bd8a],td[data-v-cb79bd8a]{padding:8px;border-bottom:1px solid #e5e7eb}select[data-v-86bbff50]{padding:6px 8px}th[data-v-86bbff50],td[data-v-86bbff50],th[data-v-4bd0832d],td[data-v-4bd0832d]{padding:8px;border-bottom:1px solid #e5e7eb}:root{font-family:Inter,PingFang SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0f172a;background:radial-gradient(circle at 20% 20%,#f8fafc,#eef2f7 50%,#e5e7eb 90%)}body{margin:0}main{padding:24px;min-height:calc(100vh - 64px)}h1{margin:0 0 12px;font-size:22px;font-weight:700}h2{margin:0 0 12px;font-size:18px;font-weight:600}.section-header h2{display:flex;align-items:center;gap:8px}.section-header h2:after{content:"";display:inline-block;width:6px;height:6px;border-radius:999px;background:linear-gradient(135deg,#2563eb,#7c3aed)}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid #e5e7eb;box-shadow:0 4px 12px #0000000a}.hero{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 120px)}.auth-card{width:100%;max-width:520px}.app-shell{display:grid;grid-template-columns:240px 1fr;gap:16px}.app-content{min-width:0}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px;box-shadow:0 18px 40px #0f172a14}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.table-wrapper{width:100%;overflow-x:auto}.sidebar{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;box-shadow:0 12px 28px #0f172a0f}.sidebar-header{margin-bottom:12px}.sidebar-title{font-weight:700;color:#0f172a}.sidebar-subtitle{font-size:12px}.nav-item{width:100%;text-align:left;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;margin-bottom:8px;cursor:pointer;transition:all .15s ease}.nav-item:hover{background:#eef2ff;border-color:#dfe3f1}.nav-item.active{background:#eef2ff;border-color:#c7d2fe;box-shadow:0 10px 20px #6366f11f}.nav-title{font-weight:600;color:#111827}.nav-desc{font-size:12px}.tabs{display:flex;gap:10px;border-bottom:1px solid #e5e7eb;margin-bottom:12px;flex-wrap:wrap}.tab{padding:12px 16px;border-radius:12px 12px 0 0;border:1px solid transparent;cursor:pointer;font-weight:600;color:#6b7280}.tab.active{background:#fff;border-color:#e5e7eb;border-bottom-color:#fff;color:#111827;box-shadow:0 -4px 16px #0f172a14}.tab:hover{color:#111827}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}input,select{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;min-width:160px;background:#fff}button{padding:10px 14px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .15s ease}.btn-primary{background:#2563eb;color:#fff;box-shadow:0 8px 20px #2563eb40}.btn-primary:hover{background:#1d4ed8}.btn-ghost{background:#f3f4f6;color:#111827;border:1px solid #e5e7eb}.btn-ghost:hover{background:#e5e7eb}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}table{width:100%;border-collapse:collapse}th,td{padding:10px 12px;border-bottom:1px solid #e5e7eb;font-size:14px}thead th{background:#f9fafb;font-weight:600;color:#4b5563}tbody tr:hover{background:#f9fafb}.muted{color:#6b7280;font-size:13px}.section-header{display:flex;justify-content:space-between;align-items:center}.skeleton{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:shimmer 1.4s ease infinite;border-radius:6px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:10px}.toast{min-width:240px;max-width:360px;padding:12px 14px;border-radius:10px;color:#111827;box-shadow:0 10px 30px #0000001f;border:1px solid #e5e7eb;background:#fff}.toast.success{border-color:#bbf7d0;background:#ecfdf3}.toast.error{border-color:#fecdd3;background:#fef2f2}.toast.info{border-color:#bfdbfe;background:#eff6ff}@media (max-width: 768px){main{padding:16px}.grid.two,.app-shell{grid-template-columns:1fr}.sidebar{position:sticky;top:56px;z-index:5}h1{font-size:20px}h2{font-size:17px}table{font-size:13px}.toast-container{right:8px;left:8px}}
