:root{--primary:#2563eb;--primary-light:#3b82f6;--primary-dark:#1d4ed8;--primary-50:#eff6ff;--primary-100:#dbeafe;--success:#16a34a;--success-bg:#f0fdf4;--success-border:#bbf7d0;--warning:#d97706;--warning-bg:#fffbeb;--warning-border:#fde68a;--danger:#dc2626;--danger-bg:#fef2f2;--danger-border:#fecaca;--info:#0284c7;--info-bg:#f0f9ff;--info-border:#bae6fd;--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;--sidebar-width:220px;--topbar-height:56px;--sidebar-bg:#0f172a;--sidebar-text:#94a3b8;--sidebar-hover-bg:#ffffff12;--sidebar-active-bg:#2563eb33;--sidebar-active-text:#bfdbfe;--sidebar-border:#ffffff12;--content-bg:#f1f5f9;--card-bg:#fff;--border-color:#e2e8f0;--input-border:#cbd5e1;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--shadow-xs:0 1px 2px #0f172a0d;--shadow-sm:0 1px 3px #0f172a14,0 1px 2px #0f172a0a;--shadow:0 4px 6px #0f172a0f,0 2px 4px #0f172a0a;--shadow-md:0 10px 15px #0f172a14,0 4px 6px #0f172a0a;--shadow-lg:0 20px 25px #0f172a1f,0 8px 10px #0f172a0f;--radius-xs:3px;--radius-sm:5px;--radius:8px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition:150ms ease;--transition-md:220ms cubic-bezier(0.4,0,0.2,1);--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}body,html{font-size:14px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;background:var(--content-bg);color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-family:var(--font);line-height:1.6}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--gray-300);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--gray-400)}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a}h1,h2,h3,h4,h5,h6{color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-family:var(--font);font-weight:600;line-height:1.3}a{color:#2563eb;color:var(--primary);text-decoration:none;transition:color .15s ease;transition:color var(--transition)}a:hover{color:#1d4ed8;color:var(--primary-dark)}button{align-items:center;background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:5px;border-radius:var(--radius-sm);box-shadow:0 1px 2px #0f172a0d;box-shadow:var(--shadow-xs);color:#0f172a;color:var(--text-primary);cursor:pointer;display:inline-flex;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-family:var(--font);font-size:13px;font-weight:500;gap:5px;line-height:1.4;padding:6px 13px;transition:background .15s ease,box-shadow .15s ease,transform .15s ease,color .15s ease,border-color .15s ease;transition:background var(--transition),box-shadow var(--transition),transform var(--transition),color var(--transition),border-color var(--transition);-webkit-user-select:none;user-select:none;vertical-align:middle;white-space:nowrap}button:hover:not(:disabled){background:#f1f5f9;background:var(--gray-100);border-color:#cbd5e1;border-color:var(--gray-300);box-shadow:0 1px 3px #0f172a14,0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm)}button:active:not(:disabled){box-shadow:none;transform:translateY(1px)}button:disabled{cursor:not-allowed;opacity:.5}button:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary);outline-offset:2px}input[type=date],input[type=email],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],select,textarea{background:#fff;background:var(--card-bg);border:1px solid #cbd5e1;border:1px solid var(--input-border);border-radius:5px;border-radius:var(--radius-sm);color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-family:var(--font);font-size:13px;line-height:1.4;outline:none;padding:6px 10px;transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition),box-shadow var(--transition)}input:focus,select:focus,textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}input::placeholder,textarea::placeholder{color:#94a3b8;color:var(--text-muted)}label{color:#475569;color:var(--text-secondary);display:block;font-size:12px;font-weight:500;margin-bottom:4px}table{border-collapse:collapse;font-size:13px}th,thead tr{background:#f8fafc;background:var(--gray-50)}th{border-bottom:1.5px solid #e2e8f0;border-bottom:1.5px solid var(--border-color);color:#475569;color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase;white-space:nowrap}td,th{padding:8px 12px}td{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#0f172a;color:var(--text-primary);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover>td:not([style*=background]){background:#eff6ff;background:var(--primary-50)}.app-shell{overflow:hidden;width:100vw}.app-shell,.sidebar{display:flex;height:100vh}.sidebar{background:#0f172a;background:var(--sidebar-bg);flex-direction:column;flex-shrink:0;min-width:220px;min-width:var(--sidebar-width);overflow-x:hidden;overflow-y:auto;width:220px;width:var(--sidebar-width)}.sidebar-logo{border-bottom:1px solid #ffffff12;border-bottom:1px solid var(--sidebar-border);gap:10px;padding:15px 14px}.sidebar-logo,.sidebar-logo-icon{align-items:center;display:flex;flex-shrink:0}.sidebar-logo-icon{background:#fff;border-radius:5px;border-radius:var(--radius-sm);height:34px;justify-content:center;overflow:hidden;padding:2px;width:34px}.sidebar-logo-text{color:#fff;font-size:15px;font-weight:700;letter-spacing:-.02em;line-height:1.1}.sidebar-logo-sub{color:#64748b;color:var(--gray-500);font-size:10px;line-height:1;margin-top:2px}.sidebar-section{flex:1 1;padding:12px 0 8px}.sidebar-section-label{color:#475569;color:var(--gray-600);font-size:9px;font-weight:700;letter-spacing:.1em;padding:0 14px 6px;text-transform:uppercase}.sidebar-nav-item{align-items:center!important;background:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;color:#94a3b8!important;color:var(--sidebar-text)!important;cursor:pointer;display:flex!important;font-size:13px!important;font-weight:400!important;gap:10px!important;letter-spacing:0;line-height:1.3!important;padding:9px 14px!important;text-align:left!important;white-space:nowrap;width:100%!important}.sidebar-nav-item:hover:not(:disabled){background:#ffffff12!important;background:var(--sidebar-hover-bg)!important;box-shadow:none!important;color:#e2e8f0!important;transform:none!important}.sidebar-nav-item.active{background:#2563eb33!important;background:var(--sidebar-active-bg)!important;border-left:2px solid #3b82f6!important;border-left:2px solid var(--primary-light)!important;color:#bfdbfe!important;color:var(--sidebar-active-text)!important;font-weight:500!important;padding-left:12px!important}.sidebar-nav-item.active:hover:not(:disabled){background:#2563eb47!important;box-shadow:none!important}.sidebar-footer{border-top:1px solid #ffffff12;border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:10px 12px 14px}.sidebar-user{gap:9px;padding:6px 4px 10px}.sidebar-avatar,.sidebar-user{align-items:center;display:flex}.sidebar-avatar{background:#1d4ed8;background:var(--primary-dark);border:1.5px solid #ffffff1f;border-radius:9999px;border-radius:var(--radius-full);color:#fff;flex-shrink:0;font-size:11px;font-weight:700;height:30px;justify-content:center;width:30px}.sidebar-user-name{color:#e2e8f0;font-size:12px;font-weight:500;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#64748b;color:var(--gray-500);font-size:10px;line-height:1;margin-top:1px;text-transform:capitalize}.btn-logout{background:#0000!important;border:1px solid #ffffff12!important;border:1px solid var(--sidebar-border)!important;border-radius:5px!important;border-radius:var(--radius-sm)!important;box-shadow:none!important;color:#64748b!important;color:var(--gray-500)!important;font-size:12px!important;justify-content:center!important;padding:6px 12px!important;transition:background .15s ease,color .15s ease,border-color .15s ease!important;transition:background var(--transition),color var(--transition),border-color var(--transition)!important;width:100%!important}.btn-logout:hover:not(:disabled){background:#fef2f2!important;background:var(--danger-bg)!important;border-color:#fecaca!important;border-color:var(--danger-border)!important;box-shadow:none!important;color:#dc2626!important;color:var(--danger)!important;transform:none!important}.sidebar--collapsed{min-width:56px;width:56px}.sidebar,.sidebar--collapsed{transition:width .22s cubic-bezier(.4,0,.2,1);transition:width var(--transition-md)}.sidebar--collapsed .sidebar-logo{justify-content:center;padding:15px 11px}.sidebar--collapsed .sidebar-nav-item--icon-only{justify-content:center!important;padding:9px 0!important}.sidebar--collapsed .sidebar-nav-item--icon-only.active{border-left:2px solid #3b82f6!important;border-left:2px solid var(--primary-light)!important;padding-left:0!important}.sidebar--collapsed .sidebar-footer{padding:10px 8px 14px}.sidebar--collapsed .sidebar-user{justify-content:center;padding:6px 0 10px}.sidebar--collapsed .btn-logout{padding:6px 0!important}.app-main{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.app-topbar{align-items:center;background:#fff;background:var(--card-bg);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);box-shadow:0 1px 2px #0f172a0d;box-shadow:var(--shadow-xs);display:flex;flex-shrink:0;gap:12px;height:56px;height:var(--topbar-height);min-height:56px;min-height:var(--topbar-height);padding:0 20px;z-index:30}.topbar-title{color:#0f172a;color:var(--text-primary);flex:1 1;font-size:14px;font-weight:600;letter-spacing:-.01em}.app-content{background:#f1f5f9;background:var(--content-bg);flex:1 1;overflow-x:hidden;overflow-y:auto}.login-page{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b 45%,#1e3a5f);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-page:before{background:radial-gradient(circle,#2563eb24 0,#0000 65%);height:700px;right:-150px;top:-200px;width:700px}.login-page:after,.login-page:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.login-page:after{background:radial-gradient(circle,#2563eb1a 0,#0000 65%);bottom:-150px;height:500px;left:-80px;width:500px}.login-card{animation:loginFadeIn .35s ease;background:#fffffffa;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 20px 25px #0f172a1f,0 8px 10px #0f172a0f,0 0 0 1px #ffffff0d;box-shadow:var(--shadow-lg),0 0 0 1px #ffffff0d;max-width:390px;padding:38px 36px;position:relative;width:100%;z-index:1}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-header{gap:14px;margin-bottom:28px}.login-header,.login-logo-icon{align-items:center;display:flex}.login-logo-icon{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);flex-shrink:0;height:46px;justify-content:center;overflow:hidden;padding:3px;width:46px}.login-logo-name{color:#0f172a;color:var(--text-primary);font-size:1.2rem;font-weight:700;letter-spacing:-.02em;line-height:1.1}.login-logo-org{color:#94a3b8;color:var(--text-muted);font-size:11px;font-weight:400;margin-top:3px}.login-heading{color:#0f172a;color:var(--text-primary);font-size:1.05rem;font-weight:600;margin-bottom:4px}.login-subheading{color:#94a3b8;color:var(--text-muted);font-size:13px;font-weight:400;margin-bottom:22px}.login-form-group{margin-bottom:14px}.login-form-group label{color:#475569;color:var(--text-secondary);font-size:12px;font-weight:500;margin-bottom:6px}.login-form-group input{border:1.5px solid #e2e8f0;border:1.5px solid var(--border-color);border-radius:5px;border-radius:var(--radius-sm);font-size:14px;padding:10px 12px;transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.login-form-group input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.login-error{background:#fef2f2;background:var(--danger-bg);border:1px solid #fecaca;border:1px solid var(--danger-border);border-radius:5px;border-radius:var(--radius-sm);color:#dc2626;color:var(--danger);font-size:12px;line-height:1.5;margin-bottom:12px;padding:8px 12px}.login-btn{border-radius:5px!important;border-radius:var(--radius-sm)!important;box-shadow:0 2px 8px #2563eb33!important;font-size:14px!important;font-weight:600!important;justify-content:center!important;letter-spacing:.01em;margin-top:6px;padding:11px!important;width:100%!important}.login-btn:hover:not(:disabled){background:#1d4ed8!important;background:var(--primary-dark)!important;box-shadow:0 4px 14px #2563eb59!important;transform:translateY(-1px)!important}.login-btn:active:not(:disabled){transform:translateY(0)!important}.home-welcome{padding:22px}.home-welcome-banner{background:linear-gradient(115deg,#1e3a5f,#1d4ed8 55%,#2563eb);border-radius:10px;border-radius:var(--radius-md);box-shadow:0 10px 15px #0f172a14,0 4px 6px #0f172a0a;box-shadow:var(--shadow-md);color:#fff;margin-bottom:22px;overflow:hidden;padding:22px 24px;position:relative}.home-welcome-title{color:#fff;font-size:1.15rem;font-weight:700;line-height:1.2;margin-bottom:4px}.home-welcome-sub{color:#ffffffa6;font-size:13px;font-weight:400}.home-section-title{color:#94a3b8;color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.08em;margin-bottom:12px;text-transform:uppercase}.home-modules-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}.home-module-card{align-items:flex-start!important;background:#fff;background:var(--card-bg);background-color:#fff!important;background-color:var(--card-bg)!important;border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);box-shadow:0 1px 2px #0f172a0d;box-shadow:var(--shadow-xs);color:#0f172a!important;color:var(--text-primary)!important;cursor:pointer;display:flex!important;flex-direction:column!important;gap:10px;outline:none;padding:18px 15px;text-align:left;transition:border-color .22s cubic-bezier(.4,0,.2,1),box-shadow .22s cubic-bezier(.4,0,.2,1),transform .22s cubic-bezier(.4,0,.2,1);transition:border-color var(--transition-md),box-shadow var(--transition-md),transform var(--transition-md);width:100%!important}.home-module-card:hover:not(:disabled){background:#fff!important;background:var(--card-bg)!important;border-color:#3b82f6!important;border-color:var(--primary-light)!important;box-shadow:0 4px 6px #0f172a0f,0 2px 4px #0f172a0a!important;box-shadow:var(--shadow)!important;transform:translateY(-2px)!important}.home-module-icon{align-items:center;background:#eff6ff;background:var(--primary-50);border-radius:5px;border-radius:var(--radius-sm);display:flex;flex-shrink:0;font-size:20px;height:42px;justify-content:center;width:42px}.home-module-name{color:#0f172a;color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.2}.home-module-desc{color:#94a3b8;color:var(--text-muted);font-size:11px;font-weight:400;line-height:1.4;margin-top:2px}.erp-card{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #0f172a14,0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm)}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.02em;line-height:1.6;padding:2px 9px;white-space:nowrap}.badge-success{background:#f0fdf4;background:var(--success-bg);border:1px solid #bbf7d0;border:1px solid var(--success-border);color:#16a34a;color:var(--success)}.badge-warning{background:#fffbeb;background:var(--warning-bg);border:1px solid #fde68a;border:1px solid var(--warning-border);color:#d97706;color:var(--warning)}.badge-danger{background:#fef2f2;background:var(--danger-bg);border:1px solid #fecaca;border:1px solid var(--danger-border);color:#dc2626;color:var(--danger)}.badge-info{background:#f0f9ff;background:var(--info-bg);border:1px solid #bae6fd;border:1px solid var(--info-border);color:#0284c7;color:var(--info)}.badge-neutral{background:#f1f5f9;background:var(--gray-100);border:1px solid #e2e8f0;border:1px solid var(--gray-200);color:#475569;color:var(--gray-600)}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.login-tabs{background:#f1f5f9;background:var(--gray-100,#f3f4f6);border-radius:5px;border-radius:var(--radius-sm);display:flex;gap:4px;margin-bottom:20px;padding:3px}.login-tab{background:#0000;border:none;border-radius:3px;border-radius:calc(var(--radius-sm) - 2px);color:#475569;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:13px;font-weight:500;padding:7px 10px;transition:background .15s ease,color .15s ease;transition:background var(--transition),color var(--transition)}.login-tab.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#2563eb;color:var(--primary);font-weight:600}.face-scan-wrap{align-items:center;display:flex;flex-direction:column;gap:10px;width:100%}.face-video{aspect-ratio:4/3;background:#0f172a;border-radius:8px;border-radius:var(--radius);display:none;max-width:320px;object-fit:cover;width:100%}.face-video.active{display:block}.face-open-btn{background:#eff6ff;background:var(--primary-50,#2563eb14);border:1.5px dashed #3b82f6;border:1.5px dashed var(--primary-light,#93c5fd);border-radius:5px;border-radius:var(--radius-sm);color:#2563eb;color:var(--primary);cursor:pointer;font-size:14px;font-weight:600;margin-top:4px;padding:11px;transition:background .15s ease,border-color .15s ease;transition:background var(--transition),border-color var(--transition);width:100%}.face-open-btn:hover{background:#dbeafe;background:var(--primary-100,#2563eb24);border-color:#2563eb;border-color:var(--primary)}.face-controls{display:flex;flex-direction:column;gap:8px;max-width:320px;width:100%}.face-capture-btn{margin-top:0!important}.face-cancel-btn{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:5px;border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;padding:8px;transition:background .15s ease;transition:background var(--transition);width:100%}.face-cancel-btn:hover,.login-org-badge{background:#f1f5f9;background:var(--gray-100,#f3f4f6)}.login-org-badge{align-items:center;border-radius:5px;border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary);display:flex;font-size:12px;gap:8px;margin-bottom:14px;padding:8px 12px}.login-org-icon{flex-shrink:0;font-size:16px}.face-login-wrap{align-items:center;display:flex;flex-direction:column;gap:10px}.face-login-status{color:#94a3b8;color:var(--text-muted);font-size:13px;padding:16px 0;text-align:center}.face-scan-status-row{align-items:center;display:flex;gap:8px;padding:6px 0}.face-scan-status-text{color:#475569;color:var(--text-secondary);font-size:13px}.face-scan-pulse{animation:facePulse 1.2s ease-in-out infinite;background:#2563eb;background:var(--primary);border-radius:50%;flex-shrink:0;height:8px;width:8px}@keyframes facePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.modal-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.face-enroll-modal{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 20px 25px #0f172a1f,0 8px 10px #0f172a0f;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:14px;max-width:380px;padding:28px 28px 24px;width:100%}.face-enroll-header{align-items:center;display:flex;justify-content:space-between}.face-enroll-header h3{color:#0f172a;color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.face-enroll-close{align-items:center;background:#f1f5f9;background:var(--gray-100,#f3f4f6);border:none;border-radius:5px;border-radius:var(--radius-sm);cursor:pointer;display:flex;height:28px;justify-content:center;width:28px}.face-enroll-close,.face-enroll-hint{color:#475569;color:var(--text-secondary);font-size:13px}.face-enroll-hint{line-height:1.5;margin:0}.face-enroll-actions{display:flex;flex-direction:column;gap:8px}.face-enroll-actions .login-btn{margin-top:0}.face-enroll-success{color:#16a34a;color:var(--success,#16a34a);font-size:14px;font-weight:600;margin:0;padding:8px 0;text-align:center}.face-enroll-error{background:#fef2f2;background:var(--danger-bg);border:1px solid #fecaca;border:1px solid var(--danger-border);border-radius:5px;border-radius:var(--radius-sm);color:#dc2626;color:var(--danger);font-size:12px;margin:0;padding:8px 12px}.app-content>*{animation:pageFadeIn .18s ease}.perm-modal-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.perm-modal{background:#fff;background:var(--surface,#fff);border-radius:8px;border-radius:var(--radius,10px);box-shadow:0 8px 40px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:520px;overflow:hidden;width:100%}.perm-modal-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 20px 14px}.perm-modal-title{color:#0f172a;color:var(--text-primary,#111827);font-size:16px;font-weight:700}.perm-modal-subtitle{align-items:center;color:#475569;color:var(--text-secondary,#6b7280);display:flex;font-size:13px;gap:8px;margin-top:2px}.perm-modal-role{background:#eff6ff;background:var(--primary-bg,#eff6ff);border-radius:20px;color:#2563eb;color:var(--primary,#2563eb);font-size:11px;font-weight:600;padding:1px 7px;text-transform:uppercase}.perm-modal-close{background:none;border:none;border-radius:4px;color:#475569;color:var(--text-secondary,#6b7280);cursor:pointer;font-size:18px;line-height:1;padding:2px 6px}.perm-modal-close:hover{background:#f3f4f6;background:var(--surface-alt,#f3f4f6)}.perm-modal-body{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:16px 20px}.perm-restrict-toggle{background:#f9fafb;background:var(--surface-alt,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:5px;border-radius:var(--radius-sm,6px);padding:10px 14px}.perm-toggle-label{align-items:center;color:#0f172a;color:var(--text-primary,#111827);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px}.perm-toggle-label input[type=checkbox]{accent-color:#2563eb;accent-color:var(--primary,#2563eb);cursor:pointer;height:16px;width:16px}.perm-bulk-btns{display:flex;gap:8px}.perm-bulk-btn{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:5px;border-radius:var(--radius-sm,6px);color:#0f172a;color:var(--text-primary,#374151);cursor:pointer;font-size:12px;font-weight:500;padding:4px 12px}.perm-bulk-btn:hover{background:#f3f4f6;background:var(--surface-alt,#f3f4f6)}.perm-bulk-btn-clear{border-color:#fecaca;border-color:var(--danger-border,#fecaca);color:#dc2626;color:var(--danger,#dc2626)}.perm-bulk-btn-clear:hover{background:#fef2f2;background:var(--danger-bg,#fef2f2)}.perm-tree{display:flex;flex-direction:column;gap:6px}.perm-group{border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:5px;border-radius:var(--radius-sm,6px);overflow:hidden}.perm-group-header{align-items:center;background:#f9fafb;background:var(--surface-alt,#f9fafb);color:#0f172a;color:var(--text-primary,#111827);cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:10px;padding:9px 14px;transition:background .15s}.perm-group-header:hover{background:#f3f4f6;background:var(--surface-hover,#f3f4f6)}.perm-group-header.perm-on{background:#eff6ff;background:var(--primary-bg,#eff6ff)}.perm-group-header input[type=checkbox]{accent-color:#2563eb;accent-color:var(--primary,#2563eb);cursor:pointer;flex-shrink:0;height:15px;width:15px}.perm-group-label{flex:1 1}.perm-children{border-top:1px solid #e5e7eb;border-top:1px solid var(--border,#e5e7eb);display:flex;flex-direction:column}.perm-row{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);color:#475569;color:var(--text-secondary,#4b5563);cursor:pointer;display:flex;font-size:13px;gap:10px;padding:7px 14px 7px 30px;transition:background .12s}.perm-row:last-child{border-bottom:none}.perm-row:hover{background:#f9fafb;background:var(--surface-alt,#f9fafb)}.perm-row.perm-on{background:#f0f7ff;color:#0f172a;color:var(--text-primary,#111827)}.perm-row input[type=checkbox]{accent-color:#2563eb;accent-color:var(--primary,#2563eb);cursor:pointer;flex-shrink:0;height:14px;width:14px}.perm-default-note{background:#f9fafb;background:var(--surface-alt,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:5px;border-radius:var(--radius-sm,6px);color:#475569;color:var(--text-secondary,#6b7280);font-size:13px;margin:0;padding:12px 14px}.perm-modal-footer{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border,#e5e7eb);display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:14px 20px}.perm-error{color:#dc2626;color:var(--danger,#dc2626);flex:1 1;font-size:12px}.perm-cancel-btn{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:5px;border-radius:var(--radius-sm,6px);color:#0f172a;color:var(--text-primary,#374151);cursor:pointer;font-size:13px;font-weight:500;padding:7px 18px}.perm-cancel-btn:hover{background:#f3f4f6;background:var(--surface-alt,#f3f4f6)}.perm-save-btn{background:#2563eb;background:var(--primary,#2563eb);border:none;border-radius:5px;border-radius:var(--radius-sm,6px);color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:7px 22px}.perm-save-btn:hover{background:#1d4ed8;background:var(--primary-dark,#1d4ed8)}.perm-save-btn:disabled{cursor:not-allowed;opacity:.6}.admin-tabs{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border,#e5e7eb);display:flex;gap:4px;margin-bottom:24px}.admin-tab{background:none;border:none;border-bottom:2px solid #0000;border-radius:5px 5px 0 0;border-radius:var(--radius-sm,6px) var(--radius-sm,6px) 0 0;color:#475569;color:var(--text-secondary,#6b7280);cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-2px;padding:9px 20px;transition:color .15s,background .15s}.admin-tab:hover{background:#f3f4f6;background:var(--surface-alt,#f3f4f6);color:#0f172a;color:var(--text-primary,#111827)}.admin-tab.active{background:none;border-bottom-color:#2563eb;border-bottom-color:var(--primary,#2563eb);color:#2563eb;color:var(--primary,#2563eb);font-weight:600}.tpl-section{display:flex;flex-direction:column;gap:20px}.tpl-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.tpl-title{color:#0f172a;color:var(--text-primary,#111827);font-size:16px;font-weight:700;margin:0 0 4px}.tpl-subtitle{color:#475569;color:var(--text-secondary,#6b7280);font-size:13px;margin:0}.tpl-empty{background:#f9fafb;background:var(--surface-alt,#f9fafb);border:1px dashed #d1d5db;border:1px dashed var(--border,#d1d5db);border-radius:8px;border-radius:var(--radius,10px);color:#475569;color:var(--text-secondary,#9ca3af);font-size:14px;padding:48px 24px;text-align:center}.tpl-list{display:flex;flex-direction:column;gap:10px}.tpl-card{align-items:center;background:#fff;background:var(--surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:8px;border-radius:var(--radius,10px);display:flex;gap:16px;justify-content:space-between;padding:14px 18px;transition:box-shadow .15s}.tpl-card:hover{box-shadow:0 2px 8px #00000012}.tpl-card-info{flex:1 1;min-width:0}.tpl-card-name{color:#0f172a;color:var(--text-primary,#111827);font-size:14px;font-weight:600}.tpl-card-desc{color:#475569;color:var(--text-secondary,#6b7280);font-size:12px;margin-top:2px}.tpl-card-count{background:#eff6ff;background:var(--primary-bg,#eff6ff);border-radius:20px;color:#2563eb;color:var(--primary,#2563eb);display:inline-block;font-size:11px;font-weight:500;margin-top:6px;padding:2px 8px}.tpl-card-actions{display:flex;flex-shrink:0;gap:8px}.tpl-form-card{background:#fff;background:var(--surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:8px;border-radius:var(--radius,10px);overflow:hidden}.tpl-form-header{align-items:center;background:#f9fafb;background:var(--surface-alt,#f9fafb);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);color:#0f172a;color:var(--text-primary,#111827);display:flex;font-size:14px;font-weight:600;justify-content:space-between;padding:14px 18px}.tpl-form-fields{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;padding:16px 18px 0}.tpl-field{display:flex;flex-direction:column;gap:5px}.tpl-label{color:#475569;color:var(--text-secondary,#6b7280);font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.tpl-input{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:5px;border-radius:var(--radius-sm,6px);color:#0f172a;color:var(--text-primary,#111827);font-size:13px;outline:none;padding:8px 10px;transition:border-color .15s}.tpl-input:focus{border-color:#2563eb;border-color:var(--primary,#2563eb)}.tpl-perm-section{padding:16px 18px 0}.tpl-perm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.tpl-form-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border,#e5e7eb);display:flex;gap:10px;justify-content:flex-end;margin-top:16px;padding:16px 18px}.perm-template-apply{align-items:center;background:#eff6ff;background:var(--primary-bg,#eff6ff);border:1px solid #bfdbfe;border-radius:5px;border-radius:var(--radius-sm,6px);display:flex;gap:10px;padding:10px 14px}.perm-template-label{color:#2563eb;color:var(--primary,#2563eb);font-size:12px;font-weight:600;white-space:nowrap}.perm-template-select{background:#fff;background:var(--surface,#fff);border:1px solid #bfdbfe;border-radius:5px;border-radius:var(--radius-sm,6px);color:#0f172a;color:var(--text-primary,#111827);cursor:pointer;flex:1 1;font-size:13px;outline:none;padding:5px 8px}.perm-template-select:focus{border-color:#2563eb;border-color:var(--primary,#2563eb)}.home-no-access{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:40vh;padding:48px 24px;text-align:center}.home-no-access-icon{font-size:56px;line-height:1;opacity:.4}.home-no-access-text{color:#0f172a;color:var(--text-primary,#111827);font-size:20px;font-weight:700}.home-no-access-sub{color:#475569;color:var(--text-secondary,#9ca3af);font-size:14px}.sidebar-group{display:flex;flex-direction:column}.sidebar-group-btn{width:100%!important}.sidebar-group-label{flex:1 1;text-align:left}.sidebar-arrow{color:#64748b;color:var(--gray-500,#9ca3af);display:inline-block;flex-shrink:0;font-size:15px;line-height:1;transform:rotate(0deg);transition:transform .2s ease}.sidebar-arrow.open{color:#cbd5e1;transform:rotate(90deg)}.sidebar-group-children{border-left:2px solid #ffffff1a;display:flex;flex-direction:column;gap:1px;margin:0 12px 2px 22px;padding:3px 10px 6px 14px}.sidebar-child-btn{align-items:center!important;background:#0000!important;border:none!important;border-radius:6px!important;box-shadow:none!important;color:#94a3b8!important;color:var(--gray-400,#9ca3af)!important;cursor:pointer!important;display:flex!important;font-size:12.5px!important;gap:8px!important;overflow:hidden;padding:6px 10px!important;text-align:left!important;text-overflow:ellipsis;transform:none!important;transition:background .12s,color .12s!important;white-space:nowrap;width:100%!important}.sidebar-child-btn:hover{background:#ffffff12!important;background:var(--sidebar-hover-bg,#ffffff12)!important;color:#e2e8f0!important}.sidebar-child-btn.active{background:#2563eb2e!important;color:#93c5fd!important;font-weight:500!important}.sidebar-child-dot{background:currentColor;border-radius:50%;flex-shrink:0;height:5px;opacity:.5;width:5px}.sidebar-child-btn.active .sidebar-child-dot{background:#60a5fa;opacity:1}