.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#1a56db 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--white);border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 25px 60px #0000004d}.login-logo{align-items:center;gap:14px;margin-bottom:32px;display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;font-weight:800;display:flex}.login-logo h1{color:var(--gray-800);font-size:18px;font-weight:700;line-height:1.2}.login-logo p{color:var(--gray-400);font-size:12px}.login-form h2{color:var(--gray-800);margin-bottom:24px;font-size:20px;font-weight:600}.login-error{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.form-group label{color:var(--gray-600);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-group input{border:1.5px solid var(--gray-200);width:100%;color:var(--text);background:var(--gray-100);border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #1a56db1a}.password-wrap{position:relative}.password-wrap input{padding-right:44px}.toggle-pass{cursor:pointer;background:0 0;border:none;padding:0;font-size:16px;line-height:1;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-btn{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:8px;padding:12px;font-size:15px;font-weight:600;transition:opacity .2s,transform .1s}.login-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;color:var(--gray-400);margin-top:28px;font-size:12px}.topbar{height:var(--topbar-height);background:var(--nav-bg);z-index:200;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:0 14px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-left{align-items:center;gap:10px;display:flex}.sidebar-toggle{width:30px;height:30px;color:var(--nav-text,#94a3b8);border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.sidebar-toggle:hover{color:var(--nav-text,#94a3b8);filter:brightness(1.3);background:#8080801f}.topbar-brand{align-items:center;gap:7px;display:flex}.brand-icon{background:var(--primary);color:#fff;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.brand-logo-img{object-fit:contain;flex-shrink:0;width:auto;height:28px;display:block}.brand-name{color:var(--nav-text,white);letter-spacing:-.02em;filter:brightness(1.4);font-size:13.5px;font-weight:600}.topbar-right{align-items:center;gap:14px;display:flex}.topbar-welcome{color:var(--nav-text,#64748b);letter-spacing:-.01em;opacity:.7;font-size:12px}.topbar-welcome strong{color:var(--nav-text,#94a3b8);opacity:1;font-weight:500}@media (width<=540px){.topbar-welcome{display:none}}.account-menu{position:relative}.account-btn{color:var(--nav-text,#94a3b8);background:#8080800f;border:1px solid #80808026;border-radius:6px;align-items:center;gap:6px;padding:4px 8px 4px 4px;transition:all .15s;display:flex}.account-btn:hover{filter:brightness(1.2);background:#8080801f}.avatar{background:linear-gradient(135deg, var(--primary), #818cf8);color:#fff;letter-spacing:.02em;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:9.5px;font-weight:700;display:flex}.avatar.lg{border-radius:7px;width:32px;height:32px;font-size:12px}.account-label{font-size:12px;font-weight:500}@media (width<=480px){.account-label{display:none}}.account-dropdown{border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:300;background:#fff;border-radius:10px;min-width:220px;animation:.12s fadeDown;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}@keyframes fadeDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:var(--gray-50);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 14px;display:flex}.dropdown-name{color:var(--gray-800);letter-spacing:-.01em;font-size:13px;font-weight:600}.dropdown-email{color:var(--gray-400);margin-top:1px;font-size:11px}.dropdown-role{color:var(--primary);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:10px;font-weight:600}.dropdown-divider{background:var(--border);height:1px}.dropdown-item{width:100%;color:var(--gray-700);cursor:pointer;text-align:left;letter-spacing:-.01em;background:0 0;border:none;align-items:center;gap:8px;padding:8px 14px;font-size:12.5px;transition:background .12s;display:flex}.dropdown-item:hover{background:var(--gray-50)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:#fef2f2}.navbar{top:var(--topbar-height);height:var(--nav-height);background:var(--nav-bar-bg);z-index:150;scrollbar-width:none;border-bottom:1px solid #ffffff0d;position:fixed;left:0;right:0;overflow-x:auto}.navbar::-webkit-scrollbar{display:none}.navbar-inner{align-items:center;gap:1px;min-width:max-content;height:100%;padding:0 10px;display:flex}.nav-item{color:var(--nav-tab-text,#52525b);cursor:pointer;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;background:0 0;border:none;border-radius:5px;padding:5px 13px;font-size:11px;font-weight:600;transition:all .15s}.nav-item:hover{color:var(--nav-text-active,#e4e4e7);background:#80808014}.nav-item.active{color:var(--nav-text-active,white);background:#8080801a;font-weight:600;position:relative}.nav-item.active:after{content:"";background:var(--nav-color,var(--primary));border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:13px;right:13px}.sidebar{top:calc(var(--topbar-height) + var(--nav-height));width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;border-right:1px solid #ffffff0a;flex-direction:column;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:0;left:0;overflow:hidden auto;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-header{border-bottom:1px solid #ffffff0a;padding:12px 12px 8px}.sidebar-title{text-transform:uppercase;letter-spacing:.08em;color:var(--nav-color,var(--primary));opacity:.9;font-size:10px;font-weight:700}.sidebar-nav{flex-direction:column;gap:1px;padding:6px;display:flex}.sidebar-link,.sidebar-group-btn{color:var(--sidebar-text);cursor:pointer;text-align:left;letter-spacing:-.01em;background:0 0;border:none;border-radius:5px;align-items:center;gap:8px;width:100%;padding:6px 8px;font-size:12px;font-weight:450;text-decoration:none;transition:background .12s,color .12s;display:flex}.sidebar-link:hover,.sidebar-group-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-active)}.sidebar-link.active{background:var(--sidebar-hover);color:var(--sidebar-active);font-weight:600}.sidebar-link.active .sidebar-icon{color:var(--sidebar-active);opacity:1}.sidebar-group-label{color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.06em;opacity:.6;align-items:center;gap:8px;padding:6px 8px;font-size:11px;font-weight:700;display:flex}.sidebar-group-label.active{color:var(--sidebar-active);opacity:1}.sidebar-icon{opacity:.7;flex-shrink:0;justify-content:center;align-items:center;width:16px;display:flex}.sidebar-link:hover .sidebar-icon,.sidebar-group-btn:hover .sidebar-icon,.sidebar-link.active .sidebar-icon{opacity:1}.sidebar-label{flex:1}.sidebar-chevron{color:var(--sidebar-text);opacity:.4;flex-shrink:0;transition:transform .2s}.sidebar-chevron.open{opacity:.7;transform:rotate(90deg)}.sidebar-children{border-left:1px solid #ffffff0f;flex-direction:column;gap:1px;margin-top:1px;margin-left:8px;padding-left:8px;display:flex}.sidebar-child{color:var(--sidebar-text);letter-spacing:-.01em;border-radius:4px;align-items:center;gap:7px;padding:5px 8px;font-size:11.5px;font-weight:450;text-decoration:none;transition:background .12s,color .12s;display:flex}.sidebar-child:hover{background:var(--sidebar-hover);color:var(--sidebar-active)}.sidebar-child.active{color:var(--sidebar-active);background:var(--sidebar-hover);font-weight:600}.sidebar-child.active .sidebar-icon{color:var(--sidebar-active);opacity:1}.coming-soon{text-align:center;min-height:60vh;color:var(--gray-400);flex-direction:column;justify-content:center;align-items:center;display:flex}.coming-soon-icon{margin-bottom:16px;font-size:48px}.coming-soon h2{color:var(--gray-600);margin-bottom:8px;font-size:22px;font-weight:600}.coming-soon p{font-size:14px}.access-sections{flex-direction:column;gap:16px;display:flex}.access-nav-group{border:1.5px solid var(--gray-200);border-radius:10px;overflow:hidden}.access-nav-header{background:var(--gray-100);padding:12px 16px}.access-nav-toggle{cursor:pointer;align-items:center;gap:10px;font-size:14px;display:flex}.access-nav-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.access-nav-label{font-size:13px;font-weight:700}.access-modules{padding:0 16px 12px}.access-modules-header{text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);border-bottom:1px solid var(--gray-200);text-align:center;grid-template-columns:1fr 60px 60px 60px 60px;padding:8px 0 6px;font-size:10px;font-weight:700;display:grid}.access-modules-header span:first-child{text-align:left}.access-module-row{border-bottom:1px solid var(--gray-200);grid-template-columns:1fr 60px 60px 60px 60px;align-items:center;padding:7px 0;font-size:13px;display:grid}.access-module-row:last-child{border-bottom:none}.module-label{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.module-parent{color:var(--gray-400);font-size:11px}.default-tag{background:var(--primary-light);color:var(--primary);border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.access-checkbox{cursor:pointer;justify-content:center;display:flex}.access-checkbox input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer}.users-page{max-width:1080px}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;letter-spacing:-.01em;border:none;padding:6px 14px;font-size:12px;font-weight:600;transition:opacity .15s}.page-toolbar{align-items:center;gap:10px;margin-bottom:10px;display:flex}.search-input{border:1px solid var(--border);border-radius:var(--radius);max-width:300px;color:var(--text);background:#fff;outline:none;flex:1;padding:6px 11px;font-size:12.5px;transition:border-color .15s,box-shadow .15s}.data-table th:first-child{border-radius:var(--radius-lg) 0 0 0}.data-table th:last-child{border-radius:0 var(--radius-lg) 0 0}.emp-no{background:var(--gray-100);color:var(--gray-500);letter-spacing:.01em;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:500}.user-cell{align-items:center;gap:9px;display:flex}.user-avatar-sm{background:linear-gradient(135deg, var(--primary), #818cf8);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:700;display:flex}.user-badge-you{background:var(--primary-light);color:var(--primary);letter-spacing:.01em;border-radius:4px;margin-top:2px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.role-badge{text-transform:capitalize;letter-spacing:.01em;border-radius:4px;padding:2px 7px;font-size:10.5px;font-weight:600}.role-superadmin{color:#92400e;background:#fef3c7}.role-admin{color:#1e40af;background:#dbeafe}.role-manager{color:#065f46;background:#d1fae5}.role-staff{background:var(--gray-100);color:var(--gray-500)}.status-badge{letter-spacing:.01em;border-radius:4px;padding:2px 7px;font-size:10.5px;font-weight:600}.status-badge.active{color:#065f46;background:#d1fae5}.status-badge.inactive{color:#991b1b;background:#fee2e2}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.modal-close{background:var(--gray-100);cursor:pointer;width:24px;height:24px;color:var(--gray-500);border:none;border-radius:5px;justify-content:center;align-items:center;font-size:13px;transition:background .12s;display:flex}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.form-group input,.form-group select{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:#fff;outline:none;padding:7px 10px;font-size:12.5px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.btn-secondary{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--gray-700);letter-spacing:-.01em;background:#fff;padding:6px 14px;font-size:12px;font-weight:500;transition:background .12s}.settings-page{max-width:860px}.settings-page .page-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.settings-page .page-header h1{color:var(--gray-900);letter-spacing:-.03em;font-size:17px;font-weight:700}.settings-page .page-header p{color:var(--text-muted);margin-top:2px;font-size:12px}.logo-toast{border-radius:6px;margin-bottom:12px;padding:8px 12px;font-size:12px}.logo-toast-success{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.logo-toast-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.logo-settings-row{flex-wrap:wrap;align-items:flex-start;gap:24px;display:flex}.logo-preview-box{flex-shrink:0}.logo-preview-label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);margin-bottom:8px;font-size:11px;font-weight:600}.logo-preview-inner{background:var(--gray-50);border:1px solid var(--border);border-radius:8px;flex-direction:column;align-items:center;gap:8px;min-width:120px;padding:16px;display:flex}.logo-preview-img{object-fit:contain;max-width:160px;max-height:56px}.logo-remove-btn{color:var(--gray-400);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;font-size:11px;transition:color .12s;display:flex}.logo-remove-btn:hover{color:#ef4444}.logo-inputs{flex-direction:column;flex:1;gap:12px;min-width:240px;display:flex}.logo-input-label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);align-items:center;gap:5px;margin-bottom:6px;font-size:11px;font-weight:600;display:flex}.logo-upload-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--gray-700);cursor:pointer;background:#fff;padding:6px 14px;font-size:12px;font-weight:500;transition:background .12s}.logo-upload-btn:hover:not(:disabled){background:var(--gray-50)}.logo-upload-btn:disabled{opacity:.6;cursor:not-allowed}.logo-hint{color:var(--text-muted);margin-top:4px;font-size:11px;display:block}.logo-divider-or{color:var(--gray-300);align-items:center;gap:8px;font-size:11px;display:flex}.logo-divider-or:before,.logo-divider-or:after{content:"";background:var(--border);flex:1;height:1px}.logo-url-row{gap:7px;display:flex}.logo-url-input{border:1px solid var(--border);border-radius:var(--radius);outline:none;flex:1;padding:7px 10px;font-family:SF Mono,monospace;font-size:12.5px;transition:border-color .15s}.logo-url-input:focus{border-color:var(--primary)}.logo-url-save-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:600;transition:opacity .15s;display:flex}.logo-url-save-btn:hover{opacity:.88}.settings-card{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;padding:18px}.settings-section-title{color:var(--gray-800);letter-spacing:-.02em;margin-bottom:3px;font-size:13px;font-weight:700}.settings-section-sub{color:var(--text-muted);margin-bottom:20px;font-size:11.5px}.theme-group{margin-bottom:20px}.theme-group:last-child{margin-bottom:0}.theme-group-label{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:6px;font-size:10.5px;font-weight:700}.theme-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;display:grid}.theme-card{border:1.5px solid var(--border);cursor:pointer;text-align:left;background:#fff;border-radius:8px;padding:8px;transition:border-color .15s,box-shadow .15s}.theme-card:hover{border-color:var(--gray-300);box-shadow:var(--shadow-sm)}.theme-card.selected{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.theme-preview{border:1px solid var(--border);border-radius:5px;flex-direction:column;height:56px;margin-bottom:7px;display:flex;overflow:hidden}.theme-preview-nav{flex-shrink:0;height:12px}.theme-preview-body{flex:1;display:flex}.theme-preview-sidebar{flex-shrink:0;width:24px}.theme-preview-content{flex-direction:column;flex:1;gap:3px;padding:4px;display:flex}.theme-preview-bar{border-radius:2px;height:4px}.theme-preview-bar.short{width:55%}.theme-info{justify-content:space-between;align-items:center;gap:4px;display:flex}.theme-name{color:var(--gray-700);letter-spacing:-.01em;font-size:11px;font-weight:600}.theme-active-badge{color:var(--primary);font-size:10px;font-weight:800;line-height:1}.store-page{max-width:1100px}.page-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.page-header h1{color:var(--gray-900);letter-spacing:-.03em;font-size:17px;font-weight:700}.page-header p{color:var(--text-muted);margin-top:2px;font-size:12px}.header-actions{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.page-toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.search-wrap{position:relative}.search-icon{color:var(--gray-400);position:absolute;top:50%;left:9px;transform:translateY(-50%)}.filter-select{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:#fff;outline:none;padding:6px 10px;font-size:12.5px;transition:border-color .15s}.filter-select:focus{border-color:var(--primary)}.user-count{color:var(--text-muted);font-size:11.5px}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:12.5px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--gray-50);padding:8px 12px;font-size:11px;font-weight:600}.data-table th.text-right{text-align:right}.data-table th.text-center{text-align:center}.data-table td{border-bottom:1px solid var(--border);color:var(--gray-700);vertical-align:middle;padding:9px 12px}.data-table td.text-right{text-align:right}.data-table td.text-center{text-align:center}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--gray-50)}.table-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:40px!important}.text-muted{color:var(--gray-400);font-size:12px}.user-name{color:var(--gray-800);letter-spacing:-.01em;font-size:12.5px;font-weight:500}.emp-no{background:var(--gray-100);color:var(--gray-500);border-radius:4px;padding:2px 6px;font-size:11px;font-weight:500}.count-badge{background:var(--gray-100);color:var(--gray-500);border-radius:10px;padding:2px 7px;font-size:11px}.row-child td{color:var(--gray-500)}.child-indent{color:var(--gray-300);margin-right:4px}.cat-name{color:var(--gray-800);font-weight:500}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-green{background:#34d399}.dot-gray{background:var(--gray-200)}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.filter-tabs{flex-wrap:wrap;gap:4px;display:flex}.filter-tab{border:1px solid var(--border);cursor:pointer;color:var(--gray-500);background:#fff;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:500;transition:all .12s}.filter-tab:hover{background:var(--gray-50);color:var(--gray-700)}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.status-badge{white-space:nowrap;border-radius:4px;padding:2px 7px;font-size:11px;font-weight:600}.badge-active,.status-badge.active{color:#065f46;background:#d1fae5}.badge-inactive,.status-badge.inactive{color:#991b1b;background:#fee2e2}.badge-gray{color:#64748b;background:#f1f5f9}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-yellow{color:#92400e;background:#fef3c7}.badge-purple{color:#6d28d9;background:#ede9fe}.badge-teal{color:#065f46;background:#ccfbf1}.badge-orange{color:#c2410c;background:#ffedd5}.badge-green{color:#15803d;background:#dcfce7}.badge-red{color:#991b1b;background:#fee2e2}.action-btns{gap:3px;display:flex}.action-btn{border:1px solid var(--border);cursor:pointer;width:26px;height:26px;color:var(--gray-500);background:#fff;border-radius:5px;justify-content:center;align-items:center;transition:all .12s;display:flex}.action-btn:hover{background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-700)}.action-btn.deactivate:hover{color:var(--danger);background:#fef2f2;border-color:#fca5a5}.action-btn.activate:hover{color:#059669;background:#ecfdf5;border-color:#6ee7b7}.action-btn.edit:hover{color:var(--primary);border-color:var(--primary-light);background:#eef2ff}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:600;transition:opacity .15s;display:flex}.btn-primary:hover{opacity:.88}.btn-secondary{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--gray-700);background:#fff;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:500;transition:background .12s;display:flex}.btn-secondary:hover{background:var(--gray-50)}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400;background:#00000059;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-lg);background:#fff;animation:.15s fadeDown;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);z-index:1;background:#fff;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex;position:sticky;top:0}.modal-header h2{letter-spacing:-.02em;font-size:14px;font-weight:700}.modal-close{background:var(--gray-100);cursor:pointer;width:24px;height:24px;color:var(--gray-500);border:none;border-radius:5px;justify-content:center;align-items:center;transition:background .12s;display:flex}.modal-close:hover{background:var(--gray-200)}.modal-tabs{border-bottom:1px solid var(--border);gap:2px;padding:0 16px;display:flex}.modal-tab{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 14px;font-size:12px;font-weight:500;transition:all .15s}.modal-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-tab:hover:not(.active){color:var(--gray-700)}.modal-body{padding:14px 16px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:7px;padding:11px 16px;display:flex}.fw-medium{font-weight:600}.mono-text{font-family:SF Mono,Menlo,monospace;font-size:11.5px}.cell-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:160px;overflow:hidden}.row-inactive td{opacity:.55}.search-wrap{align-items:center;display:flex;position:relative}.search-wrap>svg{color:var(--gray-400);pointer-events:none;position:absolute;left:9px}.search-input{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:#fff;outline:none;width:240px;padding:6px 28px;font-size:12.5px;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.search-clear{cursor:pointer;color:var(--gray-400);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;right:8px}.search-clear:hover{color:var(--gray-600)}.info-box{border:1px solid var(--border);color:var(--gray-700);background:#f8fafc;border-radius:6px;padding:10px 12px;font-size:12.5px}.order-summary{background:var(--gray-50);color:var(--gray-600);border-radius:6px;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;display:flex}.order-summary strong{color:var(--gray-900);font-size:15px}.modal.modal-sm{max-width:360px}.modal.modal-md{max-width:560px}.modal.modal-lg{max-width:820px}.form-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.form-grid-2{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px;display:grid}.form-group{margin-bottom:0}.form-group.col-2{grid-column:1/-1}.form-group label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.label-hint{text-transform:none;color:var(--gray-400);letter-spacing:0;font-size:10px;font-weight:400}.form-input{box-sizing:border-box;border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:#fff;outline:none;padding:7px 10px;font-size:12.5px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}textarea.form-input{resize:vertical}.form-row-inline{align-items:center;gap:20px;display:flex}.checkbox-group{flex-wrap:wrap;gap:10px;margin-top:6px;display:flex}.checkbox-label{color:var(--gray-700);cursor:pointer;align-items:center;gap:6px;font-size:12px;display:flex}.info-note{color:#0369a1;background:#f0f9ff;border-radius:6px;padding:9px 12px;font-size:12px;line-height:1.5}.info-note.col-2{grid-column:1/-1}.margin-note{color:#065f46;background:#f0fdf4;border-radius:6px;grid-column:1/-1;padding:9px 12px;font-size:12px;font-weight:500}.toast{z-index:999;box-shadow:var(--shadow-md);letter-spacing:-.01em;border-radius:8px;padding:9px 14px;font-size:12.5px;font-weight:500;animation:.18s fadeUp;position:fixed;bottom:20px;right:20px}.toast-success{color:#fff;background:#18181b}.toast-error{background:var(--danger);color:#fff}.main-layout{flex-direction:column;min-height:100vh;display:flex}.layout-body{padding-top:calc(var(--topbar-height) + var(--nav-height));flex:1;display:flex}.content-area{flex:1;min-width:0;padding:16px;transition:margin-left .3s}.content-area.sidebar-open{margin-left:var(--sidebar-width)}.sidebar-overlay{display:none}@media (width<=768px){.content-area.sidebar-open{margin-left:0}.sidebar-overlay{z-index:99;background:#00000080;display:block;position:fixed;inset:0}}.portal-login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.portal-login-card{background:#fff;border-radius:16px;width:100%;max-width:380px;padding:40px 36px;box-shadow:0 20px 60px #0000004d}.portal-login-brand{text-align:center;margin-bottom:28px}.portal-login-icon{color:#f59e0b;margin:0 auto 12px;display:block}.portal-login-brand h1{color:#0f172a;margin:0 0 4px;font-size:16px;font-weight:700;line-height:1.3}.portal-login-brand p{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:12px;font-weight:500}.portal-login-form{flex-direction:column;gap:14px;display:flex}.portal-login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:7px;padding:10px 12px;font-size:13px}.portal-login-group label{color:#374151;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.portal-login-group input{box-sizing:border-box;border:1px solid #e5e7eb;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .15s}.portal-login-group input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.portal-login-btn{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:8px;width:100%;margin-top:4px;padding:11px;font-size:14px;font-weight:600;transition:background .15s}.portal-login-btn:hover{background:#1e293b}.portal-login-btn:disabled{cursor:not-allowed;background:#94a3b8}.portal-login-hint{text-align:center;color:#9ca3af;margin:0;font-size:12px}.portal-layout{background:#f1f5f9;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.portal-header{color:#e2e8f0;z-index:100;background:#0f172a;align-items:center;gap:24px;height:60px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #0000004d}.portal-brand{flex:1;align-items:center;gap:10px;display:flex}.portal-logo-icon{color:#f59e0b}.portal-brand-name{color:#f8fafc;white-space:nowrap;font-size:13px;font-weight:700}.portal-brand-sub{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:500}.portal-nav{align-items:center;gap:4px;display:flex}.portal-nav-link{color:#94a3b8;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.portal-nav-link:hover{color:#e2e8f0;background:#ffffff12}.portal-nav-link.active{color:#f59e0b;background:#f59e0b26}.portal-user{align-items:center;gap:8px;display:flex}.portal-username{color:#e2e8f0;font-size:13px;font-weight:600}.portal-custno{color:#475569;font-family:SF Mono,Menlo,monospace;font-size:11px}.portal-logout-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s;display:flex}.portal-logout-btn:hover{color:#f87171}.portal-main{max-width:1100px;margin:0 auto;padding:28px 24px}.portal-page h1{color:#0f172a;margin:0 0 4px;font-size:20px;font-weight:700}.portal-page .sub{color:#64748b;margin-bottom:20px;font-size:13px}.catalog-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.catalog-search-wrap{flex:1;min-width:180px;position:relative}.catalog-search-wrap svg{color:#94a3b8;position:absolute;top:50%;left:9px;transform:translateY(-50%)}.catalog-search{box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:7px;width:100%;padding:7px 9px 7px 30px;font-size:13px}.catalog-filter{color:#374151;background:#fff;border:1px solid #e2e8f0;border-radius:7px;padding:7px 10px;font-size:13px}.catalog-layout{grid-template-columns:1fr 320px;align-items:start;gap:20px;display:grid}.catalog-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.catalog-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:6px;padding:14px;transition:box-shadow .15s,border-color .15s;display:flex}.catalog-card:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #00000014}.catalog-card-sku{color:#94a3b8;text-transform:uppercase;font-family:SF Mono,monospace;font-size:10px}.catalog-card-name{color:#1e293b;font-size:13px;font-weight:600;line-height:1.35}.catalog-card-cat{color:#64748b;font-size:11px}.catalog-card-stock{color:#94a3b8;font-size:11px}.catalog-price-row{align-items:baseline;gap:6px;margin-top:4px;display:flex}.price-regular{color:#0f172a;font-size:13px;font-weight:700}.price-regular.struck{color:#94a3b8;font-weight:400;text-decoration:line-through}.price-bulk{color:#059669;font-size:14px;font-weight:700}.price-bulk-label{color:#059669;font-size:10px;font-weight:600}.catalog-card-footer{align-items:center;gap:6px;margin-top:6px;display:flex}.qty-input{text-align:center;border:1px solid #e2e8f0;border-radius:5px;width:52px;padding:4px 6px;font-size:12px}.add-to-cart-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:600;transition:background .15s;display:flex}.add-to-cart-btn:hover{background:#4338ca}.add-to-cart-btn.in-cart{background:#059669}.add-to-cart-btn:disabled{cursor:not-allowed;background:#d1d5db}.cart-sidebar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;position:sticky;top:80px}.cart-title{color:#1e293b;align-items:center;gap:6px;margin-bottom:12px;font-size:14px;font-weight:700;display:flex}.cart-empty{color:#94a3b8;text-align:center;padding:20px 0;font-size:12px}.cart-item{border-bottom:1px solid #f1f5f9;align-items:flex-start;gap:8px;padding:8px 0;display:flex}.cart-item-name{color:#1e293b;flex:1;font-size:12px;font-weight:600}.cart-item-qty{color:#64748b;font-size:11px}.cart-item-price{color:#0f172a;white-space:nowrap;font-size:12px;font-weight:600}.cart-remove-btn{cursor:pointer;color:#94a3b8;background:0 0;border:none;align-items:center;padding:0;display:flex}.cart-remove-btn:hover{color:#ef4444}.bulk-notice{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:6px;align-items:flex-start;gap:6px;margin:10px 0;padding:8px 10px;font-size:11px;display:flex}.bulk-notice.warn{color:#92400e;background:#fffbeb;border-color:#fde68a}.cart-totals{padding-top:10px}.cart-totals-row{color:#64748b;justify-content:space-between;padding:3px 0;font-size:12px;display:flex}.cart-totals-row.total{color:#0f172a;border-top:1px solid #e2e8f0;margin-top:6px;padding-top:6px;font-size:14px;font-weight:700}.cart-notes{margin:10px 0}.cart-notes textarea{resize:vertical;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:7px;font-size:12px}.submit-order-btn{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:8px;width:100%;margin-top:12px;padding:10px;font-size:13px;font-weight:600;transition:background .15s}.submit-order-btn:hover{background:#1e293b}.submit-order-btn:disabled{cursor:not-allowed;background:#94a3b8}.portal-orders-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.portal-order-detail{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-top:16px;padding:20px}.portal-status-timeline{align-items:center;gap:0;margin:16px 0;display:flex;overflow-x:auto}.timeline-step{text-align:center;flex:1;min-width:70px;position:relative}.timeline-step:after{content:"";background:#e2e8f0;width:100%;height:2px;position:absolute;top:11px;left:50%}.timeline-step:last-child:after{display:none}.timeline-dot{z-index:1;background:#e2e8f0;border:2px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex;position:relative}.timeline-dot.done{background:#059669;border-color:#059669}.timeline-dot.current{background:#4f46e5;border-color:#4f46e5}.timeline-label{color:#94a3b8;margin-top:4px;font-size:10px}.timeline-step.done .timeline-label{color:#059669}.timeline-step.current .timeline-label{color:#4f46e5;font-weight:600}.payment-upload-box{text-align:center;cursor:pointer;border:2px dashed #e2e8f0;border-radius:8px;padding:20px;transition:border-color .15s}.payment-upload-box:hover{border-color:#4f46e5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#eef2ff;--accent:#f59e0b;--bg:#f8fafc;--sidebar-bg:#0f0f11;--sidebar-text:#94a3b8;--sidebar-active:#6366f1;--sidebar-hover:#1a1a1f;--nav-bg:#09090b;--nav-bar-bg:#111113;--white:#fff;--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;--text:#0f172a;--text-muted:#64748b;--danger:#ef4444;--success:#10b981;--border:#e2e8f0;--radius:6px;--radius-lg:10px;--sidebar-width:216px;--topbar-height:46px;--nav-height:42px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 4px #00000014, 0 0 0 1px #0000000a;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 12px 40px #00000024}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg);color:var(--text);letter-spacing:-.01em;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit}ul{list-style:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:2px}
