:root{--brand-50:#ecfeff;--brand-100:#cffafe;--brand-200:#a5f3fc;--brand-300:#67e8f9;--brand-400:#22d3ee;--brand-500:#06b6d4;--brand-600:#0891b2;--brand-700:#0e7490;--brand-800:#155e75;--brand-900:#164e63;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;--slate-950:#020617;--success:#059669;--success-bg:#d1fae5;--warning:#d97706;--warning-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee2e2;--info:#2563eb;--info-bg:#dbeafe;--bg:var(--slate-50);--surface:#fff;--surface-2:var(--slate-100);--border:var(--slate-200);--border-strong:var(--slate-300);--text:var(--slate-900);--text-muted:var(--slate-500);--text-soft:var(--slate-400);--text-on-brand:#fff;--sb-bg:var(--surface);--sb-border:var(--border);--sb-text:var(--slate-700);--sb-text-muted:var(--slate-500);--sb-active-bg:var(--brand-50);--sb-active-text:var(--brand-700);--sb-hover-bg:var(--slate-100);--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--shadow-sm:0 1px 2px #0f172a0a;--shadow:0 1px 3px #0f172a14,0 1px 2px #0f172a0a;--shadow-md:0 4px 12px #0f172a14;--shadow-lg:0 12px 30px #0f172a1f;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;--font-sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,sans-serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,monospace;--fs-xs:12px;--fs-sm:13px;--fs-md:14px;--fs-lg:16px;--fs-xl:20px;--fs-2xl:24px;--fs-3xl:30px;--sidebar-w:256px;--sidebar-w-collapsed:72px;--topbar-h:64px}.theme-superadmin{--sb-bg:var(--slate-900);--sb-border:var(--slate-800);--sb-text:#cbd5e1;--sb-text-muted:#64748b;--sb-active-bg:#0891b22e;--sb-active-text:var(--brand-300);--sb-hover-bg:#ffffff0a}*,:after,:before{box-sizing:border-box}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:var(--fs-md);line-height:1.5;margin:0}a{color:var(--brand-700);text-decoration:none}a:hover{color:var(--brand-800)}h1,h2,h3,h4,h5{color:var(--text);font-weight:600;letter-spacing:-.01em;margin:0}h1{font-size:var(--fs-3xl)}h2{font-size:var(--fs-2xl)}h3{font-size:var(--fs-xl)}p{margin:0}button{cursor:pointer;font-family:inherit}.app-shell{display:grid;grid-template-areas:"sidebar topbar" "sidebar main";grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;min-height:100vh}.app-sidebar{grid-area:sidebar}.app-topbar{grid-area:topbar}.app-main{grid-area:main;overflow-x:hidden;padding:var(--s-6) var(--s-8)}@media (max-width:960px){.app-shell{grid-template-areas:"topbar" "main";grid-template-columns:1fr}.app-main{padding:var(--s-5)}.app-sidebar{display:none}.app-sidebar.is-open{display:block}}.auth-shell{background:radial-gradient(1200px 600px at 80% -10%,var(--brand-100),#0000 60%),radial-gradient(800px 400px at -10% 110%,var(--brand-50),#0000 60%),var(--slate-50);display:grid;grid-template-columns:1fr;min-height:100vh}@media (min-width:960px){.auth-shell{grid-template-columns:1.1fr 1fr}}.auth-aside{background:linear-gradient(180deg,#0891b2f2,#0891b2d9),radial-gradient(600px 300px at 70% 10%,#ffffff2e,#0000),var(--brand-700);color:var(--slate-100);display:none;overflow:hidden;padding:var(--s-12);position:relative}@media (min-width:960px){.auth-aside{display:flex;flex-direction:column;justify-content:space-between}}.auth-aside h1{color:#fff;font-size:36px;line-height:1.15;max-width:520px}.auth-aside .auth-tagline{color:#ffffffd9;font-size:16px;margin-top:var(--s-3);max-width:480px}.auth-aside .auth-feature-list{grid-gap:var(--s-3);display:grid;gap:var(--s-3);margin-top:var(--s-8)}.auth-aside .auth-feature{align-items:flex-start;color:#ffffffeb;display:flex;gap:var(--s-3)}.auth-aside .auth-feature .dot{background:var(--brand-200);border-radius:50%;flex-shrink:0;height:8px;margin-top:8px;width:8px}.auth-aside .auth-foot{color:#ffffffb3;font-size:13px}.auth-main{align-items:center;display:flex;justify-content:center;padding:var(--s-12) var(--s-6)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);max-width:420px;padding:var(--s-8);width:100%}.auth-card h2{margin-bottom:var(--s-2)}.auth-card .auth-sub{margin-bottom:var(--s-6)}.auth-card .auth-sub,.muted{color:var(--text-muted)}.text-xs{font-size:var(--fs-xs)}.text-sm{font-size:var(--fs-sm)}.text-lg{font-size:var(--fs-lg)}.text-xl{font-size:var(--fs-xl)}.text-2xl{font-size:var(--fs-2xl)}.bold{font-weight:600}.row{align-items:center;display:flex;gap:var(--s-3)}.row.between{justify-content:space-between}.row.wrap{flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:var(--s-3)}.grid{grid-gap:var(--s-4);display:grid;gap:var(--s-4)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width:960px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.spacer{flex:1 1}.divider{background:var(--border);height:1px;margin:var(--s-4) 0}@media (max-width:600px){.hide-mobile{display:none!important}}.btn{align-items:center;background:var(--surface);border:1px solid #0000;border-radius:var(--radius);color:var(--text);display:inline-flex;font-size:var(--fs-md);font-weight:500;gap:var(--s-2);padding:9px 14px;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;white-space:nowrap}.btn:hover{background:var(--slate-100)}.btn:disabled{cursor:not-allowed;opacity:.55}.btn:focus-visible{outline:2px solid var(--brand-500);outline-offset:2px}.btn-primary{background:var(--brand-700);border-color:var(--brand-700);color:#fff}.btn-primary:hover{background:var(--brand-800)}.btn-outline{background:var(--surface);border-color:var(--border-strong);color:var(--brand-700)}.btn-outline:hover{background:var(--brand-50);border-color:var(--brand-300)}.btn-ghost{background:#0000;border-color:#0000;color:var(--slate-700)}.btn-ghost:hover{background:var(--slate-100)}.btn-danger{background:var(--surface);border-color:var(--border-strong);color:var(--danger)}.btn-danger:hover{background:var(--danger-bg)}.btn-sm{font-size:var(--fs-sm);padding:6px 10px}.btn-block{justify-content:center;width:100%}.btn-icon{padding:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--s-6)}.card.compact{padding:var(--s-4)}.card-title{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--s-4)}.card-title h3{font-size:var(--fs-lg)}.stat-card{align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:var(--s-4);padding:var(--s-5);transition:transform .15s,box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card .stat-icon{align-items:center;background:var(--brand-50);border-radius:var(--radius);color:var(--brand-700);display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.stat-card .stat-icon.indigo{background:#eef2ff;color:#4338ca}.stat-card .stat-icon.amber{background:var(--warning-bg);color:var(--warning)}.stat-card .stat-icon.rose{background:var(--danger-bg);color:var(--danger)}.stat-card .stat-icon.emerald{background:var(--success-bg);color:var(--success)}.stat-card .stat-icon.slate{background:var(--slate-100);color:var(--slate-700)}.stat-card .stat-label{color:var(--text-muted);font-size:var(--fs-sm)}.stat-card .stat-value{color:var(--text);font-size:26px;font-weight:700;letter-spacing:-.02em;margin-top:2px}.stat-card .stat-delta{align-items:center;display:inline-flex;font-size:var(--fs-xs);gap:4px;margin-top:6px}.stat-card .stat-delta.up{color:var(--success)}.stat-card .stat-delta.down{color:var(--danger)}.stat-card .stat-delta.flat{color:var(--text-muted)}.sidebar{background:var(--sb-bg);border-right:1px solid var(--sb-border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;width:var(--sidebar-w);z-index:30}.sidebar-brand{align-items:center;border-bottom:1px solid var(--sb-border);display:flex;gap:var(--s-3);height:var(--topbar-h);padding:0 var(--s-5)}.sidebar-brand .brand-mark{align-items:center;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));border-radius:8px;color:#fff;display:flex;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-brand .brand-text{color:var(--sb-text);font-size:15px;font-weight:700;letter-spacing:-.01em}.sidebar-brand .brand-sub{color:var(--sb-text-muted);display:block;font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:var(--s-3) var(--s-3)}.sidebar-section-label{color:var(--sb-text-muted);font-size:11px;letter-spacing:.06em;padding:var(--s-3) var(--s-3) var(--s-1);text-transform:uppercase}.sidebar-link{align-items:center;border-radius:var(--radius);color:var(--sb-text);display:flex;font-size:var(--fs-md);font-weight:500;gap:var(--s-3);padding:9px var(--s-3);position:relative}.sidebar-link:hover{background:var(--sb-hover-bg);color:var(--sb-text)}.sidebar-link.is-active{background:var(--sb-active-bg);color:var(--sb-active-text)}.sidebar-link.is-active:before{background:var(--sb-active-text);border-radius:3px;bottom:8px;content:"";left:-3px;position:absolute;top:8px;width:3px}.sidebar-link svg{flex-shrink:0;height:18px;width:18px}.sidebar-foot{border-top:1px solid var(--sb-border);color:var(--sb-text-muted);font-size:var(--fs-xs);padding:var(--s-3) var(--s-4)}.sidebar-backdrop{background:#0f172a73;display:none;inset:0;position:fixed;z-index:25}@media (max-width:960px){.sidebar{display:flex;inset:0 auto 0 0;position:fixed;transform:translateX(-100%);transition:transform .2s}.sidebar.is-open{transform:translateX(0)}.sidebar-backdrop.is-open{display:block}}.topbar{border-bottom:1px solid var(--border);display:flex;gap:var(--s-4);height:var(--topbar-h);padding:0 var(--s-6);position:sticky;top:0;z-index:20}.topbar,.topbar .menu-btn{align-items:center;background:var(--surface)}.topbar .menu-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--slate-700);display:none;height:40px;justify-content:center;width:40px}@media (max-width:960px){.topbar .menu-btn{display:inline-flex}}.topbar-search{align-items:center;background:var(--slate-100);border:1px solid #0000;border-radius:var(--radius);color:var(--slate-700);display:flex;flex:1 1;gap:var(--s-2);height:40px;max-width:480px;padding:0 var(--s-3)}.topbar-search input{background:#0000;border:0;color:inherit;flex:1 1;font:inherit;outline:0}.topbar-search input::placeholder{color:var(--slate-400)}.topbar-actions{align-items:center;display:flex;gap:var(--s-2)}.icon-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius);color:var(--slate-600);display:inline-flex;height:40px;justify-content:center;position:relative;width:40px}.icon-btn:hover{background:var(--slate-100)}.icon-btn .ping{background:var(--danger);border:2px solid var(--surface);border-radius:50%;height:8px;position:absolute;right:8px;top:8px;width:8px}.profile-trigger{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:999px;display:flex;gap:var(--s-3);padding:4px var(--s-3) 4px 4px}.profile-trigger:hover{background:var(--slate-100)}.profile-avatar{align-items:center;background:linear-gradient(135deg,var(--brand-300),var(--brand-700));border-radius:50%;color:#fff;display:flex;font-size:13px;font-weight:600;height:32px;justify-content:center;width:32px}.profile-info{line-height:1.1;text-align:left}.profile-info .name{color:var(--text);font-size:13px;font-weight:600}.profile-info .role{color:var(--text-muted);font-size:11px}@media (max-width:600px){.profile-info{display:none}}.dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:220px;padding:var(--s-2);position:absolute;right:0;top:calc(100% + 8px);z-index:40}.dropdown-item{align-items:center;background:#0000;border:0;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;display:flex;font-size:var(--fs-md);gap:var(--s-2);padding:8px 10px;text-align:left;width:100%}.dropdown-item:hover{background:var(--slate-100)}.dropdown-item.danger{color:var(--danger)}.dropdown-divider{background:var(--border);height:1px;margin:4px 0}.profile-wrap{position:relative}.page-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--s-4);justify-content:space-between;margin-bottom:var(--s-6)}.page-header h1{font-size:24px}.page-header .crumbs{align-items:center;display:flex;font-size:var(--fs-xs);gap:6px;margin-bottom:4px}.page-header .crumbs,.page-header .crumbs a{color:var(--text-muted)}.page-header .crumbs a:hover{color:var(--text)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--s-4)}.field label{color:var(--text);font-size:var(--fs-sm);font-weight:500}.field .hint{color:var(--text-muted);font-size:var(--fs-xs)}.field .err{color:var(--danger);font-size:var(--fs-xs)}.input,.select,.textarea{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font:inherit;height:40px;outline:none;padding:0 12px;transition:border-color .15s,box-shadow .15s;width:100%}.textarea{height:auto;min-height:96px;padding:10px 12px;resize:vertical}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px #0891b226}.input.is-error,.select.is-error,.textarea.is-error{border-color:var(--danger)}.input::placeholder,.textarea::placeholder{color:var(--slate-400)}.select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='12' height='12' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%2364748b' d='m7 10 5 5 5-5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.file-drop{background:var(--surface-2);border:2px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;padding:var(--s-6);text-align:center;transition:border-color .15s,background .15s}.file-drop.is-drag,.file-drop:hover{background:var(--brand-50);border-color:var(--brand-500);color:var(--brand-800)}.file-drop input[type=file]{display:none}.file-drop-title{color:var(--text);font-weight:600}.file-preview{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;gap:var(--s-3);margin-top:var(--s-3);padding:var(--s-3)}.file-preview .file-meta{flex:1 1}.file-preview .file-size{color:var(--text-muted);font-size:var(--fs-xs)}.badge{align-items:center;background:var(--slate-100);border:1px solid var(--slate-200);border-radius:999px;color:var(--slate-700);display:inline-flex;font-size:var(--fs-xs);font-weight:500;gap:4px;padding:3px 10px;white-space:nowrap}.badge .dot{background:currentColor;border-radius:50%;height:6px;width:6px}.badge.success{background:var(--success-bg);border-color:#a7f3d0;color:#065f46}.badge.warning{background:var(--warning-bg);border-color:#fde68a;color:#92400e}.badge.danger{background:var(--danger-bg);border-color:#fecaca;color:#991b1b}.badge.info{background:var(--info-bg);border-color:#bfdbfe;color:#1e40af}.badge.brand{background:var(--brand-50);border-color:var(--brand-200);color:var(--brand-800)}.badge.neutral{background:var(--slate-100);border-color:var(--slate-200);color:var(--slate-700)}.role-badge{border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.08em;padding:4px 8px;text-transform:uppercase}.role-SUPER_ADMIN{background:#1e293b;color:#67e8f9}.role-ADMIN{background:#ecfeff;border:1px solid #a5f3fc;color:#0e7490}.role-STAFF{background:#eef2ff;border:1px solid #c7d2fe;color:#4338ca}.role-VENDOR{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857}.role-USER{background:#f1f5f9;border:1px solid #e2e8f0;color:#334155}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.table-toolbar{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:var(--s-3);padding:var(--s-4) var(--s-5)}.table-toolbar .grow{flex:1 1;min-width:180px}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;font-size:var(--fs-md);width:100%}.data-table th{background:var(--surface-2);color:var(--text-muted);font-size:var(--fs-xs);font-weight:600;letter-spacing:.05em;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td,.data-table th{border-bottom:1px solid var(--border)}.data-table td{color:var(--text);padding:14px 16px;vertical-align:middle}.data-table tbody tr:hover{background:var(--slate-50)}.data-table tbody tr:last-child td{border-bottom:0}.cell-strong{font-weight:600}.cell-mono{font-family:var(--font-mono);font-size:var(--fs-sm)}.cell-muted{color:var(--text-muted)}.row-actions{display:flex;gap:4px}.row-actions .icon-btn{height:32px;width:32px}.table-pagination{background:var(--surface);border-top:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap;font-size:var(--fs-sm);gap:var(--s-2);justify-content:space-between;padding:var(--s-3) var(--s-5)}.pager,.table-pagination{align-items:center;display:flex}.pager{gap:2px}.pager .btn{min-width:32px;padding:6px 10px}.pager .is-current{background:var(--brand-700);border-color:var(--brand-700);color:#fff}.state{color:var(--text-muted);flex-direction:column;gap:var(--s-3);padding:var(--s-10) var(--s-6);text-align:center}.state,.state .state-icon{align-items:center;display:flex}.state .state-icon{background:var(--brand-50);border-radius:16px;color:var(--brand-700);height:56px;justify-content:center;width:56px}.state h3{color:var(--text)}.state.error .state-icon{background:var(--danger-bg);color:var(--danger)}.spinner{animation:spin .8s linear infinite;border:2px solid var(--brand-100);border-radius:50%;border-top-color:var(--brand-700);display:inline-block;height:20px;width:20px}.spinner.lg{border-width:3px;height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.modal-backdrop{align-items:center;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:var(--s-4);position:fixed;z-index:50}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:460px;overflow:hidden;width:100%}.modal-head{padding:var(--s-5) var(--s-5) var(--s-3)}.modal-head h3{font-size:var(--fs-lg)}.modal-body{color:var(--text-muted);font-size:var(--fs-md);padding:0 var(--s-5) var(--s-5)}.modal-foot{background:var(--surface-2);display:flex;gap:var(--s-2);justify-content:flex-end;padding:var(--s-3) var(--s-5)}.kvs{grid-gap:var(--s-2) var(--s-4);display:grid;gap:var(--s-2) var(--s-4);grid-template-columns:160px 1fr}.kvs dt{color:var(--text-muted);font-size:var(--fs-sm)}.kvs dd{color:var(--text);font-size:var(--fs-md);margin:0}@media (max-width:600px){.kvs{grid-template-columns:1fr}}.callout{background:var(--brand-50);border-left:3px solid var(--brand-500);border-radius:var(--radius);color:var(--brand-900);font-size:var(--fs-sm);padding:var(--s-3) var(--s-4)}.skeleton{animation:shimmer 1.4s linear infinite;background:linear-gradient(90deg,var(--slate-100),var(--slate-200),var(--slate-100));background-size:200% 100%;border-radius:var(--radius-sm);height:16px}@keyframes shimmer{0%{background-position:0 0}to{background-position:-200% 0}}.bar-track{background:var(--slate-100);border-radius:999px;height:8px;overflow:hidden}.bar-fill{background:linear-gradient(90deg,var(--brand-500),var(--brand-700));height:100%}.list-row{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:var(--s-3);justify-content:space-between;padding:var(--s-3) 0}.list-row:last-child{border-bottom:0}.tag-stack{display:flex;flex-wrap:wrap;gap:6px}.notice{background:var(--info-bg);border-radius:var(--radius);color:#1e3a8a;font-size:var(--fs-sm);padding:var(--s-3) var(--s-4)}.notice.warning{background:var(--warning-bg);color:#78350f}
/*# sourceMappingURL=main.a8b67559.css.map*/