.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 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{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.topbar-nav{scrollbar-width:none;align-items:center;gap:2px;margin-left:16px;display:flex;overflow-x:auto}.topbar-nav::-webkit-scrollbar{display:none}.topbar-nav-item{letter-spacing:-.01em;color:var(--nav-tab-text,#a1a1aa);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:600;transition:all .15s;position:relative}.topbar-nav-item:hover,.topbar-nav-item.active{color:var(--nav-text-active,#fff);background:#8080801a}.topbar-nav-item.active:after{content:"";background:var(--nav-color,var(--primary));border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:14px;right:14px}.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;white-space:nowrap;font-size:12px}.topbar-welcome strong{color:var(--nav-text,#94a3b8);opacity:1;font-weight:500}@media (width<=860px){.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}.sidebar{top:calc(var(--topbar-height) + var(--nav-height));width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;border-right:1px solid #00000012;flex-direction:column;transition:transform .22s 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 #0000000d;margin-bottom:4px;padding:13px 12px 9px}.sidebar-title{text-transform:uppercase;letter-spacing:.09em;color:var(--sidebar-text);opacity:.45;font-size:10.5px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:4px 8px 16px;display:flex}.sidebar-link{color:var(--sidebar-text);letter-spacing:-.01em;border-radius:7px;align-items:center;gap:8px;padding:7px 10px;font-size:12.5px;font-weight:700;text-decoration:none;transition:background .12s,color .12s;display:flex}.sidebar-link:hover{background:var(--sidebar-hover)}.sidebar-link.active{background:var(--primary);color:#fff;font-weight:600}.sidebar-link.active .sidebar-icon{opacity:1;color:#fff}.sidebar-group{margin-top:14px}.sidebar-group:first-child{margin-top:4px}.sidebar-group-label{text-transform:uppercase;letter-spacing:.09em;color:var(--sidebar-text);opacity:.4;padding:0 10px 5px;font-size:10px;font-weight:700}.sidebar-group-label.active{opacity:.65}.sidebar-children{border-left:none;flex-direction:column;gap:1px;margin:0;padding-left:0;display:flex}.sidebar-child{color:var(--sidebar-text);letter-spacing:-.01em;border-radius:7px;align-items:center;gap:8px;padding:7px 10px;font-size:12.5px;font-weight:700;text-decoration:none;transition:background .12s,color .12s;display:flex}.sidebar-child:hover{background:var(--sidebar-hover)}.sidebar-child.active{background:var(--primary);color:#fff;font-weight:600}.sidebar-child.active .sidebar-icon{opacity:1;color:#fff}.sidebar-icon{opacity:.6;flex-shrink:0;justify-content:center;align-items:center;width:15px;transition:opacity .12s;display:flex}.sidebar-link:hover .sidebar-icon,.sidebar-child:hover .sidebar-icon{opacity:.85}.sidebar-link.active .sidebar-icon,.sidebar-child.active .sidebar-icon{opacity:1;color:#fff}.sidebar-label{flex:1}.sidebar-group-btn,.sidebar-chevron{display:none}.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}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;overflow-x:auto}.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-name{color:var(--gray-800);letter-spacing:-.01em;font-size:12.5px;font-weight:500}.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}.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)}.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}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(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);justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.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;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 label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.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:18px;display:flex}.page-header h1{color:var(--gray-900);letter-spacing:-.03em;font-size:20px;font-weight:700}.page-header p{color:var(--text-muted);margin-top:2px;font-size:12.5px}.header-actions{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.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:9999px;padding:4px 12px;font-size:11.5px;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)}.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);color:var(--text);background:#fff;border-radius:7px;outline:none;width:240px;padding:6px 28px 6px 30px;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)}.filter-select{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:7px;outline:none;padding:6px 10px;font-size:12.5px}.filter-select:focus{border-color:var(--primary)}.user-count{color:var(--text-muted);font-size:11.5px}.table-wrap{border:1px solid var(--border);background:#fff;border-radius:10px;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:0 0;padding:9px 14px;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:10px 14px}.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:48px 20px!important}.text-muted{color:var(--gray-400);font-size:12px}.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:.5}.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)}.status-badge{white-space:nowrap;border-radius:9999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-active,.status-badge.active{color:#166534;background:#dcfce7}.badge-inactive,.status-badge.inactive{color:#991b1b;background:#fee2e2}.action-btns{gap:2px;display:flex}.action-btn{cursor:pointer;width:28px;height:28px;color:var(--gray-400);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .12s;display:flex}.action-btn:hover{background:var(--gray-100);color:var(--gray-700)}.action-btn.deactivate:hover{color:#ef4444;background:#fef2f2}.action-btn.activate:hover{color:#059669;background:#ecfdf5}.action-btn.edit:hover{color:var(--primary);background:var(--primary-light)}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:7px;align-items:center;gap:5px;padding:7px 14px;font-size:12.5px;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{border:1px solid var(--border);cursor:pointer;color:var(--gray-700);background:#fff;border-radius:7px;align-items:center;gap:5px;padding:7px 12px;font-size:12.5px;font-weight:500;transition:background .12s;display:inline-flex}.btn-secondary:hover{background:var(--gray-50)}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400;background:#0000004d;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border);background:#fff;border-radius:12px;width:100%;max-width:480px;max-height:90vh;animation:.15s fadeDown;overflow-y:auto;box-shadow:0 20px 60px #0000001f}.modal.modal-sm{max-width:360px}.modal.modal-md{max-width:560px}.modal.modal-lg{max-width:820px}.modal-header{border-bottom:1px solid var(--border);z-index:1;background:#fff;justify-content:space-between;align-items:flex-start;padding:16px 18px 13px;display:flex;position:sticky;top:0}.modal-header h2{letter-spacing:-.02em;color:var(--gray-900);font-size:15px;font-weight:700}.modal-close{background:var(--gray-100);cursor:pointer;width:26px;height:26px;color:var(--gray-500);border:none;border-radius:6px;flex-shrink:0;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 18px;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:12.5px;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:16px 18px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 18px;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-grid-2{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.form-group{margin-bottom:0}.form-group.col-2{grid-column:1/-1}.form-group label{color:var(--gray-600);margin-bottom:5px;font-size:11.5px;font-weight:600;display:block}.label-hint{color:var(--gray-400);margin-left:4px;font-size:10.5px;font-weight:400}.form-input{box-sizing:border-box;border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:7px;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 3px 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:12.5px;display:flex}.info-box{border:1px solid var(--border);color:var(--gray-700);background:#f8fafc;border-radius:7px;padding:10px 12px;font-size:12.5px}.info-note{color:#1d4ed8;background:#eff6ff;border-radius:7px;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:7px;grid-column:1/-1;padding:9px 12px;font-size:12px;font-weight:500}.order-summary{background:var(--gray-50);color:var(--gray-600);border-radius:7px;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}.toast{z-index:999;letter-spacing:-.01em;border-radius:8px;padding:9px 16px;font-size:12.5px;font-weight:500;animation:.18s fadeUp;position:fixed;bottom:20px;right:20px;box-shadow:0 8px 24px #0000001f}.toast-success{color:#fff;background:#18181b}.toast-error{background:var(--danger);color:#fff}.access-rights-page{max-width:1100px}.ar-layout{align-items:flex-start;gap:16px;display:flex}.ar-sidebar{border:1px solid var(--border);background:#fff;border-radius:10px;flex-shrink:0;width:210px;overflow:hidden}.ar-sidebar-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:11px 14px;display:flex}.ar-sidebar-title{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);font-size:11px;font-weight:700}.ar-add-btn{gap:4px;padding:4px 9px;font-size:11.5px}.ar-new-role-form{border-bottom:1px solid var(--border);background:var(--gray-50);padding:12px 14px}.ar-role-list{padding:6px;list-style:none}.ar-role-item{cursor:pointer;color:var(--gray-700);border-radius:7px;align-items:center;gap:8px;padding:8px 10px;font-size:12.5px;font-weight:600;transition:background .12s;display:flex;position:relative}.ar-role-item:hover{background:var(--gray-50)}.ar-role-item.active{background:var(--primary);color:#fff}.ar-role-item.active .ar-system-icon{color:#ffffffb3}.ar-role-item.active .ar-delete-btn{color:#fff9}.ar-role-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.ar-role-name{flex:1}.ar-system-icon{color:var(--gray-300);flex-shrink:0}.ar-delete-btn{cursor:pointer;color:var(--gray-300);background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:2px;transition:color .12s,background .12s;display:flex}.ar-delete-btn:hover{color:#ef4444;background:#fef2f2}.ar-color-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.ar-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:20px;height:20px;transition:transform .12s,border-color .12s}.ar-color-dot.active{border-color:var(--gray-800);transform:scale(1.15)}.ar-matrix-wrap{flex:1;min-width:0}.ar-matrix-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.ar-role-badge{color:#fff;border-radius:9999px;margin-bottom:4px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-block}.ar-system-tag{color:var(--gray-400);background:var(--gray-100);vertical-align:middle;border-radius:9999px;margin-left:6px;padding:2px 7px;font-size:10.5px;font-weight:600;display:inline-block}.ar-role-desc{color:var(--gray-500);margin-top:2px;font-size:12px}.ar-matrix{border:1px solid var(--border);background:#fff;border-radius:10px;overflow:hidden}.ar-group+.ar-group{border-top:1px solid var(--border)}.ar-group-header{background:var(--gray-50);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.ar-group-label{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-500);font-size:11px;font-weight:700}.ar-col-heads{gap:0;display:flex}.ar-col-head{text-align:center;width:72px;color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em;font-size:10.5px;font-weight:700}.ar-col-noaccess{color:#ef4444;width:84px}.ar-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:9px 16px;transition:background .1s;display:flex}.ar-row:last-child{border-bottom:none}.ar-row:hover{background:var(--gray-50)}.ar-row-noaccess{background:#fff5f5}.ar-row-noaccess:hover{background:#fee2e2}.ar-row-noaccess .ar-feat-label{color:var(--gray-400);text-decoration:line-through}.ar-feat-label{color:var(--gray-700);flex:1;font-size:12.5px;font-weight:600}.ar-checks{gap:0;display:flex}.ar-check-noaccess{width:84px}.ar-check-noaccess .ar-checkmark{border-color:#fca5a5}.ar-check-noaccess input:checked~.ar-checkmark{background:#ef4444;border-color:#ef4444}.ar-check{cursor:pointer;justify-content:center;align-items:center;width:72px;display:flex;position:relative}.ar-check input[type=checkbox]{display:none}.ar-checkmark{border:2px solid var(--border);background:#fff;border-radius:5px;justify-content:center;align-items:center;width:18px;height:18px;transition:all .12s;display:flex;position:relative}.ar-check input:checked~.ar-checkmark{background:var(--primary);border-color:var(--primary)}.ar-check input:checked~.ar-checkmark:after{content:"";border:2px solid #fff;border-top:none;border-left:none;width:5px;height:9px;display:block;transform:rotate(45deg)translate(-1px,-1px)}.ar-check.ar-check-na{cursor:default;opacity:.25}.ar-loading{text-align:center;color:var(--gray-400);padding:48px;font-size:13px}.dash-page{max-width:1200px}.dash-header{margin-bottom:24px}.dash-header h1{color:var(--gray-900);margin:0 0 2px;font-size:22px;font-weight:700}.dash-header p{color:var(--gray-500);margin:0;font-size:13px}.dash-stats{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:24px;display:grid}.stat-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:10px;padding:18px 20px;transition:box-shadow .15s;display:flex;position:relative;overflow:hidden}.stat-card:hover{box-shadow:0 4px 16px #00000014}.stat-card-accent{border-radius:12px 12px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.stat-body{flex:1}.stat-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:11px;font-weight:600}.stat-value{color:var(--gray-900);font-size:28px;font-weight:800;line-height:1}.stat-sub{color:var(--gray-400);margin-top:4px;font-size:11.5px}.dash-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-grid-3{grid-template-columns:2fr 1fr;gap:16px;display:grid}@media (width<=900px){.dash-grid-2,.dash-grid-3{grid-template-columns:1fr}}.dash-card{border:1px solid var(--border);background:#fff;border-radius:12px;overflow:hidden}.dash-card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.dash-card-title{color:var(--gray-800);font-size:13px;font-weight:700}.dash-card-link{color:var(--primary);cursor:pointer;background:0 0;border:none;font-size:11.5px;font-weight:600}.dash-card-body{padding:14px 18px}.dash-mini-table{border-collapse:collapse;width:100%;font-size:12.5px}.dash-mini-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);border-bottom:1px solid var(--border);padding:0 0 8px;font-size:10.5px;font-weight:700}.dash-mini-table td{border-bottom:1px solid var(--border);color:var(--gray-700);padding:9px 0}.dash-mini-table tr:last-child td{border-bottom:none}.dash-mini-table .fw{font-weight:600}.badge-gray{color:#6b7280;background:#f3f4f6}.badge-blue{color:#3b82f6;background:#eff6ff}.badge-yellow{color:#d97706;background:#fefce8}.badge-purple{color:#7c3aed;background:#f5f3ff}.badge-teal{color:#0d9488;background:#f0fdf9}.badge-orange{color:#ea580c;background:#fff7ed}.badge-green{color:#16a34a;background:#f0fdf4}.badge-red{color:#dc2626;background:#fef2f2}.badge-sky{color:#0284c7;background:#f0f9ff}.mini-badge{border-radius:9999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.status-bar-wrap{margin-bottom:16px}.status-bar{border-radius:9999px;height:8px;margin:10px 0 8px;display:flex;overflow:hidden}.status-bar-seg{transition:flex .4s}.status-bar-legend{flex-wrap:wrap;gap:8px 14px;display:flex}.status-bar-key{color:var(--gray-600);align-items:center;gap:5px;font-size:11px;display:flex}.status-bar-dot{border-radius:50%;width:8px;height:8px}.dash-quick-links{grid-template-columns:1fr 1fr;gap:8px;padding:14px 18px;display:grid}.dash-quick-link{background:var(--gray-50);border:1px solid var(--border);color:var(--gray-700);cursor:pointer;border-radius:8px;align-items:center;gap:9px;padding:10px 12px;font-size:12.5px;font-weight:600;text-decoration:none;transition:background .12s;display:flex}.dash-quick-link:hover{background:var(--gray-100)}.dash-quick-link-icon{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.dash-empty{text-align:center;color:var(--gray-400);padding:32px 20px;font-size:12.5px}.dash-notice{border-left:3px solid;border-radius:8px;margin-bottom:12px;padding:12px 16px;font-size:12.5px}.dash-notice.info{color:#1e40af;background:#eff6ff;border-color:#3b82f6}.dash-notice.warning{color:#92400e;background:#fefce8;border-color:#f59e0b}.dash-notice.success{color:#166534;background:#f0fdf4;border-color:#22c55e}.dash-donut-row{flex-direction:column;gap:10px;padding:10px 0;display:flex}.dash-donut-item{align-items:center;gap:10px;font-size:12.5px;display:flex}.dash-donut-label{color:var(--gray-700);flex:1;font-weight:600}.dash-donut-count{color:var(--gray-500);margin-right:6px;font-size:12px}.dash-donut-bar{background:var(--gray-100);border-radius:9999px;flex:2;height:6px;overflow:hidden}.dash-donut-fill{border-radius:9999px;height:100%;transition:width .6s}.jo-page{max-width:1200px}.jo-tab-bar{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.jo-tab-btn{border:1.5px solid var(--border,#e5e7eb);color:var(--gray-500,#6b7280);cursor:pointer;white-space:nowrap;background:#fff;border-radius:20px;padding:6px 14px;font-size:12.5px;font-weight:700;transition:background .12s,border-color .12s,color .12s}.jo-tab-btn:hover{color:#7c3aed;background:#f5f3ff;border-color:#c4b5fd}.jo-tab-btn.active{color:#7c3aed;background:#f5f3ff;border-color:#8b5cf6}.badge-submitted{color:#3b82f6;background:#eff6ff}.badge-quoted{color:#a16207;background:#fef9c3}.badge-accepted{color:#7c3aed;background:#f5f3ff}.badge-paid{color:#0d9488;background:#f0fdf9}.badge-completed{color:#16a34a;background:#f0fdf4}.badge-cancelled{color:#dc2626;background:#fef2f2}.badge-draft{color:#6b7280;background:#f3f4f6}.jo-wizard{max-width:820px}.jo-type-row{gap:14px;margin-bottom:24px;display:flex}.jo-type-card{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;flex:1;align-items:flex-start;gap:14px;padding:20px 18px;transition:border-color .15s,box-shadow .15s;display:flex}.jo-type-card.selected{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61f}.jo-type-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.jo-type-label{color:var(--gray-900);margin-bottom:3px;font-size:14px;font-weight:700}.jo-type-desc{color:var(--gray-500);font-size:12px;line-height:1.5}.work-type-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:20px;display:grid}.work-type-chip{border:2px solid var(--border);cursor:pointer;color:var(--gray-700);text-align:left;background:#fff;border-radius:10px;align-items:center;gap:8px;padding:12px 14px;font-size:13px;font-weight:600;transition:border-color .15s,background .15s,color .15s;display:flex}.work-type-chip:hover{background:#f5f3ff;border-color:#c4b5fd}.work-type-chip.active{color:#7c3aed;background:#f5f3ff;border-color:#8b5cf6}.work-type-chip.locked{cursor:default}.work-type-check{border:2px solid var(--border);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:background .12s,border-color .12s;display:flex}.work-type-chip.active .work-type-check{background:#8b5cf6;border-color:#8b5cf6}.jo-items-table{border-collapse:collapse;width:100%;margin-bottom:16px;font-size:13px}.jo-items-table th{background:var(--gray-50);text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);padding:9px 10px;font-size:11px;font-weight:700}.jo-items-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:8px 10px}.jo-items-table tr:last-child td{border-bottom:none}.jo-items-table .item-type{color:#7c3aed;font-weight:700}.jo-items-table input,.jo-items-table textarea{box-sizing:border-box;width:100%}.jo-items-table textarea{resize:vertical;min-height:52px}.jo-steps{border-bottom:2px solid var(--border);gap:0;margin-bottom:28px;padding-bottom:0;display:flex}.jo-step{color:var(--gray-400);cursor:default;border-bottom:2px solid #0000;margin-bottom:-2px;margin-right:32px;padding:0 0 12px;font-size:12.5px;font-weight:700}.jo-step.done{color:#8b5cf6}.jo-step.active{color:#8b5cf6;border-bottom-color:#8b5cf6}.jo-step-num{background:var(--gray-200);width:20px;height:20px;color:var(--gray-500);border-radius:50%;justify-content:center;align-items:center;margin-right:6px;font-size:11px;display:inline-flex}.jo-step.active .jo-step-num,.jo-step.done .jo-step-num{color:#fff;background:#8b5cf6}.jo-section{margin-bottom:24px}.jo-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin:0 0 14px;font-size:11px;font-weight:700}.jo-detail-status{align-items:center;gap:10px;margin-bottom:20px;display:flex}.jo-status-steps{flex-wrap:wrap;align-items:center;gap:0;margin-bottom:20px;display:flex}.jo-status-step{color:var(--gray-300);align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.jo-status-step.done{color:#8b5cf6}.jo-status-step.current{color:#7c3aed}.jo-status-arrow{color:var(--gray-200);margin:0 6px;font-size:14px}.jo-status-dot{background:var(--gray-200);border-radius:50%;width:8px;height:8px}.jo-status-step.done .jo-status-dot{background:#8b5cf6}.jo-status-step.current .jo-status-dot{background:#7c3aed}.customer-search-wrap{position:relative}.customer-dropdown{z-index:200;border:1px solid var(--border);background:#fff;border-radius:8px;max-height:240px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 20px #0000001a}.customer-option{cursor:pointer;align-items:center;gap:10px;padding:10px 14px;font-size:13px;transition:background .1s;display:flex}.customer-option:hover{background:#f5f3ff}.customer-option-code{color:#8b5cf6;font-family:monospace;font-size:10px;font-weight:700}.customer-option-name{color:var(--gray-800);font-weight:600}.customer-option-sub{color:var(--gray-400);font-size:11px}.jo-total-row{background:var(--gray-50);border-radius:8px;justify-content:flex-end;align-items:center;gap:20px;margin-bottom:16px;padding:12px 10px;display:flex}.jo-total-label{color:var(--gray-700);font-size:13px;font-weight:700}.jo-total-value{color:#7c3aed;font-size:18px;font-weight:800}.hr-page{max-width:1100px}.employee-card{border:1px solid var(--border);background:#fff;border-radius:12px;transition:box-shadow .15s;overflow:hidden}.employee-card:hover{box-shadow:0 4px 16px #00000014}.employee-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.emp-card-head{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px 18px 12px;display:flex}.emp-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:700;display:flex}.emp-name{color:var(--gray-900);font-size:14px;font-weight:700}.emp-role{color:var(--gray-500);margin-top:2px;font-size:11.5px}.emp-body{padding:12px 18px 14px}.emp-field{justify-content:space-between;padding:5px 0;font-size:12px;display:flex}.emp-field-label{color:var(--gray-400);font-weight:600}.emp-field-value{color:var(--gray-700);font-weight:600}.emp-complete-bar{background:var(--gray-100);border-radius:9999px;height:4px;margin:10px 18px 14px;overflow:hidden}.emp-complete-fill{border-radius:9999px;height:100%;transition:width .5s}.emp-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.emp-incomplete-tag{color:#f59e0b;background:#fefce8;border-radius:9999px;padding:2px 8px;font-size:11px;font-weight:600}.emp-complete-tag{color:#16a34a;background:#f0fdf4;border-radius:9999px;padding:2px 8px;font-size:11px;font-weight:600}.emp-tabs{border-bottom:1px solid var(--border);gap:2px;margin-bottom:0;padding:0 18px;display:flex}.emp-tab{color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-size:12.5px;font-weight:600;transition:color .12s,border-color .12s}.emp-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.emp-tab-panel{padding:18px}.emp-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin:0 0 10px;padding:0;font-size:11px;font-weight:700}.payslip-period{color:var(--gray-500);margin-bottom:16px;font-size:12px}.payslip-breakdown{grid-template-columns:1fr 1fr;gap:0 24px;display:grid}.payslip-section-head{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);border-bottom:1px solid var(--border);margin-bottom:4px;padding:8px 0 4px;font-size:11px;font-weight:700}.payslip-line{color:var(--gray-700);border-bottom:1px solid var(--border);justify-content:space-between;padding:5px 0;font-size:12.5px;display:flex}.payslip-line:last-child{border-bottom:none}.payslip-line .fw{font-weight:700}.payslip-total{color:var(--gray-900);border-top:2px solid var(--border);justify-content:space-between;margin-top:8px;padding:10px 0 0;font-size:14px;font-weight:700;display:flex}.payslip-net{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;justify-content:space-between;align-items:center;margin-top:14px;padding:12px 16px;display:flex}.payslip-net-label{color:#166534;font-size:13px;font-weight:700}.payslip-net-amount{color:#166534;font-size:20px;font-weight:800}.policy-list{flex-direction:column;gap:8px;display:flex}.policy-item{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;align-items:center;gap:12px;padding:14px 18px;transition:background .12s,box-shadow .12s;display:flex}.policy-item:hover{background:#f8fafc;box-shadow:0 2px 8px #0000000f}.policy-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.policy-meta{flex:1;min-width:0}.policy-title{color:var(--gray-900);font-size:13.5px;font-weight:700}.policy-desc{color:var(--gray-500);margin-top:2px;font-size:12px}.policy-tag{background:var(--gray-100);color:var(--gray-500);border-radius:9999px;flex-shrink:0;padding:2px 8px;font-size:10.5px;font-weight:600}.policy-tag.required{color:#dc2626;background:#fef2f2}.policy-reader{max-height:70vh;line-height:1.75;overflow-y:auto}.policy-reader h3{color:var(--gray-900);margin:20px 0 6px;font-size:14px;font-weight:700}.policy-reader h3:first-child{margin-top:0}.policy-reader p{color:var(--gray-700);margin:0 0 10px;font-size:13px}.policy-reader ul{color:var(--gray-700);margin:0 0 10px;padding-left:20px;font-size:13px}.policy-reader li{margin-bottom:4px}.policy-editor-toolbar{border-bottom:1px solid var(--border);background:var(--gray-50);flex-wrap:wrap;align-items:center;gap:2px;padding:6px 14px;display:flex}.policy-toolbar-btn{cursor:pointer;width:28px;height:28px;color:var(--gray-600);background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;font-size:14px;transition:background .1s,color .1s;display:flex}.policy-toolbar-btn:hover{background:var(--gray-200);color:var(--gray-900)}.policy-toolbar-sep{background:var(--border);width:1px;height:18px;margin:0 4px}.policy-search{border:1px solid var(--border);background:var(--gray-50);border-radius:8px;align-items:center;gap:8px;margin-bottom:14px;padding:8px 14px;display:flex}.policy-search input{color:var(--gray-800);background:0 0;border:none;outline:none;flex:1;font-size:13px}.pr-section{margin-bottom:28px}.pr-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin:0 0 14px;font-size:11px;font-weight:700}.pr-stats-row{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:24px;display:grid}.pr-stat-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:4px;padding:16px 18px;display:flex}.pr-stat-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.pr-stat-value{color:var(--gray-900);font-size:20px;font-weight:800}.pr-stat-sub{color:var(--gray-400);font-size:11px}.pr-period-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.pr-period-pill{border:1.5px solid var(--border);color:var(--gray-600);cursor:pointer;white-space:nowrap;background:#fff;border-radius:20px;padding:8px 16px;font-size:12.5px;font-weight:700;transition:all .12s}.pr-period-pill:hover{color:#0ea5e9;border-color:#38bdf8}.pr-period-pill.active{color:#0369a1;background:#f0f9ff;border-color:#0ea5e9}.pr-table{border-collapse:collapse;width:100%;font-size:13px}.pr-table th{background:var(--gray-50);text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:9px 12px;font-size:10.5px;font-weight:700}.pr-table th.num{text-align:right}.pr-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:9px 12px}.pr-table td.num{text-align:right;font-variant-numeric:tabular-nums}.pr-table tbody tr:hover{background:var(--gray-50)}.pr-table tfoot td{background:var(--gray-50);border-top:2px solid var(--border);font-size:13px;font-weight:800}.pr-table tfoot td.num{color:#0369a1}.att-present{background:#f0fdf4}.att-late{background:#fffbeb}.att-absent{background:#fef2f2}.att-holiday{background:#f0f9ff}.att-badge-present{color:#16a34a;background:#dcfce7;border-radius:20px;padding:2px 8px;font-size:10.5px;font-weight:700;display:inline-block}.att-badge-late{color:#b45309;background:#fef3c7;border-radius:20px;padding:2px 8px;font-size:10.5px;font-weight:700;display:inline-block}.att-badge-absent{color:#dc2626;background:#fee2e2;border-radius:20px;padding:2px 8px;font-size:10.5px;font-weight:700;display:inline-block}.att-badge-holiday{color:#0369a1;background:#e0f2fe;border-radius:20px;padding:2px 8px;font-size:10.5px;font-weight:700;display:inline-block}.payslip-wrap{border:1px solid var(--border);background:#fff;border-radius:14px;max-width:680px;padding:28px 32px;font-size:13px}.payslip-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.payslip-company{color:#0369a1;font-size:18px;font-weight:800}.payslip-sub{color:var(--gray-400);margin-top:2px;font-size:11px}.payslip-grid{grid-template-columns:1fr 1fr;gap:8px 24px;margin-bottom:20px;display:grid}.payslip-row{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.payslip-row.total-row{border-bottom:2px solid var(--border);margin-top:4px;padding:10px 0;font-size:15px;font-weight:800}.payslip-row.net-row{color:#0369a1;border-bottom:none;padding:12px 0;font-size:17px;font-weight:800}.payslip-label{color:var(--gray-600)}.payslip-amount{font-variant-numeric:tabular-nums;font-weight:600}.payslip-deduction{color:#dc2626}.payslip-divider{border:none;border-top:1px solid var(--border);margin:12px 0}.ps-tab-bar{border-bottom:2px solid var(--border);gap:4px;margin-bottom:24px;display:flex;overflow-x:auto}.ps-tab{color:var(--gray-400);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 18px 10px;font-size:13px;font-weight:700;transition:color .12s,border-color .12s}.ps-tab:hover{color:#0ea5e9}.ps-tab.active{color:#0369a1;border-bottom-color:#0ea5e9}.ps-table{border-collapse:collapse;width:100%;font-size:12.5px}.ps-table th{background:var(--gray-50);text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);padding:8px 12px;font-size:10.5px;font-weight:700}.ps-table td{border-bottom:1px solid var(--border);padding:6px 12px}.ps-table input{border:1px solid var(--border);box-sizing:border-box;background:#fff;border-radius:6px;width:100%;padding:5px 8px;font-size:12.5px}.ps-table input:focus{border-color:#38bdf8;outline:none}.cp-steps{border-bottom:2px solid var(--border);gap:0;margin-bottom:28px;display:flex;overflow-x:auto}.cp-step{color:var(--gray-400);white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-2px;margin-right:32px;padding:0 0 12px;font-size:12.5px;font-weight:700}.cp-step.active{color:#0369a1;border-bottom-color:#0ea5e9}.cp-step.done{color:#0ea5e9}.cp-step-num{background:var(--gray-200);width:20px;height:20px;color:var(--gray-500);border-radius:50%;justify-content:center;align-items:center;margin-right:6px;font-size:11px;display:inline-flex}.cp-step.active .cp-step-num,.cp-step.done .cp-step-num{color:#fff;background:#0ea5e9}.att-filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.att-filter-bar select,.att-filter-bar input[type=month]{border:1.5px solid var(--border);color:var(--gray-800);background:#fff;border-radius:8px;padding:8px 12px;font-size:13px}.rpt-subnav{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.rpt-subnav-btn{border:1.5px solid var(--border);color:var(--gray-500);cursor:pointer;background:#fff;border-radius:20px;padding:7px 16px;font-size:12.5px;font-weight:700;transition:all .12s}.rpt-subnav-btn:hover{color:#0ea5e9;border-color:#38bdf8}.rpt-subnav-btn.active{color:#0369a1;background:#f0f9ff;border-color:#0ea5e9}@media print{.no-print{display:none!important}.payslip-wrap{border:none;padding:0}}.cp-total-bar{background:#f0f9ff;border-radius:12px;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;padding:16px 20px;display:grid}.cp-total-item{flex-direction:column;gap:3px;display:flex}.cp-total-label{text-transform:uppercase;letter-spacing:.06em;color:#0369a1;font-size:10.5px;font-weight:700}.cp-total-value{color:var(--gray-900);font-size:16px;font-weight:800}.getsolar-embed{width:100%;height:100%;min-height:calc(100vh - var(--topbar-height));position:relative}.getsolar-frame{width:100%;height:calc(100vh - var(--topbar-height));border:none;display:block}.getsolar-loading{color:#64748b;z-index:1;background:#f8fafc;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex;position:absolute;inset:0}.getsolar-spinner{border:3px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.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)}.getsolar-shell{padding-top:var(--topbar-height);flex-direction:column;flex:1;display:flex}.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}:root{--jgp-purple:#8b5cf6;--jgp-purple-dark:#7c3aed;--jgp-purple-light:#ede9fe}.jgp-layout{background:#f8f7ff;min-height:100vh;font-family:Inter,system-ui,sans-serif}.jgp-header{z-index:100;background:#fff;border-bottom:1px solid #e8e2ff;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.jgp-logo{color:inherit;align-items:center;gap:10px;text-decoration:none;display:flex}.jgp-logo-mark{background:var(--jgp-purple);border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.jgp-logo-text{color:#1a1523;font-size:15px;font-weight:800}.jgp-logo-sub{color:var(--gray-400,#9ca3af);font-size:10px;font-weight:500}.jgp-header-nav{align-items:center;gap:4px;display:flex}.jgp-nav-link{color:var(--gray-600,#4b5563);border-radius:7px;padding:6px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:background .12s,color .12s}.jgp-nav-link:hover,.jgp-nav-link.active{background:var(--jgp-purple-light);color:var(--jgp-purple-dark)}.jgp-main{max-width:900px;margin:0 auto;padding:32px 24px}.jgp-main-wide{max-width:1100px;margin:0 auto;padding:32px 24px}.jgp-card{background:#fff;border:1px solid #ede9fe;border-radius:16px;margin-bottom:20px;padding:28px;box-shadow:0 1px 4px #0000000f}.jgp-card-sm{max-width:440px;margin-left:auto;margin-right:auto}.jgp-welcome{justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:24px;display:flex}.jgp-welcome-inner{text-align:center;width:100%;max-width:540px}.jgp-welcome-logo{background:var(--jgp-purple);border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;display:flex}.jgp-welcome-title{color:#1a1523;margin-bottom:8px;font-size:28px;font-weight:900}.jgp-welcome-sub{color:var(--gray-500,#6b7280);margin-bottom:36px;font-size:15px;line-height:1.5}.jgp-choice-row{justify-content:center;gap:16px;display:flex}.jgp-choice-card{cursor:pointer;max-width:220px;color:inherit;background:#fff;border:2px solid #ede9fe;border-radius:14px;flex:1;padding:24px 18px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .12s;display:block}.jgp-choice-card:hover{border-color:var(--jgp-purple);transform:translateY(-2px);box-shadow:0 0 0 4px #8b5cf61a}.jgp-choice-icon{margin-bottom:10px;font-size:32px}.jgp-choice-label{color:#1a1523;margin-bottom:4px;font-size:15px;font-weight:800}.jgp-choice-desc{color:var(--gray-400,#9ca3af);font-size:12px;line-height:1.5}.jgp-auth-page{justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:24px;display:flex}.jgp-auth-box{background:#fff;border:1px solid #ede9fe;border-radius:16px;width:100%;max-width:420px;padding:32px;box-shadow:0 2px 16px #8b5cf614}.jgp-auth-title{color:#1a1523;margin-bottom:6px;font-size:22px;font-weight:900}.jgp-auth-sub{color:var(--gray-400,#9ca3af);margin-bottom:24px;font-size:13px}.jgp-form-group{margin-bottom:16px}.jgp-label{color:var(--gray-600,#4b5563);margin-bottom:5px;font-size:12px;font-weight:700;display:block}.jgp-input{box-sizing:border-box;color:#1a1523;background:#fff;border:1.5px solid #e2d9f3;border-radius:9px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .12s,box-shadow .12s}.jgp-input:focus{border-color:var(--jgp-purple);box-shadow:0 0 0 3px #8b5cf61f}.jgp-btn{cursor:pointer;border:none;border-radius:9px;width:100%;padding:11px;font-size:14px;font-weight:700;transition:background .12s,opacity .12s}.jgp-btn-primary{background:var(--jgp-purple);color:#fff}.jgp-btn-primary:hover:not(:disabled){background:var(--jgp-purple-dark)}.jgp-btn-secondary{background:var(--jgp-purple-light);color:var(--jgp-purple-dark)}.jgp-btn-secondary:hover:not(:disabled){background:#ddd6fe}.jgp-btn:disabled{opacity:.5;cursor:not-allowed}.jgp-divider{text-align:center;color:var(--gray-300,#d1d5db);margin:16px 0;font-size:12px;position:relative}.jgp-divider:before,.jgp-divider:after{content:"";background:#ede9fe;width:calc(50% - 18px);height:1px;position:absolute;top:50%}.jgp-divider:before{left:0}.jgp-divider:after{right:0}.jgp-link{color:var(--jgp-purple);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.jgp-link:hover{text-decoration:underline}.jgp-error{color:#dc2626;background:#fef2f2;border-radius:8px;margin-bottom:14px;padding:10px 14px;font-size:13px}.jgp-success{color:#16a34a;background:#f0fdf4;border-radius:8px;margin-bottom:14px;padding:10px 14px;font-size:13px}.jgp-otp-row{justify-content:center;gap:8px;margin:18px 0;display:flex}.jgp-otp-box{text-align:center;width:48px;height:56px;color:var(--jgp-purple-dark);border:2px solid #e2d9f3;border-radius:10px;outline:none;font-size:24px;font-weight:800}.jgp-otp-box:focus{border-color:var(--jgp-purple);box-shadow:0 0 0 3px #8b5cf61f}.jgp-stats-row{flex-wrap:wrap;gap:14px;margin-bottom:20px;display:flex}.jgp-stat-card{background:#fff;border:1px solid #ede9fe;border-radius:12px;flex:1;min-width:140px;padding:18px 20px;box-shadow:0 1px 3px #0000000d}.jgp-stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400,#9ca3af);margin-bottom:6px;font-size:11px;font-weight:700}.jgp-stat-value{color:#1a1523;font-size:28px;font-weight:900}.jgp-stat-sub{color:var(--gray-400,#9ca3af);margin-top:2px;font-size:12px}.jgp-order-list{flex-direction:column;gap:10px;display:flex}.jgp-order-row{cursor:pointer;color:inherit;background:#fff;border:1px solid #ede9fe;border-radius:12px;align-items:center;gap:14px;padding:14px 18px;text-decoration:none;transition:border-color .12s,box-shadow .12s;display:flex}.jgp-order-row:hover{border-color:var(--jgp-purple);box-shadow:0 0 0 3px #8b5cf614}.jgp-order-no{color:var(--jgp-purple-dark);min-width:90px;font-family:monospace;font-size:14px;font-weight:800}.jgp-order-info{flex:1}.jgp-order-types{color:#1a1523;font-size:13px;font-weight:600}.jgp-order-date{color:var(--gray-400,#9ca3af);margin-top:2px;font-size:12px}.jgp-order-total{color:#1a1523;text-align:right;min-width:100px;font-size:14px;font-weight:800}.jgp-badge{text-transform:capitalize;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-block}.jgp-badge-submitted{color:#3b82f6;background:#eff6ff}.jgp-badge-quoted{color:#a16207;background:#fef9c3}.jgp-badge-accepted{color:#7c3aed;background:#f5f3ff}.jgp-badge-paid{color:#0d9488;background:#f0fdf9}.jgp-badge-completed{color:#16a34a;background:#f0fdf4}.jgp-badge-cancelled{color:#dc2626;background:#fef2f2}.jgp-badge-draft{color:#6b7280;background:#f3f4f6}.jgp-accept-banner{border:2px solid var(--jgp-purple);background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:14px;align-items:center;gap:16px;margin-bottom:20px;padding:20px 24px;display:flex}.jgp-accept-text{flex:1}.jgp-accept-title{color:var(--jgp-purple-dark);margin-bottom:4px;font-size:16px;font-weight:800}.jgp-accept-sub{color:var(--gray-500,#6b7280);font-size:13px}.jgp-wt-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-bottom:16px;display:grid}.jgp-wt-chip{cursor:pointer;color:var(--gray-700,#374151);background:#fff;border:2px solid #ede9fe;border-radius:9px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:600;transition:all .12s;display:flex}.jgp-wt-chip:hover{background:#f5f3ff;border-color:#c4b5fd}.jgp-wt-chip.active{border-color:var(--jgp-purple);background:var(--jgp-purple-light);color:var(--jgp-purple-dark)}.jgp-wt-check{border:2px solid #d1d5db;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.jgp-wt-chip.active .jgp-wt-check{background:var(--jgp-purple);border-color:var(--jgp-purple)}.jgp-detail-table{border-collapse:collapse;width:100%;font-size:13px}.jgp-detail-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400,#9ca3af);text-align:left;background:#f5f3ff;border-bottom:1px solid #ede9fe;padding:9px 12px;font-size:11px;font-weight:700}.jgp-detail-table td{vertical-align:top;border-bottom:1px solid #f3f0ff;padding:10px 12px}.jgp-detail-table tr:last-child td{border-bottom:none}.jgp-detail-table .wt-col{color:var(--jgp-purple-dark);font-weight:700}.jgp-page-title{color:#1a1523;margin-bottom:4px;font-size:24px;font-weight:900}.jgp-page-sub{color:var(--gray-400,#9ca3af);margin-bottom:24px;font-size:14px}@media (width<=600px){.jgp-main{padding:20px 14px}.jgp-choice-row{flex-direction:column;align-items:center}.jgp-choice-card{max-width:100%}.jgp-stats-row{flex-direction:column}.jgp-auth-box{padding:22px 18px}}*,: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:0px;--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}
