:root{--color-bg: #f0f4f8;--color-surface: #ffffff;--color-surface-muted: #f8fafc;--color-text: #0f172a;--color-muted: #64748b;--color-primary: #3b82f6;--color-primary-strong: #2563eb;--color-border: rgba(148, 163, 184, .35);--color-sidebar: #0f172a;--color-sidebar-text: #e2e8f0;--color-sidebar-muted: #94a3b8;--color-sidebar-active: rgba(59, 130, 246, .2);--shadow-soft: 0 18px 40px rgba(15, 23, 42, .12);--shadow-sm: 0 8px 24px rgba(15, 23, 42, .08);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .6);--input-bg: rgba(255, 255, 255, .9);--input-border: rgba(148, 163, 184, .4);--font-display: "Plus Jakarta Sans", "Segoe UI", system-ui, -apple-system, sans-serif;--font-body: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif}.dark{--color-bg: #0f172a;--color-surface: rgba(30, 41, 59, .92);--color-surface-muted: rgba(15, 23, 42, .9);--color-text: #e2e8f0;--color-muted: #94a3b8;--color-border: rgba(148, 163, 184, .2);--glass-bg: rgba(30, 41, 59, .65);--glass-border: rgba(148, 163, 184, .15);--input-bg: rgba(15, 23, 42, .8);--input-border: rgba(148, 163, 184, .3)}*,*:before,*:after{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b899;border-radius:999px}.dark ::-webkit-scrollbar-thumb{background:#475569cc}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.app-shell{position:relative;display:flex;min-height:100%;height:100%;overflow:hidden}.app-bg{position:absolute;inset:0;pointer-events:none;z-index:0}.bg-blob{position:absolute;width:40%;height:40%;border-radius:999px;filter:blur(120px);opacity:.65}.bg-blob--left{top:-12%;left:-10%;background:#3b82f640}.bg-blob--right{bottom:-12%;right:-10%;background:#6366f133}.dark .bg-blob--left{background:#3b82f61f}.dark .bg-blob--right{background:#6366f11f}.sidebar-overlay{position:fixed;inset:0;background:#0f172a66;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:2}.sidebar-overlay.open{opacity:1;pointer-events:auto}.sidebar{width:180px;background:var(--color-sidebar);color:var(--color-sidebar-text);padding:18px 12px;display:flex;flex-direction:column;gap:20px;position:relative;z-index:3;border-right:1px solid rgba(148,163,184,.2);overflow-y:auto}.sidebar-header{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid rgba(148,163,184,.2)}.sidebar-header .material-icons-round{color:#60a5fa}.sidebar-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:#fff;line-height:1.1}.sidebar-subtitle{font-size:12px;color:var(--color-sidebar-muted);text-transform:uppercase;letter-spacing:.12em}.sidebar-section{display:flex;flex-direction:column;gap:0}.sidebar-section+.sidebar-section{margin-top:8px}.sidebar-section-toggle{width:100%;border:none;background:linear-gradient(135deg,#0f172ae6,#1e293be6);color:inherit;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;text-align:left;border-radius:999px;border:1px solid rgba(148,163,184,.2);box-shadow:0 10px 24px #0f172a2e;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease,background .2s ease}.sidebar-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-sidebar-muted);margin:0}.sidebar-section-toggle:hover{transform:translateY(-1px);border-color:#60a5fa73;box-shadow:0 14px 28px #0f172a4d;background:linear-gradient(135deg,#1e293bf2,#334155f2)}.sidebar-section-toggle[aria-expanded=true]{background:linear-gradient(135deg,#1e40af40,#2563eb33);border-color:#60a5fa99;box-shadow:inset 0 0 0 1px #60a5fa26,0 12px 26px #0f172a59}.sidebar-section-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f659,0 12px 26px #0f172a59}.sidebar-section-chevron{font-size:18px;color:var(--color-sidebar-muted);transition:transform .2s ease,color .2s ease}.sidebar-section-toggle:hover .sidebar-section-chevron{color:#fff}.sidebar-section-toggle[aria-expanded=true] .sidebar-section-title,.sidebar-section-toggle[aria-expanded=true] .sidebar-section-chevron{color:#bfdbfe}.sidebar-section-chevron.open{transform:rotate(180deg)}.sidebar-section-links{display:grid;gap:6px;max-height:0;overflow:hidden;opacity:0;transform:translateY(-4px);transition:max-height .2s ease,opacity .2s ease,transform .2s ease}.sidebar-section-links.open{max-height:320px;opacity:1;transform:translateY(0);margin-top:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:inherit;border:1px solid transparent;transition:background .2s ease,color .2s ease,border-color .2s ease}.sidebar-link .material-icons-round{font-size:18px;color:var(--color-sidebar-muted)}.sidebar-link:hover{background:#94a3b826;color:#fff}.sidebar-link.active{background:var(--color-sidebar-active);border-color:#3b82f680;color:#60a5fa}.sidebar-link.active .material-icons-round{color:#60a5fa}.sidebar-profile{margin-top:auto;padding-top:14px;border-top:1px solid rgba(148,163,184,.2);display:flex;align-items:center;gap:12px}.avatar{width:40px;height:40px;border-radius:999px;background:linear-gradient(135deg,#60a5fab3,#6366f1cc);display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#fff}.sidebar-profile-name{font-size:14px;font-weight:600;color:#fff}.sidebar-profile-role{font-size:12px;color:var(--color-sidebar-muted)}.app-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1}.topbar{margin:16px 20px 0;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-radius:var(--radius-lg)}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-title{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0}.topbar-subtitle{margin:0;font-size:12px;color:var(--color-muted)}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:999px;padding:6px 12px;min-width:220px}.topbar-search .material-icons-round{font-size:18px;color:var(--color-muted)}.topbar-search input{border:none;background:transparent;padding:0;outline:none;font-size:13px;color:inherit}.topbar-search input::placeholder{color:var(--color-muted)}.topbar-actions{display:flex;align-items:center;gap:10px}.page{flex:1;overflow-y:auto;padding:20px}.panel,.card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--glass-border)}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.page-stack{display:flex;flex-direction:column;gap:16px}.section-title{font-family:var(--font-display);font-size:22px;font-weight:700;margin:0 0 4px}.muted{color:var(--color-muted)}input,textarea,select{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--input-border);background:var(--input-bg);color:inherit;font:inherit;transition:box-shadow .2s ease,border-color .2s ease,background .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f62e}.input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44442e}.error-text{color:#ef4444;font-size:12px}label{font-weight:600;margin-bottom:6px;display:block}input[type=checkbox],input[type=radio]{width:auto;accent-color:var(--color-primary)}.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease,opacity .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-strong)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{background:transparent;color:inherit;border-color:var(--color-border)}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-ghost{background:transparent;color:var(--color-muted)}.btn-ghost:hover:not(:disabled){color:var(--color-primary)}.icon-btn{width:36px;height:36px;border-radius:12px;border:1px solid var(--color-border);background:var(--input-bg);color:var(--color-muted);display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease,border-color .2s ease}.icon-btn:hover{color:var(--color-primary);border-color:#3b82f666}.icon-btn.active{background:var(--color-primary);color:#fff;border-color:transparent}.icon-btn.danger{color:#ef4444}.flex{display:flex}.row{display:flex;flex-direction:row;gap:12px}.column{display:flex;flex-direction:column;gap:12px}.center{display:flex;align-items:center;justify-content:center}.text-right{text-align:right}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.ml-2{margin-left:8px}.ml-auto{margin-left:auto}.m-0{margin:0}.p-3{padding:12px}.p-4{padding:16px}.p-5{padding:20px}.p-6{padding:24px}.p-7{padding:28px}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-md{font-size:14px}.text-lg{font-size:16px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.font-bold{font-weight:700}.min-w-select{min-width:180px}.min-w-160{min-width:160px}.min-w-200{min-width:200px}.min-w-220{min-width:220px}.min-w-240{min-width:240px}.max-w-260{max-width:260px}.max-w-form{max-width:860px}.w-full{width:100%}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-col-center{display:flex;flex-direction:column;align-items:center;justify-content:center}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.self-end{align-self:flex-end}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-pointer{cursor:pointer}.py-2{padding-top:10px;padding-bottom:10px}.mt-6{margin-top:6px}.mb-6{margin-bottom:6px}.p-18{padding:18px}.p-22{padding:22px}.text-icon-lg{font-size:64px}.text-18{font-size:18px}.opacity-40{opacity:.4}.opacity-70{opacity:.7}.max-w-100{max-width:100px}.max-w-400{max-width:400px}.min-h-screen{min-height:100vh}.min-h-60vh{min-height:60vh}.text-danger{color:#ef4444}.text-center{text-align:center}.spacer{flex:1;min-width:0}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.span-2{grid-column:span 2}.checkbox-group{flex-direction:row;align-items:center;gap:10px}.checkbox-group label{margin:0}.form-actions{display:flex;gap:10px;align-items:center;margin-top:8px}.table-wrap{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface)}thead{background:var(--color-surface-muted)}th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--color-border);vertical-align:top}tbody tr:nth-child(odd){background:#fff9}.dark tbody tr:nth-child(odd){background:#0f172a66}tbody tr:hover{background:#3b82f61f}.table-actions{display:flex;gap:8px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#94a3b833;font-size:12px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.chip--success{background:#22c55e26;color:#15803d}.chip--danger{background:#ef444426;color:#b91c1c}.chip--neutral{background:#94a3b833;color:var(--color-text)}.alert{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid rgba(239,68,68,.3);background:#ef444426;color:#b91c1c;margin-bottom:12px}.alert--error{border-color:#ef44444d;background:#ef444426;color:#b91c1c}.alert--success{border-color:#22c55e4d;background:#ecfdf3;color:#065f46}.alert--warning{border-color:#f59e0b4d;background:#fffbeb;color:#92400e}.dark .alert--error{color:#fca5a5}.dark .alert--success{background:#22c55e26;color:#34d399}.dark .alert--warning{background:#f59e0b26;color:#fbbf24}.inventory-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.inventory-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.inventory-actions select{width:auto;min-width:200px}.inventory-empty{min-height:180px;display:grid;place-items:center;text-align:center;gap:6px;color:var(--color-muted)}.inventory-empty .material-icons-round{font-size:32px;opacity:.4}.inventory-item{display:flex;align-items:center;gap:10px}.inventory-item-thumb{width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-surface-muted);overflow:hidden;display:grid;place-items:center;flex-shrink:0}.inventory-item-thumb img{width:100%;height:100%;object-fit:cover}.inventory-item-thumb .material-icons-round{font-size:18px;color:var(--color-muted)}.inventory-item-name{font-size:13px;font-weight:600}.inventory-item-sku{font-size:11px;color:var(--color-muted)}.inventory-chip{font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;background:#94a3b833;color:var(--color-text)}.inventory-qty input{max-width:110px}.inventory-details{display:grid;gap:12px}.inventory-total{display:flex;justify-content:space-between;align-items:center;padding-top:8px;font-size:13px;color:var(--color-muted);border-top:1px solid var(--color-border)}.inventory-total strong{color:var(--color-text);font-size:16px}.summary-sticky{position:sticky;top:16px;align-self:start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:30;padding:20px}.modal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px;width:min(960px,95vw);max-height:85vh;overflow:auto;box-shadow:var(--shadow-soft)}.modal-card--compact{width:min(1608px,95vw);max-height:76vh;padding:12px}.attachment-list{margin-top:8px;display:grid;gap:6px}.attachment-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 10px;border-radius:10px;background:#fff9;border:1px solid var(--color-border)}.attachment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.attachment-card{border-radius:12px;border:1px solid var(--color-border);overflow:hidden;background:#fff;display:flex;flex-direction:column}.attachment-card img{width:100%;height:120px;object-fit:cover}.attachment-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px}.attachment-inline{display:flex;align-items:center;gap:6px}.attachment-inline img{width:34px;height:34px;object-fit:cover;border-radius:6px;border:1px solid var(--color-border)}.btn-xs{padding:4px 10px;font-size:12px;border-radius:999px}.col-actions{width:180px}.col-actions-lg{width:200px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:16px}.empty-state .material-icons-round{font-size:64px;opacity:.4}.product-thumb-table{width:120px;height:120px;object-fit:cover;border-radius:10px;border:1px solid var(--color-border)}.input-narrow{max-width:100px}.input-medium{max-width:120px}@media(max-width:1024px){.sidebar{position:fixed;left:0;top:0;height:100vh;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.topbar{margin:12px 16px 0}.page{padding:16px}}@media(min-width:1025px){.modal-overlay{padding-left:200px}.menu-btn{display:none}}@media(max-width:860px){.topbar-search{display:none}.summary-sticky{position:static}}@media(max-width:640px){.inventory-toolbar,.panel-header{flex-direction:column;align-items:flex-start}.inventory-actions select{width:100%;min-width:0}}.auth-page[data-v-0dc3fd1f]{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px}.auth-card[data-v-0dc3fd1f]{width:min(420px,92vw);display:grid;gap:16px}.auth-header[data-v-0dc3fd1f]{display:flex;align-items:center;gap:12px}.auth-icon[data-v-0dc3fd1f]{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#3b82f62e;color:#60a5fa}
