.up-cpn-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.up-cpn-stats-card{display:flex;align-items:center;gap:16px;padding:20px;border-radius:10px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;transition:transform .2s,box-shadow .2s}.up-cpn-stats-card.up-cpn-stats-clickable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.up-cpn-stats-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.up-cpn-stats-card.up-cpn-stats-clickable:active{transform:translateY(0);box-shadow:0 2px 6px #0000001a}.up-cpn-stats-icon{font-size:36px;line-height:1}.up-cpn-stats-content{flex:1}.up-cpn-stats-value{font-size:32px;font-weight:700;line-height:1.2;margin-bottom:4px;text-align:center}.up-cpn-stats-label{font-size:13px;opacity:.9;font-weight:500;text-align:center}.up-cpn-stats-total{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.up-cpn-stats-active{background:linear-gradient(135deg,#48bb78 0%,#38a169 100%)}.up-cpn-stats-inactive{background:linear-gradient(135deg,#f56565 0%,#c53030 100%)}.up-cpn-stats-internal{background:linear-gradient(135deg,#4299e1 0%,#3182ce 100%)}.up-cpn-stats-vendor{background:linear-gradient(135deg,#ed8936 0%,#dd6b20 100%)}.up-cpn-stats-locked{background:linear-gradient(135deg,#e53e3e 0%,#c53030 100%)}.up-cpn-stats-online{background:linear-gradient(135deg,#38b2ac 0%,#2c7a7b 100%)}@media (max-width: 1200px){.up-cpn-stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.up-cpn-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.up-cpn-stats-card{padding:12px 14px;gap:10px}.up-cpn-stats-icon{font-size:26px}.up-cpn-stats-value{font-size:22px}.up-cpn-stats-label{font-size:11px}}@media (max-width: 480px){.up-cpn-stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.up-cpn-stats-card{padding:10px 12px;gap:8px;border-radius:8px}.up-cpn-stats-icon{font-size:22px}.up-cpn-stats-value{font-size:20px}.up-cpn-stats-label{font-size:10px}}@media (max-width: 360px){.up-cpn-stats-grid{grid-template-columns:repeat(2,1fr);gap:5px}.up-cpn-stats-card{padding:8px 10px;gap:6px}.up-cpn-stats-icon,.up-cpn-stats-value{font-size:18px}}.up-cpn-action-dropdown{position:relative;display:inline-block}.up-cpn-action-btn{width:36px;height:36px;border:2px solid #e2e8f0;background:white;border-radius:8px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.up-cpn-action-btn:hover{border-color:#667eea;background:#f7faff;transform:scale(1.05)}.up-cpn-action-btn.active{border-color:#667eea;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 12px #667eea4d}.up-cpn-action-menu{position:absolute;top:calc(100% + 8px);left:0;background:white;border:2px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f;min-width:200px;z-index:1000;overflow:hidden;animation:up-cpn-action-fade-in .2s ease-out}@keyframes up-cpn-action-fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.up-cpn-action-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:white;border:none;cursor:pointer;transition:all .2s;text-align:left;font-size:14px;font-weight:500;color:#2d3748}.up-cpn-action-item:hover{background:#f7fafc}.up-cpn-action-icon{font-size:16px;flex-shrink:0}.up-cpn-action-label{flex:1}.up-cpn-action-view:hover{background:#e6f7ff;color:#06c}.up-cpn-action-edit:hover{background:#fff7e6;color:#d68910}.up-cpn-action-delete{color:#c53030}.up-cpn-action-delete:hover{background:#fff5f5;color:#c53030}.up-cpn-action-divider{height:1px;background:#e2e8f0;margin:4px 0}@media (max-width: 768px){.up-cpn-action-menu{right:auto;left:0}.up-cpn-action-btn{width:32px;height:32px;font-size:16px}}.up-cpn-table-wrapper{display:block;height:100%;overflow-y:auto;overflow-x:auto;border:1px solid #e2e8f0;border-radius:0;margin:0;background:white}.up-cpn-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.up-cpn-table-wrapper::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.up-cpn-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.up-cpn-table-wrapper::-webkit-scrollbar-thumb:hover{background:#a0aec0}.up-cpn-table{width:100%;border-collapse:collapse;font-size:14px}.up-cpn-table thead{background-color:#f7fafc;position:sticky;top:0;z-index:10;box-shadow:0 2px 4px #0000000d}.up-cpn-table thead:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,#667eea 0%,#764ba2 100%)}.up-cpn-table th{padding:14px;text-align:left;font-weight:600;color:#2d3748;text-transform:uppercase;font-size:13px;letter-spacing:.5px;white-space:nowrap;vertical-align:top}.up-cpn-table td{padding:10px;border-bottom:1px solid #e2e8f0;vertical-align:middle}.up-cpn-table tbody tr{transition:background-color .2s}.up-cpn-table tbody tr.up-cpn-table-row-clickable{cursor:pointer}.up-cpn-table tbody tr.up-cpn-table-row-clickable:hover{background-color:#edf2f7}.up-cpn-table tbody tr.up-cpn-table-row-selected{background-color:#e6fffa!important;border-left:4px solid #38b2ac}.up-cpn-table tbody tr.up-cpn-table-row-selected:hover{background-color:#b2f5ea!important}.up-cpn-table tbody tr.up-cpn-table-row-inactive{opacity:.6}.up-cpn-table tbody tr.up-cpn-table-row-locked{background-color:#fff5f5}.up-cpn-table-col-id{width:60px;color:#667eea;font-weight:600}.up-cpn-table-col-user{min-width:300px}.up-cpn-table-col-type,.up-cpn-table-col-code{width:150px}.up-cpn-table-col-org{min-width:280px}.up-cpn-table-col-sessions{width:140px}.up-cpn-table-col-actions{width:160px}.up-cpn-table-actions-wrapper{display:flex;align-items:center;gap:8px}.up-cpn-table-user-info{display:flex;align-items:center;gap:12px}.up-cpn-table-user-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#e2e8f0,#cbd5e0);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.up-cpn-table-user-details{flex:1;min-width:0}.up-cpn-table-user-name{font-size:15px;font-weight:600;color:#2d3748;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-cpn-table-user-meta{font-size:13px;color:#718096;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden}.up-cpn-table-user-meta .up-cpn-table-username{color:#667eea;font-weight:500;white-space:nowrap}.up-cpn-table-user-meta .up-cpn-table-separator{color:#cbd5e0}.up-cpn-table-user-meta .up-cpn-table-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0}.up-cpn-table-type-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500}.up-cpn-table-type-badge.up-cpn-table-type-internal{background-color:#ebf4ff;color:#2c5282}.up-cpn-table-type-badge.up-cpn-table-type-vendor{background-color:#fef5e7;color:#c05621}.up-cpn-table-code-info{display:flex;flex-direction:column;gap:4px}.up-cpn-table-code-value{font-size:13px;font-weight:600;color:#2d3748;white-space:nowrap}.up-cpn-table-code-name{font-size:12px;color:#718096;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-cpn-table-org-info{font-size:13px;color:#2d3748;line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-cpn-table-session-info{display:flex;flex-direction:column;gap:4px}.up-cpn-table-session-count{font-size:13px;color:#48bb78;font-weight:600;white-space:nowrap}.up-cpn-table-last-login{font-size:12px;color:#718096;white-space:nowrap}.up-cpn-table-status-badge{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600}.up-cpn-table-status-badge.up-cpn-table-status-locked{background-color:#fff5f5;color:#c53030;border:1px solid #fc8181}.up-cpn-table-toggle-switch{position:relative;display:inline-block;width:52px;height:28px}.up-cpn-table-toggle-switch input{opacity:0;width:0;height:0}.up-cpn-table-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e0;transition:.3s;border-radius:28px}.up-cpn-table-toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.up-cpn-table-toggle-switch input:checked+.up-cpn-table-toggle-slider{background-color:#48bb78}.up-cpn-table-toggle-switch input:checked+.up-cpn-table-toggle-slider:before{transform:translate(24px)}.up-cpn-table-toggle-switch input:disabled+.up-cpn-table-toggle-slider{opacity:.5;cursor:not-allowed}.up-cpn-table-action-buttons{display:flex;gap:8px}.up-cpn-table-action-btn{padding:8px 12px;border:1px solid #e2e8f0;background:white;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s}.up-cpn-table-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.up-cpn-table-action-btn.up-cpn-table-btn-view:hover{border-color:#4299e1;background-color:#ebf8ff}.up-cpn-table-action-btn.up-cpn-table-btn-edit:hover{border-color:#ed8936;background-color:#fffaf0}.up-cpn-table-action-btn.up-cpn-table-btn-delete:hover{border-color:#f56565;background-color:#fff5f5}.up-cpn-table-text-muted{color:#a0aec0;font-style:italic;white-space:nowrap}@media (max-width: 1200px){.up-cpn-table{font-size:13px}.up-cpn-table th,.up-cpn-table td{padding:12px}.up-cpn-table-user-icon{width:40px;height:40px;font-size:20px}}.up-cpn-table-card-list{display:none}@media (max-width: 768px){.up-cpn-table-wrapper{height:auto;overflow:visible;border:none;background:transparent}.up-cpn-table{display:none!important}.up-cpn-table-card-list{display:flex;flex-direction:column;gap:10px;padding:10px;background:#f5f7fa}.up-cpn-table-card{background:white;border-radius:10px;border:1px solid #e2e8f0;padding:14px 16px;box-shadow:0 1px 4px #0000000f;cursor:pointer;transition:all .2s}.up-cpn-table-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#cbd5e0}.up-cpn-table-card.up-cpn-table-row-selected{border-color:#38b2ac;border-left:4px solid #38b2ac;background:#e6fffa}.up-cpn-table-card.up-cpn-table-row-locked{background:#fff5f5;border-color:#fc8181}.up-cpn-table-card.up-cpn-table-row-inactive{opacity:.65}.up-cpn-table-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.up-cpn-table-card-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#e2e8f0,#cbd5e0);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.up-cpn-table-card-name-block{flex:1;min-width:0}.up-cpn-table-card-fullname{font-size:15px;font-weight:600;color:#1a202c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-cpn-table-card-username{font-size:12px;color:#667eea;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-cpn-table-card-body{display:flex;flex-direction:column;gap:6px;font-size:13px}.up-cpn-table-card-row{display:flex;align-items:flex-start;gap:6px;color:#4a5568;flex-wrap:wrap}.up-cpn-table-card-label{font-weight:600;color:#718096;font-size:11px;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0;min-width:60px}.up-cpn-table-card-val{color:#2d3748;font-size:13px;word-break:break-word}.up-cpn-table-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid #edf2f7;flex-wrap:wrap;gap:8px}.up-cpn-table-card-badges{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.up-cpn-table-card-actions{display:flex;align-items:center;gap:8px}}@media (max-width: 480px){.up-cpn-table-card-list{padding:8px;gap:8px}.up-cpn-table-card{padding:12px}.up-cpn-table-card-fullname{font-size:14px}.up-cpn-table-card-avatar{width:38px;height:38px;font-size:18px}}.up-cpn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.up-cpn-grid-card{background:white;border:2px solid #e2e8f0;border-radius:12px;padding:20px;transition:all .2s}.up-cpn-grid-card:hover{border-color:#667eea;box-shadow:0 8px 16px #667eea1a;transform:translateY(-4px)}.up-cpn-grid-card.up-cpn-grid-inactive{opacity:.6}.up-cpn-grid-card.up-cpn-grid-locked{border-color:#feb2b2;background:#fffaf0}.up-cpn-grid-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.up-cpn-grid-avatar{width:64px;height:64px;border-radius:12px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;font-size:32px}.up-cpn-grid-card-status{display:flex;align-items:center}.up-cpn-grid-status-badge{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600}.up-cpn-grid-status-badge.up-cpn-grid-status-locked{background:#fff5f5;color:#c53030;border:1px solid #fc8181}.up-cpn-grid-toggle-switch-sm{position:relative;display:inline-block;width:44px;height:24px}.up-cpn-grid-toggle-switch-sm input{opacity:0;width:0;height:0}.up-cpn-grid-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e0;transition:.3s;border-radius:24px}.up-cpn-grid-toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.up-cpn-grid-toggle-switch-sm input:checked+.up-cpn-grid-toggle-slider{background-color:#48bb78}.up-cpn-grid-toggle-switch-sm input:checked+.up-cpn-grid-toggle-slider:before{transform:translate(20px)}.up-cpn-grid-toggle-switch-sm input:disabled+.up-cpn-grid-toggle-slider{opacity:.5;cursor:not-allowed}.up-cpn-grid-card-body{margin-bottom:16px}.up-cpn-grid-card-name{font-size:18px;font-weight:700;color:#2d3748;margin:0 0 6px}.up-cpn-grid-card-username{font-size:14px;color:#667eea;font-weight:500;margin:0 0 4px}.up-cpn-grid-card-email{font-size:13px;color:#718096;margin:0 0 12px}.up-cpn-grid-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.up-cpn-grid-meta-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#f7fafc;border-radius:6px;font-size:12px;font-weight:500;color:#4a5568}.up-cpn-grid-role-badge{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;white-space:nowrap}.up-cpn-grid-role-badge.up-cpn-grid-role-admin{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.up-cpn-grid-role-badge.up-cpn-grid-role-hr{background:linear-gradient(135deg,#4299e1 0%,#3182ce 100%);color:#fff}.up-cpn-grid-role-badge.up-cpn-grid-role-workshop{background:linear-gradient(135deg,#ed8936 0%,#dd6b20 100%);color:#fff}.up-cpn-grid-role-badge.up-cpn-grid-role-user{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.up-cpn-grid-role-badge.up-cpn-grid-role-vendor{background:linear-gradient(135deg,#48bb78 0%,#38a169 100%);color:#fff}.up-cpn-grid-card-department,.up-cpn-grid-card-position{font-size:13px;color:#4a5568;margin:6px 0}.up-cpn-grid-card-stats{display:flex;gap:12px;padding-top:12px;border-top:1px solid #e2e8f0}.up-cpn-grid-stat-item{font-size:12px;color:#718096}.up-cpn-grid-stat-item.up-cpn-grid-stat-online{color:#48bb78;font-weight:600}.up-cpn-grid-card-footer{display:flex;gap:8px;padding-top:12px;border-top:1px solid #e2e8f0}.up-cpn-grid-card-action-btn{flex:1;padding:10px;border:2px solid #e2e8f0;background:white;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s;display:flex;align-items:center;justify-content:center}.up-cpn-grid-card-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.up-cpn-grid-card-action-btn.up-cpn-grid-btn-view:hover{border-color:#4299e1;background:#ebf8ff}.up-cpn-grid-card-action-btn.up-cpn-grid-btn-edit:hover{border-color:#ed8936;background:#fef5e7}.up-cpn-grid-card-action-btn.up-cpn-grid-btn-delete:hover{border-color:#f56565;background:#fff5f5}@media (max-width: 768px){.up-cpn-grid{grid-template-columns:1fr}}@media (max-width: 480px){.up-cpn-grid-card{padding:16px}.up-cpn-grid-avatar{width:48px;height:48px;font-size:24px}.up-cpn-grid-card-name{font-size:16px}}.up-cpn-pagination-section{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding:16px 24px;background:white;border-top:2px solid #e2e8f0;box-shadow:0 -2px 8px #0000000d;flex-shrink:0}.up-cpn-pagination-info{display:flex;align-items:center;gap:8px;font-size:14px;color:#718096}.up-cpn-pagination-text strong{color:#2d3748;font-weight:600}.up-cpn-pagination-separator{color:#cbd5e0;font-weight:700}.up-cpn-pagination-controls{display:flex;align-items:center;gap:8px}.up-cpn-pagination-btn{padding:8px 14px;background:white;border:2px solid #e2e8f0;color:#4a5568;border-radius:8px;font-size:14px;font-weight:500;transition:all .2s;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.up-cpn-pagination-btn:hover:not(:disabled){border-color:#667eea;background:#f7faff;color:#667eea}.up-cpn-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.up-cpn-pagination-pages{display:flex;gap:4px}.up-cpn-pagination-btn-page{min-width:40px;padding:8px 12px;background:white;border:2px solid #e2e8f0;color:#4a5568;border-radius:8px;font-size:14px;font-weight:500;transition:all .2s;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.up-cpn-pagination-btn-page:hover{border-color:#667eea;background:#f7faff;color:#667eea}.up-cpn-pagination-btn-page.active{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea;color:#fff;font-weight:600}.up-cpn-pagination-btn-page.active:hover{background:linear-gradient(135deg,#5568d3 0%,#653a8b 100%)}@media (max-width: 768px){.up-cpn-pagination-section{flex-direction:column;align-items:stretch;padding:10px 14px;gap:10px}.up-cpn-pagination-info{justify-content:center;order:2;font-size:13px}.up-cpn-pagination-controls{justify-content:center;order:1}}@media (max-width: 480px){.up-cpn-pagination-section{padding:8px 12px}.up-cpn-pagination-controls{gap:4px;font-size:13px}.up-cpn-pagination-btn,.up-cpn-pagination-btn-page{padding:6px 10px;font-size:13px;min-width:36px}.up-cpn-pagination-pages{display:flex;gap:3px}.up-cpn-pagination-pages .up-cpn-pagination-btn-page:not(.active):not(:first-child):not(:last-child){display:none}.up-cpn-pagination-info{font-size:12px}}.rbac-cpn-search-item{position:relative;display:flex;align-items:center;width:100%;max-width:400px;background:#fff;border:1px solid #d1d5db;border-radius:6px;transition:all .2s ease}.rbac-cpn-search-item:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.rbac-cpn-search-item-icon{position:absolute;left:12px;font-size:16px;color:#9ca3af;pointer-events:none;transition:color .2s ease}.rbac-cpn-search-item:focus-within .rbac-cpn-search-item-icon{color:#667eea}.rbac-cpn-search-item-field{flex:1;padding:8px 40px;border:none;outline:none;font-size:14px;color:#1f2937;background:transparent}.rbac-cpn-search-item-field::-moz-placeholder{color:#9ca3af}.rbac-cpn-search-item-field::placeholder{color:#9ca3af}.rbac-cpn-search-item-field:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.rbac-cpn-search-item-clear{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:#e5e7eb;border-radius:50%;color:#6b7280;font-size:12px;cursor:pointer;transition:all .2s ease}.rbac-cpn-search-item-clear:hover{background:#d1d5db;color:#374151}.rbac-cpn-search-item-clear:active{transform:scale(.95)}@media (max-width: 768px){.rbac-cpn-search-item{max-width:100%}}.perm-tree-selector{width:100%;height:100%;display:flex;flex-direction:column;gap:0}.perm-tree-selector-header{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px 8px 0 0;flex-shrink:0}.perm-tree-selector-title{font-size:14px;font-weight:600;color:#1f2937;white-space:nowrap}.perm-tree-selector-required{color:#ef4444;margin-left:4px}.perm-tree-selector-search-wrapper{flex:1;max-width:400px;min-width:250px}.perm-tree-search-result{font-size:.85em;color:#667eea;padding:8px 16px;background:#f0f4ff;border-left:3px solid #667eea;flex-shrink:0}.perm-tree-root{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 12px;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;background:#fff;min-height:0}.perm-tree-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;color:#9ca3af;font-size:.9em;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;background:#fff}.perm-tree-node{margin-bottom:4px}.perm-tree-item{display:flex;align-items:center;padding:8px 12px;border-radius:6px;transition:background-color .2s;cursor:pointer}.perm-tree-item:hover{background-color:#f9fafb}.perm-tree-item.existing{background-color:#f0f4ff;border-left:3px solid #667eea}.perm-tree-item.active-editing{background-color:#fef3c7!important;border:2px solid #f59e0b!important;box-shadow:0 0 0 3px #f59e0b1a}.perm-tree-item.active-editing .perm-tree-text{color:#92400e;font-weight:600}.perm-tree-item.active-editing .perm-tree-code{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.perm-tree-item input[type=checkbox]{width:18px;height:18px;margin-right:10px;cursor:pointer;flex-shrink:0}.perm-tree-item input[type=checkbox].indeterminate{accent-color:#f59e0b}.perm-tree-label{display:flex;align-items:center;gap:6px;cursor:pointer;flex:1;font-size:.95em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.perm-tree-icon{font-size:1.1em;flex-shrink:0}.perm-tree-toggle{padding:0 15px}.perm-tree-text{flex:1;font-weight:500}.perm-tree-text.service{font-weight:700;font-size:1.05em;color:#1f2937}.perm-tree-text.category{font-weight:600;font-size:1em;color:#374151}.perm-tree-text.module{font-weight:500;font-size:.95em;color:#4b5563}.perm-tree-text.permission{font-weight:400;font-size:.9em;color:#6b7280}.perm-tree-count{font-size:.8em;color:#9ca3af;font-weight:400;margin-left:4px}.perm-tree-code{font-size:.8em;color:#7c3aed;background:#f5f3ff;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;margin-left:auto}.perm-tree-badge-existing{font-size:.75em;color:#667eea;background:#eef2ff;padding:2px 8px;border-radius:4px;font-weight:500;margin-left:6px}.perm-tree-children{margin-left:0}.perm-tree-level-0 .perm-tree-item{border-bottom:1px solid #f3f4f6;margin-bottom:8px;padding:8px;margin-left:0}.perm-tree-level-1 .perm-tree-item{background-color:#fafafa;margin-left:30px}.perm-tree-level-2 .perm-tree-item{background-color:#fff;margin-left:60px}.perm-tree-level-3 .perm-tree-item{background-color:#fff;padding:6px 12px;font-size:.9em;margin-left:100px}.perm-tree-selector::-webkit-scrollbar{width:8px}.perm-tree-selector::-webkit-scrollbar-track{background:#f9fafb;border-radius:4px}.perm-tree-selector::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.perm-tree-selector::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 1024px){.perm-tree-selector-header{flex-direction:column;align-items:flex-start;gap:12px}.perm-tree-selector-search-wrapper{width:100%;max-width:100%}}@media (max-width: 768px){.perm-tree-selector{max-height:400px}.perm-tree-item{padding:6px 8px}.perm-tree-label{font-size:.9em}.perm-tree-icon{font-size:1em}.perm-tree-selector-header{padding:10px 12px}.perm-tree-selector-title{font-size:13px}}.udp-panel{width:800px;height:100%;display:flex;flex-direction:column;background:white;border-left:2px solid #e2e8f0;box-shadow:-4px 0 12px #0000000d;flex-shrink:0;position:relative}.udp-header{display:flex;justify-content:space-between;align-items:center;padding:7px 20px;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;flex-shrink:0}.udp-header-left{flex:1}.udp-title{margin:0;font-size:18px;font-weight:600}.udp-header-right{display:flex;gap:8px}.udp-btn{width:36px;height:36px;border:none;background:rgba(255,255,255,.2);border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s;display:flex;align-items:center;justify-content:center}.udp-btn:hover{background:rgba(255,255,255,.3);transform:scale(1.05)}.udp-btn-close:hover{background:rgba(239,68,68,.9)}.udp-content{flex:1;overflow-y:auto;padding:0 0 80px}.udp-content::-webkit-scrollbar{width:8px}.udp-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.udp-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.udp-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}.udp-group{border-bottom:1px solid #e2e8f0;padding:24px}.udp-group:last-child{border-bottom:none}.udp-group-title{margin:0 0 20px;font-size:16px;font-weight:600;color:#1a202c;display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.udp-group-content{margin-top:16px}.udp-two-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}.udp-column{display:flex;flex-direction:column;gap:6px}.udp-user-basic{display:flex;flex-direction:column;align-items:center;gap:20px}.udp-avatar-large{width:120px;height:120px;font-size:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;box-shadow:0 4px 12px #667eea4d}.udp-user-name{margin:0;font-size:20px;font-weight:600;color:#1a202c}.udp-username{margin:0;font-size:14px;color:#718096;font-family:Courier New,monospace}.udp-subsection{margin-top:20px}.udp-subsection:first-child{margin-top:0}.udp-subsection-title{margin:0 0 12px;font-size:14px;font-weight:600;color:#4a5568;display:flex;align-items:center;gap:6px}.udp-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:12px;box-shadow:0 4px 12px #0000001a}.udp-user-name{margin:0 0 8px;font-size:24px;font-weight:700;color:#2d3748}.udp-username{margin:0 0 16px;font-size:16px;color:#667eea;font-weight:500}.udp-badges{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.udp-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;white-space:nowrap}.udp-badge-active{background-color:#d1fae5;color:#065f46}.udp-badge-inactive{background-color:#fee2e2;color:#991b1b}.udp-badge-locked{background-color:#fef3c7;color:#92400e}.udp-section{margin-bottom:24px}.udp-section-title{margin:0 0 16px;font-size:16px;font-weight:700;color:#2d3748;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.udp-field{margin-bottom:10px}.udp-label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.5px}.udp-value{font-size:15px;color:#2d3748;padding:8px 12px;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0}.udp-value-warning{color:#c05621;background:#fef5e7;border-color:#f59e0b}.udp-value-error{color:#c53030;background:#fff5f5;border-color:#fc8181}.udp-input,.udp-select{width:100%;padding:10px 12px;font-size:14px;border:2px solid #e2e8f0;border-radius:6px;transition:all .2s;background:white;color:#2d3748}.udp-input:focus,.udp-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.udp-select{cursor:pointer}.udp-select[multiple]{cursor:default;padding:8px;min-height:120px}.udp-select[multiple] option{padding:8px 12px;border-radius:4px;margin:2px 0;cursor:pointer;transition:background .2s}.udp-select[multiple] option:hover{background:#edf2f7}.udp-select[multiple] option:checked{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;font-weight:500}.udp-select[multiple]:focus option:checked{background:linear-gradient(135deg,#764ba2 0%,#667eea 100%)}.udp-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:2px solid #e2e8f0}.udp-btn-action{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.udp-btn-cancel{background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0}.udp-btn-cancel:hover{background:#edf2f7;border-color:#cbd5e0}.udp-btn-save{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.udp-btn-save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.udp-loading{text-align:center;padding:20px;color:#718096;font-style:italic}.udp-no-data{text-align:center;padding:20px;color:#a0aec0;font-style:italic;font-size:14px;background:#f7fafc;border-radius:6px;border:1px dashed #e2e8f0}.udp-rbac-list{display:flex;flex-direction:column;gap:8px}.udp-rbac-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0}.udp-rbac-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:13px;font-weight:600}.udp-rbac-badge.udp-rbac-role{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.udp-rbac-badge.udp-rbac-group{background:linear-gradient(135deg,#48bb78 0%,#38a169 100%);color:#fff}.udp-rbac-code{font-size:12px;color:#718096;font-family:Courier New,monospace}.udp-perm-tree-readonly{position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none;max-height:420px;overflow-y:auto;overscroll-behavior:contain;border:1px solid #e2e8f0;border-radius:8px;padding:4px 0;background:#f9fafb}.udp-perm-tree-readonly .perm-tree-item{pointer-events:none}.udp-perm-tree-readonly .perm-tree-toggle{pointer-events:auto;cursor:pointer}.udp-perm-tree-readonly input[type=checkbox]{opacity:.75;cursor:default}.udp-perm-tree-readonly .perm-tree-selector-search-wrapper{display:none}.udp-perm-tree-readonly .perm-tree-selector-title:after{content:" (chỉ xem)";font-size:11px;font-weight:400;color:#94a3b8;font-style:italic}.udp-permissions-grid{display:flex;flex-direction:column;gap:6px;max-height:400px;overflow-y:auto}.udp-permission-item{padding:10px 12px;border-radius:6px;border:1px solid #e2e8f0;background:#f7fafc;transition:all .2s;display:grid;grid-template-columns:24px 1fr 1fr;gap:12px;align-items:center;min-width:0}.udp-permission-item.granted{border-left:3px solid #48bb78}.udp-permission-item.denied{border-left:3px solid #f56565;opacity:.6}.udp-permission-icon{font-size:16px;flex-shrink:0;text-align:center}.udp-permission-name{font-size:14px;font-weight:600;color:#2d3748;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.udp-permission-details{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.udp-permission-code{color:#718096;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;font-size:12px}.udp-permission-source{padding:3px 8px;background:#edf2f7;border-radius:4px;color:#4a5568;font-size:11px;font-weight:500;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.udp-sessions-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.udp-session-item{padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#f7fafc;transition:all .2s}.udp-session-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #e2e8f0;gap:8px}.udp-session-browser{font-size:13px;font-weight:600;color:#2d3748;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.udp-session-device{font-size:11px;padding:2px 6px;background:#ebf8ff;color:#2c5282;border-radius:4px;font-weight:500;white-space:nowrap;flex-shrink:0}.udp-session-os{font-size:11px;padding:2px 6px;background:#f0fdf4;color:#166534;border-radius:4px;font-weight:500;white-space:nowrap;flex-shrink:0}.udp-session-details{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;font-size:14px}.udp-session-detail{display:flex;align-items:center;gap:6px;min-width:0}.udp-session-label{color:#718096;font-weight:500;white-space:nowrap;flex-shrink:0}.udp-session-value{color:#2d3748;font-family:Courier New,monospace;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.udp-session-summary{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding-bottom:16px;border-bottom:1px solid #e2e8f0;margin-bottom:16px}.udp-footer{position:absolute;bottom:0;left:0;right:0;display:flex;gap:12px;padding:4px 24px;background:#f8fafc;border-top:3px solid #e2e8f0;box-shadow:0 -4px 12px #0000000d;z-index:10}.udp-footer-btn{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.udp-btn-activate{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;box-shadow:0 2px 8px #48bb784d}.udp-btn-activate:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-2px);box-shadow:0 4px 12px #48bb7866}.udp-btn-deactivate{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff;box-shadow:0 2px 8px #ed89364d}.udp-btn-deactivate:hover{background:linear-gradient(135deg,#dd6b20,#c05621);transform:translateY(-2px);box-shadow:0 4px 12px #ed893666}.udp-btn-delete{background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;box-shadow:0 2px 8px #f565654d}.udp-btn-delete:hover{background:linear-gradient(135deg,#e53e3e,#c53030);transform:translateY(-2px);box-shadow:0 4px 12px #f5656566}.udp-footer-btn:active{transform:translateY(0)}.udp-value-muted{color:#a0aec0!important;font-style:italic}.udp-groups-selection{display:flex;flex-direction:column;gap:8px;padding:8px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;max-height:200px;overflow-y:auto}.udp-checkbox-label{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;border-radius:4px;transition:background .2s}.udp-checkbox-label:hover{background:#edf2f7}.udp-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.udp-checkbox-label span{font-size:14px;color:#2d3748;-webkit-user-select:none;-moz-user-select:none;user-select:none}.udp-dropdown-container{position:relative;width:100%}.udp-dropdown-button{width:100%;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;background:white;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:14px;color:#2d3748;transition:all .2s}.udp-dropdown-button:hover{border-color:#cbd5e0}.udp-dropdown-button:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.udp-dropdown-text{flex:1;text-align:left}.udp-dropdown-arrow{margin-left:8px;font-size:10px;color:#a0aec0;transition:transform .2s}.udp-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:white;border:2px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001a;z-index:1000;max-height:300px;display:flex;flex-direction:column}.udp-dropdown-search{padding:8px;border-bottom:1px solid #e2e8f0}.udp-dropdown-search-input{width:100%;padding:8px 12px;border:1px solid #e2e8f0;border-radius:4px;font-size:13px;outline:none;transition:border-color .2s}.udp-dropdown-search-input:focus{border-color:#667eea}.udp-dropdown-list{max-height:200px;overflow-y:auto;padding:4px}.udp-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;border-radius:4px;transition:background .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.udp-dropdown-item:hover{background:#f7fafc}.udp-dropdown-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#667eea}.udp-dropdown-item span{flex:1;font-size:14px;color:#2d3748}.udp-dropdown-footer{padding:8px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}.udp-dropdown-clear-btn{padding:6px 12px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;color:#718096;cursor:pointer;transition:all .2s}.udp-dropdown-clear-btn:hover{background:#edf2f7;color:#4a5568}.udp-selected-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.udp-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:4px;font-size:12px;font-weight:500}.udp-tag-remove{background:rgba(255,255,255,.2);border:none;color:#fff;width:16px;height:16px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:background .2s;padding:0;line-height:1}.udp-tag-remove:hover{background:rgba(255,255,255,.3)}.udp-btn-reset-password{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none}.udp-btn-reset-password:hover{background:linear-gradient(135deg,#d97706,#b45309)}.udp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center}.udp-modal{background:#fff;border-radius:16px;width:480px;max-width:95vw;box-shadow:0 20px 60px #0003;overflow:hidden;animation:udpModalIn .22s ease}@keyframes udpModalIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.udp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.udp-modal-header h4{margin:0;font-size:16px;font-weight:600}.udp-modal-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1;transition:background .15s}.udp-modal-close:hover{background:rgba(255,255,255,.2)}.udp-modal-body{padding:20px 24px 24px}.udp-modal-desc{font-size:13.5px;color:#4b5563;line-height:1.6;margin-bottom:20px}.udp-reset-field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:8px}.udp-reset-input-row{display:flex;gap:8px;align-items:stretch}.udp-reset-input-wrap{position:relative;flex:1}.udp-reset-input{width:100%;padding:9px 68px 9px 12px;border:1.5px solid #d1d5db;border-radius:8px;font-size:14px;font-family:Courier New,monospace;outline:none;transition:border-color .2s;letter-spacing:.5px}.udp-reset-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.udp-reset-toggle{position:absolute;right:36px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;padding:2px;line-height:1}.udp-reset-copy-inline{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:15px;padding:2px 4px;line-height:1;border-radius:4px;transition:background .15s}.udp-reset-copy-inline:hover{background:rgba(245,158,11,.15)}.udp-btn-generate{white-space:nowrap;padding:9px 14px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.udp-btn-generate:hover{background:linear-gradient(135deg,#4f46e5,#4338ca)}.udp-reset-hint{font-size:12px;color:#6b7280;margin-top:8px;padding:6px 10px;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:4px}.udp-modal-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}.udp-modal-cancel{padding:9px 18px;background:#f3f4f6;color:#374151;border:1.5px solid #d1d5db;border-radius:8px;font-size:14px;cursor:pointer;transition:background .15s}.udp-modal-cancel:hover{background:#e5e7eb}.udp-modal-confirm{padding:9px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.udp-modal-confirm:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)}.udp-modal-confirm:disabled{opacity:.5;cursor:not-allowed}.udp-reset-success{text-align:center;padding:28px 24px 24px}.udp-reset-success-icon{font-size:48px;margin-bottom:12px}.udp-reset-success h5{font-size:16px;font-weight:700;color:#059669;margin-bottom:8px}.udp-reset-success p{font-size:13.5px;color:#4b5563;margin-bottom:12px}.udp-reset-password-display{display:flex;align-items:center;gap:10px;justify-content:center;background:#f3f4f6;border:1.5px solid #d1d5db;border-radius:8px;padding:10px 16px;margin:0 auto 16px}.udp-reset-password-display code{font-size:18px;font-weight:700;letter-spacing:1.5px;color:#1f2937;font-family:Courier New,monospace}.udp-copy-btn{background:#6366f1;color:#fff;border:none;border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;white-space:nowrap;transition:background .15s}.udp-copy-btn:hover{background:#4f46e5}.udp-reset-note{font-size:12px;color:#6b7280;line-height:1.6;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:10px 14px;text-align:left;margin-bottom:20px}.udp-reset-success .udp-modal-confirm{background:linear-gradient(135deg,#059669,#047857);margin:0 auto;display:block;min-width:120px}.udp-reset-success .udp-modal-confirm:hover{background:linear-gradient(135deg,#047857,#065f46)}.udp-btn-update-info{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.udp-btn-update-info:hover{background:#bbdefb;border-color:#1565c0}.udp-modal--update{width:560px;max-width:95vw}.udp-update-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;margin-top:12px;align-items:start}.udp-update-field{display:flex;flex-direction:column;gap:4px}.udp-update-field label{font-size:12.5px;font-weight:600;color:#4a5568}.udp-update-input{padding:7px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#1a202c;background:#fff;transition:border-color .15s}.udp-update-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea26}.udp-update-input[readonly]{background:#f7f8fa;color:#6b7280;cursor:default}.udp-update-emp-row{display:flex;gap:8px}.udp-update-emp-row .udp-update-input{flex:1}.udp-btn-search-emp{padding:7px 14px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.udp-btn-search-emp:hover:not(:disabled){background:#5a67d8}.udp-btn-search-emp:disabled{background:#a5b4fc;cursor:not-allowed}.udp-emp-found-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px}.udp-emp-found-icon{font-size:18px}.udp-emp-found-info{display:flex;flex-direction:column;gap:2px}.udp-emp-found-info strong{font-size:13px;color:#166534}.udp-emp-found-info span{font-size:12px;color:#4b7a5b}.udp-emp-not-found{padding:8px 12px;background:#fff8e1;border:1px solid #f0ad4e;border-radius:6px;font-size:12.5px;color:#856404}.udp-update-error{margin-top:10px;padding:8px 12px;background:#fff5f5;border:1px solid #fc8181;border-radius:6px;font-size:13px;color:#c53030}.udp-modal-body>.udp-update-field{margin-top:12px}.udp-modal-body>.udp-update-field:first-child{margin-top:0}.udp-update-grid-2 .udp-update-field{margin-top:0}.udp-modal-body .udp-emp-found-card,.udp-modal-body .udp-emp-not-found{margin-top:6px}.udp-modal-body .udp-update-grid-2{margin-top:14px}@media (max-width: 1400px){.udp-panel{width:700px}.udp-two-columns{grid-template-columns:1fr}}@media (max-width: 1200px){.udp-panel{width:600px}.udp-avatar-large{width:100px;height:100px;font-size:52px}.udp-user-name{font-size:18px}.udp-session-summary{grid-template-columns:1fr}}@media (max-width: 1024px){.udp-panel{position:fixed;top:70px;right:0;bottom:0;width:min(600px,90vw);height:calc(100vh - 70px);z-index:1000;border-left:2px solid #cbd5e0;box-shadow:-8px 0 32px #0000002e;animation:udp-slide-in-right .25s ease}.udp-panel:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.35);z-index:-1;pointer-events:none}}@media (max-width: 768px){.udp-panel{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:1100;border-left:none;border-radius:0;box-shadow:0 0 40px #0000004d;animation:udp-slide-up .28s cubic-bezier(.34,1.04,.64,1)}.udp-panel:before{display:none}.udp-header{padding:10px 16px;position:sticky;top:0;z-index:10}.udp-title{font-size:16px}.udp-btn{width:32px;height:32px;font-size:14px}.udp-content{padding-bottom:100px}.udp-group{padding:16px}.udp-group-title{font-size:14px;margin-bottom:14px}.udp-two-columns{grid-template-columns:1fr;gap:16px}.udp-avatar-large{width:80px;height:80px;font-size:42px}.udp-user-name{font-size:17px}.udp-username{font-size:13px}.udp-perm-tree-readonly{max-height:280px}.udp-sessions-list,.udp-permissions-grid{max-height:300px}.udp-actions{flex-direction:column;gap:8px;margin-top:16px;padding-top:16px}.udp-btn-action{padding:10px 16px;font-size:14px}}@media (max-width: 480px){.udp-group{padding:12px}.udp-avatar-large{width:68px;height:68px;font-size:34px}.udp-user-name{font-size:15px}.udp-value{font-size:13px;padding:7px 10px}.udp-input,.udp-select{padding:9px 10px;font-size:13px}.udp-permission-item{grid-template-columns:24px 1fr;gap:8px}.udp-permission-details{grid-column:2;flex-direction:column;align-items:flex-start;gap:4px}.udp-rbac-item{flex-direction:column;align-items:flex-start;gap:6px}}@keyframes udp-slide-in-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes udp-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.udp-sessions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.udp-sessions-header .udp-subsection-title{margin-bottom:0}.udp-btn-revoke-all{padding:6px 14px;background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 2px 6px #e53e3e4d}.udp-btn-revoke-all:hover:not(:disabled){background:linear-gradient(135deg,#e53e3e,#c53030);transform:translateY(-1px);box-shadow:0 4px 10px #e53e3e66}.udp-btn-revoke-all:disabled{opacity:.6;cursor:not-allowed;transform:none}.udp-session-info{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.udp-btn-revoke-single{padding:4px 10px;background:transparent;color:#e53e3e;border:1px solid #e53e3e;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.udp-btn-revoke-single:hover:not(:disabled){background:#e53e3e;color:#fff;box-shadow:0 2px 6px #e53e3e4d}.udp-btn-revoke-single:disabled{opacity:.55;cursor:not-allowed}.udp-revoke-message{padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500;margin-bottom:10px;animation:udp-fadein .2s ease}.udp-revoke-message--success{background:#f0fff4;border:1px solid #9ae6b4;color:#276749}.udp-revoke-message--error{background:#fff5f5;border:1px solid #feb2b2;color:#c53030}@keyframes udp-fadein{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.users-page{background:#f5f7fa;height:calc(100vh - 70px);overflow:hidden;padding:10px}.up-layout-container{display:flex;gap:12px;height:100%;margin:0 auto;position:relative}.up-sidebar-left{width:250px;flex-shrink:0;display:flex;flex-direction:column;gap:14px;background:white;border-radius:12px;padding:10px 14px;box-shadow:0 2px 8px #0000000d;height:100%;overflow-y:auto;position:sticky;top:0}.up-sidebar-header{background:white;border-radius:12px;padding:27px;box-shadow:0 2px 8px #0000000d}.up-sidebar-title{font-size:20px;font-weight:700;color:#1a1a1a;margin:0;text-align:center;align-items:center}.up-sidebar-content{flex:1;display:flex;flex-direction:column;gap:16px}.up-sidebar-content .up-cpn-stats-grid{grid-template-columns:1fr;gap:12px}.up-main-content{flex:1;min-width:0;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:margin-right .3s ease}.up-main-content-with-panel{margin-right:0}.users-page-header{background:white;border-radius:12px;padding:12px 24px;box-shadow:0 2px 8px #0000000d;flex-shrink:0;position:sticky;top:0;z-index:10}.header-content{display:flex;justify-content:space-between;align-items:center;gap:24px}.header-title-section{flex-shrink:0}.header-title-section .page-title{font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 8px}.header-title-section .page-description{font-size:14px;color:#666;margin:0}.header-search-group{flex:1;max-width:600px;min-width:300px}.header-search-wrapper{position:relative;display:flex;align-items:center}.header-search-icon{position:absolute;left:16px;font-size:18px;color:#a0aec0;pointer-events:none}.header-search-input{width:100%;padding:12px 48px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;transition:all .2s;background:#f7fafc}.header-search-input:focus{outline:none;border-color:#667eea;background:white;box-shadow:0 0 0 3px #667eea1a}.header-search-input::-moz-placeholder{color:#a0aec0}.header-search-input::placeholder{color:#a0aec0}.header-search-clear{position:absolute;right:12px;background:#cbd5e0;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .2s}.header-search-clear:hover{background:#a0aec0;transform:scale(1.1)}.header-view-mode-switcher{display:flex;gap:4px;background:#f7fafc;border-radius:8px;padding:4px;flex-shrink:0}.header-view-mode-btn{padding:8px 12px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s;display:flex;align-items:center;justify-content:center}.header-view-mode-btn:hover{background:#e2e8f0}.header-view-mode-btn.active{background:white;box-shadow:0 1px 3px #0000001a}.btn-create{display:flex;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;flex-shrink:0}.up-content-with-panel-wrapper{flex:1;display:flex;gap:0;overflow:hidden;position:relative;min-height:0}.up-content-left-section{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.up-main-content-scroll{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:0;min-width:0;padding:0;min-height:0}.up-main-content-scroll::-webkit-scrollbar{width:8px}.up-main-content-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.up-main-content-scroll::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:10px}.up-main-content-scroll::-webkit-scrollbar-thumb:hover{background:#a0aec0}.filter-summary-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;margin:0;background:#edf2f7;border-left:4px solid #667eea;border-radius:0;gap:16px}.filter-summary-text{font-size:14px;color:#2d3748;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-tag{display:inline-flex;padding:4px 12px;background:white;border-radius:6px;font-size:13px;font-weight:600;color:#667eea;border:1px solid #cbd5e0}.btn-reset-filters{display:flex;align-items:center;gap:6px;padding:8px 16px;background:white;border:2px solid #cbd5e0;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;color:#4a5568;transition:all .2s;flex-shrink:0}.btn-reset-filters:hover{background:#667eea;border-color:#667eea;color:#fff;transform:translateY(-1px);box-shadow:0 4px 8px #667eea33}.users-content-section{flex:1;display:flex;flex-direction:column;min-height:0}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-text{margin-top:16px;font-size:15px;color:#718096;font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-title{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 8px}.empty-description{font-size:14px;color:#718096;margin:0 0 20px}.alert{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:10px;margin-bottom:20px;font-size:14px;font-weight:500}.alert-danger{background:#fff5f5;border:2px solid #feb2b2;color:#c53030}.alert-icon{font-size:20px}.alert-close{background:none;border:none;font-size:20px;color:currentColor;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s}.alert-close:hover{opacity:1}.btn{border:none;cursor:pointer;font-weight:600;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;font-size:14px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:10px 20px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-outline{background:white;border:2px solid #e2e8f0;color:#4a5568;padding:8px 16px}.btn-outline:hover{border-color:#cbd5e0;background:#f7fafc}.btn-icon{font-size:16px}@media (min-width: 1025px){.up-layout-container{gap:12px}.up-sidebar-left{width:250px}}@media (max-width: 1024px){.up-layout-container{flex-direction:column;gap:12px;height:auto;min-height:100%}.users-page{height:auto;min-height:calc(100vh - 70px);overflow:visible}.up-sidebar-left{width:100%;height:auto;flex-direction:row;flex-wrap:wrap;padding:16px 20px;position:static;overflow:visible}.up-sidebar-header{display:none}.up-sidebar-content{width:100%}.up-sidebar-content .up-cpn-stats-grid{grid-template-columns:repeat(3,1fr)}.up-main-content{height:auto;overflow:visible;flex:unset}.up-content-with-panel-wrapper,.up-content-left-section{overflow:visible;height:auto}.up-main-content-scroll{overflow:visible;height:auto;min-height:0;flex:unset}.header-content{flex-direction:column;align-items:stretch;gap:12px}.header-title-section{order:1}.header-search-group{order:2;max-width:100%;min-width:100%}.header-view-mode-switcher{order:3;justify-content:flex-end}.btn-create{order:4;width:100%;justify-content:center}}@media (max-width: 768px){.users-page{padding:8px;height:auto;min-height:calc(100vh - 70px);overflow:visible}.up-layout-container{gap:8px;height:auto}.up-sidebar-left{padding:12px 16px;border-radius:10px}.up-sidebar-content .up-cpn-stats-grid{grid-template-columns:repeat(2,1fr)}.users-page-header{padding:12px 16px;border-radius:10px;position:static}.header-content{gap:10px}.header-title-section .page-title{font-size:20px}.header-title-section .page-description{font-size:12px}.header-search-group{min-width:100%}.header-search-input{font-size:14px;padding:10px 40px}.filter-summary-bar{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 14px}.btn-reset-filters{align-self:flex-end}.users-content-section{padding:0}}@media (max-width: 480px){.users-page{padding:6px}.up-layout-container{gap:6px}.up-sidebar-left{padding:10px 12px;border-radius:8px}.up-sidebar-content .up-cpn-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.users-page-header{padding:10px 12px;border-radius:8px}.header-title-section .page-title{font-size:17px;margin-bottom:2px}.header-title-section .page-description{font-size:11px;display:none}.header-search-input{font-size:13px;padding:9px 36px}.header-search-input::-moz-placeholder{font-size:12px;content:"Tìm kiếm..."}.header-search-input::placeholder{font-size:12px;content:"Tìm kiếm..."}.header-view-mode-btn{padding:6px 10px;font-size:14px}.btn-create{width:100%;justify-content:center;padding:10px 16px}.users-content-section{padding:0}.filter-summary-bar{padding:8px 12px}.filter-tag{font-size:12px;padding:3px 8px}.alert{padding:12px 14px;font-size:13px}}@media (max-width: 360px){.users-page{padding:4px}.up-sidebar-content .up-cpn-stats-grid{grid-template-columns:1fr 1fr;gap:6px}.header-title-section .page-title{font-size:15px}}.ucp-container{width:100%;height:calc(100vh - 70px);display:flex;flex-direction:column;overflow:hidden;padding:0}.ucp-page-header{flex-shrink:0;padding:16px 24px;background:white;border-bottom:1px solid #e9ecef}.ucp-header-left{display:flex;align-items:center;gap:16px}.ucp-btn-back{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.ucp-btn-back:hover{background:#5a6268}.ucp-create-container{display:flex;flex-direction:row;flex:1;overflow:hidden;background:white}.ucp-progress-tabs{display:flex;flex-direction:column;width:220px;flex-shrink:0;background:#f8f9fa;border-right:2px solid #e9ecef;padding:16px 0;gap:4px}.ucp-tab-button{display:flex;flex-direction:row;align-items:center;gap:12px;padding:14px 20px;background:transparent;border:none;border-right:3px solid transparent;cursor:pointer;transition:all .2s;text-align:left;position:relative}.ucp-tab-button:after{display:none}.ucp-tab-button:hover{background:rgba(0,123,255,.06)}.ucp-tab-button.active{background:rgba(0,123,255,.08);border-right-color:#007bff}.ucp-tab-number{width:28px;height:28px;border-radius:50%;background:#dee2e6;color:#6c757d;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;transition:all .2s}.ucp-tab-button.active .ucp-tab-number{background:#007bff;color:#fff}.ucp-tab-label{font-size:13px;color:#6c757d;font-weight:500;transition:color .2s;white-space:nowrap}.ucp-tab-button.active .ucp-tab-label{color:#007bff;font-weight:600}.ucp-tab-content-container{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.ucp-content-header{flex-shrink:0;padding:10px 32px;background:white;border-bottom:1px solid #e9ecef}.ucp-content-header-title{font-size:20px;font-weight:700;color:#212529;margin:0 0 4px;display:flex;align-items:center;gap:10px}.ucp-content-header-desc{font-size:13px;color:#6c757d;margin:0}.ucp-tab-content-scroll{flex:1;overflow-y:auto;padding:28px 32px 16px}.ucp-tab-content-scroll:has(.ucp-basic-layout){overflow-y:hidden;padding:0;display:flex;flex-direction:column}.ucp-tab-content{max-width:860px}.ucp-tab-content.ucp-basic-layout{max-width:unset;height:100%}.ucp-tab-title{font-size:24px;font-weight:600;color:#212529;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.ucp-form-section{margin-bottom:15px}.ucp-form-section-body{display:flex;flex-direction:row;gap:20px;align-items:flex-start}.ucp-form-section-left{flex:0 0 260px;min-width:0}.ucp-form-section-right{flex:1;min-width:0}.ucp-form-section-right:empty{display:none}.ucp-section-title{font-size:18px;font-weight:600;color:#495057;margin-bottom:20px;display:flex;align-items:center;gap:10px}.ucp-form-group{margin-bottom:20px}.ucp-form-group label{display:block;font-size:14px;font-weight:500;color:#495057;margin-bottom:8px}.ucp-required{color:#dc3545;margin-left:4px}.ucp-form-control{width:100%;padding:10px 15px;font-size:14px;border:1px solid #ced4da;border-radius:6px;transition:border-color .2s,box-shadow .2s}.ucp-form-control:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.ucp-form-control:disabled{background-color:#e9ecef;cursor:not-allowed}.ucp-form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.ucp-form-row.ucp-form-row-password{grid-template-columns:repeat(2,1fr);align-items:start}.ucp-form-row.ucp-form-row-username{align-items:center}.ucp-autogen-inline{display:flex;justify-content:flex-end;align-items:center}.ucp-form-hint{display:block;font-size:12px;color:#6c757d;margin-top:5px}.ucp-basic-layout{display:flex;flex-direction:row;flex:1;overflow:hidden}.ucp-basic-left{width:260px;flex-shrink:0;display:flex;flex-direction:column;background:#f8f9fa;border-right:1px solid #e9ecef;padding:20px 16px 16px;gap:0}.ucp-basic-left .ucp-section-title{font-size:11px;font-weight:700;color:#6c757d;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;flex-shrink:0}.ucp-basic-left .ucp-user-type-option{flex:1;display:flex;cursor:pointer}.ucp-basic-left .ucp-user-type-option input[type=radio]{display:none}.ucp-basic-left .ucp-user-type-card{flex:1;padding:16px 14px;border:2px solid #e9ecef;border-radius:8px;background:white;margin-bottom:8px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;transition:all .2s;text-align:center}.ucp-basic-left .ucp-user-type-option:last-child .ucp-user-type-card{margin-bottom:0}.ucp-basic-left .ucp-user-type-option.selected .ucp-user-type-card{border-color:#007bff;background:rgba(0,123,255,.04);box-shadow:0 2px 8px #007bff1f}.ucp-basic-left .ucp-user-type-card-header{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px}.ucp-basic-left .ucp-user-type-icon{font-size:24px;flex-shrink:0;line-height:1;display:flex;align-items:center;justify-content:center;height:24px}.ucp-basic-left .ucp-user-type-card h5{font-size:14px;font-weight:600;color:#212529;margin:0;line-height:1;white-space:nowrap}.ucp-basic-left .ucp-user-type-option.selected .ucp-user-type-card h5{color:#007bff}.ucp-basic-left .ucp-user-type-card p{font-size:12px;color:#6c757d;margin:0;line-height:1.5;text-align:center;padding-left:0}.ucp-basic-right{flex:1;min-width:0;overflow-y:auto;padding:24px 28px}@media (max-width: 768px){.ucp-basic-layout{flex-direction:column}.ucp-basic-left{width:100%;flex-direction:row;height:auto;border-right:none;border-bottom:1px solid #e9ecef;padding:12px;gap:8px}.ucp-basic-left .ucp-user-type-option{flex:1}.ucp-basic-left .ucp-user-type-card{margin-bottom:0}.ucp-basic-right{overflow-y:visible;padding:16px}}.ucp-user-type-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.ucp-user-type-option{cursor:pointer}.ucp-user-type-option input[type=radio]{display:none}.ucp-user-type-card{padding:25px;border:2px solid #dee2e6;border-radius:8px;text-align:center;transition:all .3s;background:white}.ucp-user-type-option.selected .ucp-user-type-card{border-color:#007bff;background:rgba(0,123,255,.05);box-shadow:0 4px 12px #007bff26}.ucp-user-type-icon{font-size:48px;margin-bottom:15px}.ucp-user-type-card h5{font-size:18px;font-weight:600;color:#212529;margin-bottom:8px}.ucp-user-type-card p{font-size:14px;color:#6c757d;margin:0}.ucp-employee-info-card{padding:20px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-top:15px}.ucp-employee-info-card h5{font-size:16px;font-weight:600;color:#495057;margin-bottom:15px}.ucp-info-split{display:flex;flex-direction:row;gap:16px;align-items:flex-start}.ucp-info-split-main{flex:2;min-width:0}.ucp-info-split-checklist{flex:1;min-width:0;background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:14px 16px}.ucp-checklist-title{font-size:13px;font-weight:600;color:#495057;margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid #e9ecef}.ucp-checklist{display:flex;flex-direction:column;gap:6px}.ucp-checklist-item{display:flex;align-items:center;gap:8px;font-size:12px;line-height:1.4}.ucp-checklist-icon{flex-shrink:0;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.ucp-checklist-icon.pass{background:#d4edda;color:#155724}.ucp-checklist-icon.fail{background:#f8d7da;color:#721c24}.ucp-checklist-text{color:#495057;flex:1}.ucp-checklist-item.pass .ucp-checklist-text{color:#155724}.ucp-checklist-item.fail .ucp-checklist-text{color:#721c24}.ucp-checklist-icon.optional{background:#e9ecef;color:#6c757d}.ucp-checklist-item.optional .ucp-checklist-text{color:#868e96}.ucp-checklist-optional{font-size:10px;color:#adb5bd;font-style:italic}.ucp-password-input-wrap{position:relative;display:flex;align-items:center}.ucp-password-input-wrap .ucp-form-control-password{padding-right:40px;width:100%}.ucp-password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;line-height:1;padding:2px 4px;border-radius:4px;color:#6c757d;transition:color .15s,background .15s;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ucp-password-toggle:hover{color:#343a40;background:#f0f0f0}.ucp-password-toggle:active{background:#e2e6ea}.ucp-btn-autogen{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;color:#6f42c1;background:#f3eeff;border:1px solid #c4a8f5;border-radius:6px;cursor:pointer;transition:all .18s ease;white-space:nowrap;flex-shrink:0}.ucp-btn-autogen:hover{background:#e8d8ff;border-color:#a97de8;color:#5a30a8}.ucp-btn-autogen:active{background:#d9c4fc;transform:scale(.97)}.ucp-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.ucp-info-item{display:flex;gap:8px}.ucp-info-label{font-size:13px;font-weight:500;color:#6c757d;min-width:100px}.ucp-info-value{font-size:13px;color:#212529;font-weight:500}.ucp-table-wrapper{border:1px solid #dee2e6;border-radius:8px;overflow:hidden;margin-bottom:24px}.ucp-table{width:100%;border-collapse:collapse;font-size:14px;background:white}.ucp-table thead tr{background:#f8f9fa;border-bottom:2px solid #dee2e6}.ucp-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.ucp-table-col-check{width:44px;text-align:center!important}.ucp-table-col-name{min-width:160px}.ucp-table-col-code{width:140px}.ucp-table-col-priority{width:100px}.ucp-table-col-desc{min-width:200px}.ucp-table-row{border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .15s}.ucp-table-row:last-child{border-bottom:none}.ucp-table-row:hover{background:#f5f8ff}.ucp-table-row.ucp-table-row-selected{background:#eaf2ff}.ucp-table-row.ucp-table-row-selected:hover{background:#ddeeff}.ucp-table-row.ucp-table-row-selected.ucp-table-row-selected-group{background:#e7f8fb}.ucp-table-row.ucp-table-row-selected.ucp-table-row-selected-group:hover{background:#d4f1f6}.ucp-table td{padding:12px 16px;vertical-align:middle;color:#212529}.ucp-table-col-check td,td.ucp-table-col-check{text-align:center}.ucp-table-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#007bff}.ucp-table-cell-name{font-weight:600;color:#212529}.ucp-table-badge-code{display:inline-block;padding:2px 8px;font-size:11px;font-family:monospace;background:#e9ecef;color:#495057;border-radius:4px}.ucp-table-badge-priority{display:inline-block;padding:2px 10px;font-size:12px;font-weight:600;background:#d4edda;color:#155724;border-radius:12px}.ucp-table-cell-desc{font-size:13px;color:#6c757d;line-height:1.4}.ucp-table-empty{padding:40px 16px;text-align:center;color:#adb5bd;font-style:italic;font-size:14px}.ucp-selected-roles-summary{padding:16px 20px;background:#f0f7ff;border:1px solid #cce0ff;border-radius:8px;margin-top:4px}.ucp-selected-roles-summary h4{font-size:14px;font-weight:600;color:#0056b3;margin-bottom:10px}.ucp-selected-roles-list{display:flex;flex-wrap:wrap;gap:8px}.ucp-permissions-info{padding:15px 20px;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;margin-bottom:25px}.ucp-permissions-info p{margin:0;font-size:14px;color:#856404}.ucp-permissions-tree{display:flex;flex-direction:column;gap:25px}.ucp-permission-module{border:1px solid #dee2e6;border-radius:8px;overflow:hidden}.ucp-module-name{padding:12px 16px;background:#f8f9fa;font-size:16px;font-weight:600;color:#495057;margin:0;border-bottom:1px solid #dee2e6}.ucp-permission-list{padding:15px}.ucp-permission-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-bottom:1px solid #f1f3f5;transition:background-color .2s}.ucp-permission-item:last-child{border-bottom:none}.ucp-permission-item:hover{background:#f8f9fa}.ucp-permission-label{display:flex;align-items:center;gap:12px;flex:1;cursor:pointer}.ucp-permission-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.ucp-permission-info{display:flex;flex-direction:column;gap:4px}.ucp-permission-name{font-size:14px;font-weight:500;color:#212529}.ucp-permission-code{font-size:12px;color:#6c757d;font-family:monospace}.ucp-permission-category{font-size:12px;color:#6c757d;padding:3px 8px;background:#e9ecef;border-radius:4px}.ucp-preview-sections{display:flex;flex-direction:column;gap:25px}.ucp-preview-section{padding:20px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px}.ucp-preview-section-title{font-size:16px;font-weight:600;color:#495057;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #dee2e6}.ucp-preview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.ucp-preview-item{display:flex;gap:10px}.ucp-preview-label{font-size:13px;font-weight:500;color:#6c757d;min-width:140px}.ucp-preview-value{font-size:13px;color:#212529;font-weight:600}.ucp-preview-badges{display:flex;flex-wrap:wrap;gap:8px}.ucp-empty-state{text-align:center;padding:40px 20px;color:#6c757d}.ucp-form-actions{display:flex;justify-content:flex-end;align-items:center;gap:24px;padding:16px 32px;background:#f8f9fa;border-top:1px solid #dee2e6;flex-shrink:0;position:sticky;bottom:0;z-index:10;box-shadow:0 -2px 8px #0000000f}.ucp-form-actions-hint{margin-right:auto;font-size:13px;color:#6c757d;font-style:italic}.ucp-form-actions .ucp-btn{padding:10px 24px;font-size:14px;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.ucp-form-actions .ucp-btn-outline{background:white;color:#6c757d;border:1px solid #ced4da}.ucp-form-actions .ucp-btn-outline:hover{background:#e9ecef}.ucp-form-actions .ucp-btn-secondary{background:#6c757d;color:#fff}.ucp-form-actions .ucp-btn-secondary:hover{background:#5a6268}.ucp-form-actions .ucp-btn-primary{background:#007bff;color:#fff}.ucp-form-actions .ucp-btn-primary:hover{background:#0056b3}.ucp-form-actions .ucp-btn-success{background:#28a745;color:#fff}.ucp-form-actions .ucp-btn-success:hover{background:#218838}.ucp-form-actions .ucp-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.ucp-create-container{flex-direction:column}.ucp-progress-tabs{width:100%;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:2px solid #e9ecef;padding:0;gap:0}.ucp-tab-button{flex-direction:column;align-items:center;min-width:100px;padding:12px 8px;border-right:none;border-bottom:3px solid transparent}.ucp-tab-button.active{border-bottom-color:#007bff;border-right-color:transparent}.ucp-tab-content-scroll{padding:20px 16px}.ucp-user-type-selector,.ucp-form-row,.ucp-info-grid,.ucp-preview-grid{grid-template-columns:1fr}.ucp-table-col-desc{display:none}.ucp-form-actions{padding:12px 16px}}.ucp-card-manual-fields{margin-top:12px;border-top:1px dashed #f0ad4e;padding-top:10px}.ucp-card-manual-fields-banner{font-size:12.5px;font-weight:500;color:#856404;background:#fff8e1;border-radius:4px;padding:6px 10px;margin-bottom:10px}.ucp-manual-fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px 14px}.ucp-manual-fields-grid--not-found{margin-top:12px}.ucp-employee-not-found-card{background:#fff8e1;border:1.5px solid #f0ad4e;border-radius:8px;padding:16px;color:#856404}.ucp-employee-not-found-icon{font-size:24px;margin-bottom:6px}.ucp-employee-not-found-title{font-weight:600;font-size:14px;margin:0 0 4px;color:#856404}.ucp-employee-not-found-desc{font-size:12.5px;margin:0;color:#6c5b00;line-height:1.5}.ucp-info-missing{color:#dc3545;font-style:italic;font-size:12px}.api-management-page{padding:24px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;border-bottom:2px solid #e5e7eb}.page-header h1{font-size:32px;font-weight:700;color:#1f2937;margin:0 0 8px}.page-description{color:#6b7280;font-size:14px;margin:0}.header-actions{display:flex;gap:12px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:flex-start}.alert-error{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-content{display:flex;gap:12px;flex:1}.alert-icon{font-size:20px;flex-shrink:0}.alert-message{flex:1}.alert-message strong{display:block;margin-bottom:8px;font-size:15px}.alert-help{margin-top:12px;padding:12px;background:white;border-radius:6px;font-size:13px}.alert-help p{margin:0 0 8px;font-weight:600}.alert-help ol{margin:8px 0 0 20px;padding:0}.alert-help li{margin:4px 0;line-height:1.6}.alert-help a{color:#2563eb;text-decoration:underline;font-weight:600}.alert-help code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#dc2626}.alert-close{background:none;border:none;font-size:20px;color:#6b7280;cursor:pointer;padding:0 4px;flex-shrink:0;line-height:1}.alert-close:hover{color:#991b1b}.tabs-navigation{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid #e5e7eb;padding-bottom:0}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:15px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;position:relative;bottom:-2px}.tab-button:hover{color:#3b82f6;background-color:#f3f4f6}.tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6;font-weight:600}.statistics-section{margin-bottom:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:20px;border-radius:12px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 6px #0000001a}.stat-card:nth-child(2){background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.stat-card:nth-child(3){background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%)}.stat-card:nth-child(4){background:linear-gradient(135deg,#43e97b 0%,#38f9d7 100%)}.stat-icon{font-size:36px;opacity:.9}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;margin:0}.stat-label{font-size:13px;opacity:.9;margin-top:4px}.service-stats{background:white;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.service-stats h3{margin:0 0 20px;font-size:18px;color:#1f2937}.service-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.service-stat-card{background:#f9fafb;padding:16px;border-radius:8px;border:1px solid #e5e7eb}.service-name{font-weight:600;font-size:16px;color:#1f2937;margin-bottom:12px}.service-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px}.metric{display:flex;justify-content:space-between;font-size:13px}.metric-label{color:#6b7280}.metric-value{font-weight:600;color:#1f2937}.metric-value.success{color:#059669}.metric-value.warning{color:#d97706}.most-used-section{background:white;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.most-used-section h3{margin:0 0 16px;font-size:18px;color:#1f2937}.most-used-list{display:flex;flex-direction:column;gap:12px}.most-used-item{display:flex;align-items:center;gap:16px;padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.rank{font-size:20px;font-weight:700;color:#9ca3af;min-width:40px;text-align:center}.api-info{flex:1}.api-title{display:flex;align-items:center;gap:8px;margin-bottom:6px}.api-path{font-family:Courier New,monospace;font-size:13px;color:#1f2937}.api-meta{display:flex;gap:12px;font-size:12px;color:#6b7280}.filters-section{background:white;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.filters-section h3{margin:0 0 16px;font-size:18px;color:#1f2937}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:13px;font-weight:500;color:#374151}.filter-group.search-group{grid-column:span 2}.search-input-group{display:flex;gap:8px}.search-input-group .form-control{flex:1}.filter-group.checkbox-group{display:flex;flex-direction:column;gap:8px;justify-content:center}.filter-group.checkbox-group label{display:flex;align-items:center;gap:8px;font-weight:400}.filter-group.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-control{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.btn-block{width:100%;justify-content:center}.api-table-section{background:white;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-header{padding:20px 24px;border-bottom:1px solid #e5e7eb}.table-header h3{margin:0;font-size:18px;color:#1f2937}.table-container{overflow-x:auto}.api-table{width:100%;border-collapse:collapse;font-size:13px}.api-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.api-table th{padding:12px 16px;text-align:left;font-weight:600;color:#374151;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.api-table th:hover{background-color:#f3f4f6}.api-table td{padding:12px 16px;border-bottom:1px solid #e5e7eb}.api-table tbody tr:hover{background-color:#f9fafb}.api-table tbody tr.deprecated-row{background-color:#fef3c7;opacity:.8}.method-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.method-get{background-color:#dbeafe;color:#1e40af}.method-post{background-color:#d1fae5;color:#065f46}.method-put{background-color:#fef3c7;color:#92400e}.method-patch{background-color:#e0e7ff;color:#3730a3}.method-delete{background-color:#fee2e2;color:#991b1b}.service-badge,.category-badge{display:inline-block;padding:4px 10px;background-color:#f3f4f6;color:#1f2937;border-radius:12px;font-size:12px;font-weight:500}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500}.badge-success{background-color:#d1fae5;color:#065f46}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-secondary{background-color:#f3f4f6;color:#4b5563}.api-title-cell .title{font-weight:500;color:#1f2937;margin-bottom:4px}.api-title-cell .description{color:#6b7280;font-size:12px}.status-cell{display:flex;flex-direction:column;gap:4px}.action-buttons{display:flex;gap:6px}.btn-icon{background:none;border:1px solid #d1d5db;padding:6px 10px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.btn-icon:hover{background-color:#f3f4f6;transform:scale(1.1)}.btn-view:hover{border-color:#3b82f6}.btn-edit:hover{border-color:#f59e0b}.btn-delete:hover{border-color:#ef4444}.empty-state{text-align:center;padding:60px 20px}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{font-size:20px;color:#1f2937;margin-bottom:8px}.empty-state p{color:#6b7280;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-width:900px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:20px;color:#1f2937}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:#6b7280}.modal-close:hover{background-color:#f3f4f6}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb}.form-section{margin-bottom:32px}.form-section:last-child{margin-bottom:0}.form-section h3{font-size:16px;color:#1f2937;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.form-group textarea{resize:vertical}.stats-display{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;background:#f9fafb;padding:16px;border-radius:8px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-item .stat-label{font-size:12px;color:#6b7280}.stat-item .stat-value{font-size:16px;font-weight:600;color:#1f2937}.usage-example-box{margin-top:20px;padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.usage-example-box h4{font-size:14px;font-weight:600;color:#1f2937;margin:0 0 12px}.code-example{background:#1f2937;border-radius:6px;overflow:hidden}.code-example pre{margin:0;padding:16px;overflow-x:auto}.code-example code{font-family:Consolas,Monaco,Courier New,monospace;font-size:12px;line-height:1.6;color:#f3f4f6;display:block}.analytics-tab{padding:20px;background-color:#f9fafb;border-radius:8px}.analytics-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px;background:white;border-radius:8px;box-shadow:0 1px 3px #0000001a}.time-range-selector{display:flex;gap:8px}.time-range-button{padding:8px 16px;background:white;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.time-range-button:hover{border-color:#3b82f6;color:#3b82f6}.time-range-button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.analytics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.analytics-card{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.analytics-card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.analytics-card-icon{font-size:24px}.analytics-card-title{font-size:13px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.analytics-card-value{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:8px}.analytics-card-subtitle{font-size:13px;color:#9ca3af}.service-breakdown{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.service-breakdown h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937}.service-table{width:100%;border-collapse:collapse}.service-table th{text-align:left;padding:12px;background:#f9fafb;border-bottom:2px solid #e5e7eb;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.service-table td{padding:12px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#374151}.service-table tbody tr:hover{background-color:#f9fafb}.timeline-chart{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.timeline-chart h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937}.chart-container{height:300px;display:flex;align-items:flex-end;gap:8px;padding:20px 0;border-bottom:2px solid #e5e7eb;position:relative}.chart-bar{flex:1;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:opacity .2s ease}.chart-bar:hover{opacity:.8}.bar-segment{width:100%;border-radius:4px 4px 0 0;transition:all .2s ease}.bar-success{background:linear-gradient(135deg,#10b981 0%,#059669 100%)}.bar-error{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%)}.chart-label{margin-top:8px;font-size:11px;color:#6b7280;text-align:center;transform:rotate(-45deg);transform-origin:top left;white-space:nowrap}.chart-legend{display:flex;gap:16px;margin-top:16px;justify-content:center}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.legend-color{width:16px;height:16px;border-radius:3px}.top-apis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:24px}.top-api-card{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.top-api-card h4{margin:0 0 16px;font-size:15px;font-weight:600;color:#1f2937}.top-api-list{list-style:none;padding:0;margin:0}.top-api-item{padding:12px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.top-api-item:last-child{border-bottom:none}.top-api-item:hover{background-color:#f9fafb}.api-rank{font-size:18px;font-weight:700;color:#9ca3af;min-width:30px}.api-info{flex:1;margin:0 12px}.api-endpoint{font-size:13px;font-weight:500;color:#1f2937;margin-bottom:4px}.api-method{font-size:11px;padding:2px 6px;border-radius:3px;margin-right:4px;font-weight:600}.api-method.GET{background:#dbeafe;color:#1e40af}.api-method.POST{background:#dcfce7;color:#166534}.api-method.PUT{background:#fef3c7;color:#92400e}.api-method.DELETE{background:#fee2e2;color:#991b1b}.api-metric{font-size:16px;font-weight:700;color:#3b82f6;text-align:right}.recent-errors{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.recent-errors h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937}.errors-table{width:100%;border-collapse:collapse}.errors-table th{text-align:left;padding:12px;background:#fef2f2;border-bottom:2px solid #fca5a5;font-size:13px;font-weight:600;color:#991b1b;text-transform:uppercase;letter-spacing:.5px}.errors-table td{padding:12px;border-bottom:1px solid #fee2e2;font-size:14px;color:#374151}.errors-table tbody tr:hover{background-color:#fef2f2}.error-status{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#fee2e2;color:#991b1b}.error-message{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:Courier New,monospace;font-size:12px;color:#6b7280}.analytics-empty-state{text-align:center;padding:60px 20px;color:#6b7280}.analytics-empty-state .icon{font-size:64px;margin-bottom:16px;opacity:.5}.analytics-empty-state h3{font-size:20px;margin:0 0 8px;color:#374151}.analytics-empty-state p{font-size:14px;margin:0}@media (max-width: 768px){.analytics-summary,.top-apis-grid{grid-template-columns:1fr}.tabs-navigation{overflow-x:auto}.tab-button{white-space:nowrap}.chart-container{height:200px}}.page-header{margin-bottom:1px!important}.page-title{font-size:1.5rem;margin:0;display:flex;align-items:center;gap:8px}.page-description{color:#6b7280;margin-top:4px}.stats-grid{display:flex;gap:12px;flex-wrap:wrap}.stat-card{background:#fff;border:1px solid #e5e7eb;padding:12px;border-radius:8px;display:flex;align-items:center;gap:10px;min-width:140px}.stat-icon{font-size:1.4rem}.stat-content h3{margin:0;font-size:1.25rem}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px}.card-header{padding:12px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.btn{padding:6px 10px;border-radius:6px;border:1px solid #d1d5db;background:#fff;cursor:pointer}.btn-primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.btn-warning{background:#f59e0b;color:#fff;border-color:#f59e0b}.btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.btn-success{background:#10b981;color:#fff;border-color:#10b981}.btn-outline{background:transparent}.logs-container{background:#0f172a;color:#e6eef8;padding:8px;border-radius:6px;font-family:monospace}.log-entry{padding:6px;border-bottom:1px dashed rgba(255,255,255,.06);display:flex;gap:8px;align-items:center}.log-entry:hover{background:rgba(255,255,255,.02)}.log-timestamp{color:#93c5fd}.log-level.info{color:#60a5fa}.log-level.warning{color:#f59e0b}.log-level.error{color:#f87171}.log-level.debug{color:#a3e635}.log-service{color:#c7d2fe}.log-module{color:#a5b4fc;font-size:.8rem;font-weight:500}.log-method{color:#fbbf24;font-weight:600;font-size:.8rem;text-align:center}.log-message{flex:1;color:#e2e8f0;line-height:1.5;font-size:.875rem}.status-indicator{width:10px;height:10px;border-radius:50%;display:inline-block}.status-indicator.online{background:#10b981}.alert{padding:8px;border-radius:6px}.alert-danger{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(2,6,23,.6);display:flex;align-items:center;justify-content:center}.modal{background:#fff;border-radius:8px;width:720px;max-width:95%;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid #e5e7eb}.modal-body{padding:12px}.modal-footer{padding:12px;border-top:1px solid #e5e7eb;text-align:right}.detail-row{display:flex;gap:8px;padding:6px 0}.detail-content{background:#f3f4f6;padding:8px;border-radius:4px;white-space:pre-wrap;max-height:240px;overflow:auto}.badge{padding:3px 6px;border-radius:4px;font-size:.75rem}.badge-danger{background:#fecaca;color:#7f1d1d}.badge-warning{background:#fff7ed;color:#92400e}.badge-info{background:#eff6ff;color:#1e3a8a}.badge-primary{background:#eef2ff;color:#3730a3}.logs-table-container{background:#0f172a;color:#e6eef8;border-radius:6px;overflow:hidden;height:100%;overflow-y:auto}.logs-table{width:100%;border-collapse:collapse;font-family:monospace;font-size:.875rem;min-width:1200px}.logs-table thead{background:#1e293b;position:sticky;top:0;z-index:10}.logs-table th{padding:10px 12px;text-align:left;font-weight:600;color:#94a3b8;border-bottom:2px solid #334155;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.logs-table th:nth-child(1),.logs-table td:nth-child(1){width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table th:nth-child(2),.logs-table td:nth-child(2){width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table th:nth-child(3),.logs-table td:nth-child(3){width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table th:nth-child(4),.logs-table td:nth-child(4){width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table th:nth-child(5),.logs-table td:nth-child(5){width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table th:nth-child(6),.logs-table td:nth-child(6){width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table th:nth-child(7),.logs-table td:nth-child(7){width:400px}.logs-table .filter-row th{padding:6px 8px;border-bottom:1px solid #334155;background:#1a2332}.logs-table .column-filter{width:100%;background:#0f172a;color:#e2e8f0;border:1px solid #334155;border-radius:4px;padding:4px 6px;font-size:.75rem;cursor:pointer;outline:none;font-family:monospace}.logs-table .column-filter:hover{border-color:#4299e1;background:#1e293b}.logs-table .column-filter:focus{border-color:#4299e1;box-shadow:0 0 0 2px #4299e133}.logs-table .column-filter-input{width:100%;background:#0f172a;color:#e2e8f0;border:1px solid #334155;border-radius:4px;padding:4px 6px;font-size:.75rem;outline:none;font-family:monospace}.logs-table .column-filter-input::-moz-placeholder{color:#64748b}.logs-table .column-filter-input::placeholder{color:#64748b}.logs-table .column-filter-input:hover{border-color:#4299e1;background:#1e293b}.logs-table .column-filter-input:focus{border-color:#4299e1;box-shadow:0 0 0 2px #4299e133}.logs-table tbody tr{border-bottom:1px solid rgba(255,255,255,.06);transition:background .2s;cursor:pointer}.logs-table tbody tr:hover{background:rgba(255,255,255,.06)}.logs-table tbody tr.selected{background:rgba(59,130,246,.2);border-left:3px solid #3b82f6}.logs-table tbody tr.selected:hover{background:rgba(59,130,246,.25)}.logs-table td{padding:10px 12px;vertical-align:middle}.logs-table .log-timestamp{color:#93c5fd;font-size:.8rem;white-space:nowrap}.logs-table .log-level{text-align:center}.logs-table .log-service{color:#c7d2fe;font-weight:500;font-size:.85rem}.logs-table .log-module{color:#a5b4fc;font-size:.8rem;font-weight:500}.logs-table .log-method{color:#fbbf24;font-weight:600;font-size:.8rem;text-align:center}.logs-table .log-message{color:#e2e8f0;line-height:1.5;font-size:.875rem}.logs-table .log-details-inline{color:#cbd5e1;font-size:.8rem;line-height:1.4;position:relative;cursor:pointer}.logs-table .log-details-inline>div{max-width:600px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logs-table .log-details-inline:hover{background:rgba(59,130,246,.1);color:#93c5fd}.logs-table .log-actions{text-align:center}.custom-tooltip{position:fixed;right:20px;top:120px;bottom:20px;width:500px;background:#1e293b;color:#e2e8f0;padding:16px;border-radius:8px;box-shadow:0 10px 25px #00000080;z-index:9999;font-size:.85rem;line-height:1.6;border:1px solid #334155;overflow-y:auto;overflow-x:auto}.custom-tooltip::-webkit-scrollbar{width:8px;height:8px}.custom-tooltip::-webkit-scrollbar-track{background:#0f172a;border-radius:4px}.custom-tooltip::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.custom-tooltip::-webkit-scrollbar-thumb:hover{background:#64748b}.custom-tooltip-arrow{position:fixed;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:12px solid #1e293b;z-index:9998;filter:drop-shadow(-2px 0 2px rgba(0,0,0,.3))}.custom-tooltip-title{font-size:.9rem;font-weight:600;color:#93c5fd;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #334155}.custom-tooltip-content{white-space:pre-wrap;word-wrap:break-word;font-family:monospace;font-size:.8rem;line-height:1.8}.logs-table .btn-sm{padding:5px 10px;font-size:.8rem;border-radius:4px;transition:all .2s}.logs-table .btn-sm:hover{transform:scale(1.1);background:rgba(59,130,246,.2)}.status-code{padding:2px 6px;border-radius:4px;font-weight:600;font-size:.75rem;display:inline-block}.status-code.status-2{background:#065f46;color:#6ee7b7}.status-code.status-3{background:#1e3a8a;color:#93c5fd}.status-code.status-4{background:#92400e;color:#fcd34d}.status-code.status-5{background:#7f1d1d;color:#fca5a5}.logs-table .log-row.log-error{background:rgba(239,68,68,.05)}.logs-table .log-row.log-error:hover{background:rgba(239,68,68,.1)}.logs-table .log-row.log-warning{background:rgba(245,158,11,.05)}.logs-table .log-row.log-warning:hover{background:rgba(245,158,11,.1)}.logs-table .log-row.log-debug{background:rgba(163,230,53,.03)}.logs-table .log-row.log-debug:hover{background:rgba(163,230,53,.08)}@media (max-width:640px){.grid{grid-template-columns:1fr}.stats-grid{flex-direction:column}}.logs-page-card-body{padding:0;height:calc(100vh - 196px);min-height:600px}.logs-page-split-container{display:flex;gap:0;height:100%;position:relative}.logs-page-table-section{flex:1;min-width:0;height:100%}.logs-page-detail-panel{position:fixed;right:0;top:197px;width:800px;height:calc(100vh - 200px);border-left:1px solid #334155;background:#0f172a;overflow-y:auto;z-index:1000;transform:translate(100%);transition:transform .3s ease-in-out;box-shadow:-5px 0 20px #00000080}.logs-page-detail-panel.open{transform:translate(0)}.logs-page-detail-header{padding:17px;border-bottom:1px solid #334155;background:#1e293b;position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center}.logs-page-detail-header-title{font-size:.9rem;font-weight:600;color:#93c5fd}.logs-page-detail-header-subtitle{font-size:.75rem;color:#94a3b8;margin-top:4px}.logs-page-detail-close-btn{background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.5);color:#fca5a5;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.75rem;transition:all .2s}.logs-page-detail-close-btn:hover{background:rgba(239,68,68,.3)}.logs-page-detail-content{padding:16px;font-family:monospace;font-size:.8rem;line-height:1.8;color:#e2e8f0;white-space:pre-wrap;word-wrap:break-word}.logs-page-empty-state{text-align:center;padding:40px;color:#94a3b8}.logs-page-alert{margin:12px}.rbac-management-page{display:flex;height:calc(100vh - 70px);overflow:hidden;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.rbac-management-page>.rbac-sidebar{width:190px;background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-right:2px solid rgba(255,255,255,.2);display:flex;flex-direction:column;padding:20px 0;overflow-y:auto}.rbac-tabs{display:flex;flex-direction:column;gap:8px;padding:0 10px}.rbac-tab-btn{padding:12px 10px;background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:.85rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}.rbac-tab-btn:hover{background:rgba(255,255,255,.2);transform:translate(5px)}.rbac-tab-btn.active{background:white;color:#667eea;border-color:#fff;box-shadow:0 4px 15px #0003}.tab-icon{font-size:1.5rem}.tab-label{font-weight:500;font-size:.75rem;line-height:1.2}.rbac-main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.rbac-header{background:rgba(255,255,255,.95);padding:5px 30px;border-bottom:3px solid #667eea;box-shadow:0 2px 10px #0000001a;flex-shrink:0;display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;gap:20px}.rbac-header-content{grid-column:1;justify-self:start}.rbac-header h1{font-size:1.8rem;margin:0 0 5px;color:#667eea}.rbac-description{font-size:.95rem;color:#666;margin:0}.rbac-header-actions{grid-column:3;justify-self:end;display:flex;gap:10px;align-items:center;flex:0 0 auto}.rbac-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:white;min-height:0}.rbac-tab-container,.rbac-cpn-permissions-tab,.rbac-cpn-roles-tab,.rbac-cpn-role-permissions-tab,.rbac-cpn-user-groups-tab,.rbac-cpn-group-members-tab,.rbac-cpn-group-permissions-tab,.rbac-cpn-permission-hierarchy-tab{flex:1;display:flex;flex-direction:column;overflow:visible;position:relative;min-height:0}.rbac-tab-container.rbac-split-layout{flex-direction:row;overflow:hidden;height:100%}.rbac-content-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rbac-table-wrapper{flex:1;overflow-y:auto;overflow-x:auto;position:relative;min-height:0}.rbac-table{min-width:100%;border-collapse:collapse;font-size:.9rem}.rbac-table thead{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;overflow:visible}.rbac-table th{padding:12px 15px;text-align:center;font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px;white-space:nowrap;position:relative;overflow:visible;vertical-align:middle}.rbac-table th span{display:inline-block;vertical-align:middle}.rbac-table th .rbac-table-filter{display:inline-block;vertical-align:middle;margin-left:8px}.rbac-table .rbac-actions-column{width:80px;text-align:center}.rbac-table td{padding:10px 15px;border-bottom:1px solid #f0f0f0;vertical-align:middle;text-align:left;white-space:nowrap}.rbac-text-cell{white-space:nowrap}.rbac-permission-name-code-cell{min-width:200px;max-width:350px}.rbac-permission-name-code-cell>div{display:flex;flex-direction:column;gap:4px}.rbac-permission-name{font-weight:600;font-size:.9rem;color:#2c3e50;display:block}.rbac-permission-code{font-size:.8rem;color:#6c757d;padding:2px 6px;display:inline-block;font-family:Courier New,monospace}.rbac-code-cell{white-space:nowrap}.rbac-code-cell code{white-space:nowrap;display:inline-block;vertical-align:bottom}.rbac-description-cell{max-width:400px;min-width:200px;white-space:normal;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;text-align:left;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.rbac-description-cell>*{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.8em}.rbac-date-cell{white-space:nowrap;font-size:.85rem}.rbac-table td:first-child{position:relative;overflow:visible}.rbac-actions-row{display:flex;align-items:center;gap:8px;justify-content:center}.rbac-table tbody tr{transition:background-color .2s ease}.rbac-table tbody tr:hover{background-color:#f8f9ff}.rbac-table-row-hover:hover{background-color:#e8f4f8!important;cursor:pointer;box-shadow:0 2px 8px #667eea26}.rbac-table tbody tr:last-child td{border-bottom:none}.rbac-btn{padding:10px 20px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:.9rem}.rbac-btn-primary{background:#667eea;color:#fff}.rbac-btn-primary:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.rbac-btn-success{background:#28a745;color:#fff}.rbac-btn-success:hover{background:#218838;transform:translateY(-2px)}.rbac-btn-warning{background:#ffc107;color:#333}.rbac-btn-warning:hover{background:#e0a800;transform:translateY(-2px)}.rbac-btn-danger{background:#dc3545;color:#fff}.rbac-btn-danger:hover{background:#c82333;transform:translateY(-2px)}.rbac-btn-secondary{background:#6c757d;color:#fff}.rbac-btn-secondary:hover{background:#5a6268;transform:translateY(-2px)}.rbac-btn-sm{padding:6px 12px;font-size:.8rem}@media (max-width: 1024px){.rbac-management-page{height:auto;min-height:calc(100vh - 70px);overflow:visible;flex-direction:column}.rbac-management-page>.rbac-sidebar{width:100%;height:auto;border-right:none;border-bottom:2px solid rgba(255,255,255,.2);padding:10px 0;flex-shrink:0;overflow-x:auto;overflow-y:hidden}.rbac-tabs{flex-direction:row;flex-wrap:nowrap;gap:6px;padding:0 12px;width:-moz-max-content;width:max-content}.rbac-tab-btn{flex-direction:row;white-space:nowrap;padding:8px 14px;gap:6px;min-width:-moz-max-content;min-width:max-content}.rbac-tab-btn:hover{transform:translateY(-2px)}.tab-icon{font-size:1.1rem}.tab-label{font-size:.8rem}.rbac-main-content{flex:unset;height:auto;min-height:calc(100vh - 136px);overflow:visible}.rbac-header{grid-template-columns:1fr auto;grid-template-rows:auto auto;padding:10px 16px;gap:10px}.rbac-header-content{grid-column:1;grid-row:1}.rbac-header-actions{grid-column:2;grid-row:1;justify-self:end}.rbac-header>*:nth-child(2){grid-column:1 / -1;grid-row:2}.rbac-content,.rbac-content-wrapper,.rbac-table-wrapper{overflow:visible;height:auto}.rbac-table-wrapper{overflow-x:auto;overflow-y:visible}}@media (max-width: 768px){.rbac-management-page{height:auto;min-height:calc(100vh - 70px);overflow:visible}.rbac-management-page>.rbac-sidebar{padding:8px 0}.rbac-tabs{gap:5px;padding:0 8px}.rbac-tab-btn{padding:7px 11px;gap:5px;border-radius:6px}.tab-icon{font-size:1rem}.tab-label{font-size:.75rem}.rbac-header{display:flex;flex-direction:column;align-items:stretch;gap:8px;padding:10px 12px}.rbac-header-content{order:1}.rbac-header h1{font-size:1.3rem}.rbac-description{font-size:.85rem}.rbac-header>*:nth-child(2){order:2}.rbac-header-actions{order:3;justify-self:unset;justify-content:flex-end;flex-wrap:wrap;gap:8px}.rbac-table{font-size:.8rem}.rbac-table th,.rbac-table td{padding:8px 10px}.rbac-split-layout,.rbac-tab-container.rbac-split-layout{flex-direction:column;height:auto;min-height:unset;overflow:visible}.rbac-split-layout>.rbac-sidebar-groups{width:100%;min-width:100%;max-height:none;height:auto;border-right:none;border-bottom:2px solid #e0e0e0;overflow:visible}.rbac-split-layout .rbac-sidebar-list{display:flex;flex-wrap:wrap;gap:6px;padding:8px;overflow-y:auto;max-height:170px;overflow-x:visible}.rbac-split-layout .rbac-sidebar-item{flex:0 0 auto;padding:6px 10px;margin-bottom:0;border-radius:20px}.rbac-split-layout .rbac-sidebar-item-title{margin-bottom:0;gap:6px;flex-wrap:nowrap}.rbac-split-layout .rbac-sidebar-item-subtitle{display:none}.rbac-split-layout>.rbac-content-right{flex:unset;height:auto;overflow:visible}.rbac-split-layout .rbac-table-card-list{overflow-y:visible;flex:unset}}.rbac-table-card-list{display:none}@media (max-width: 768px){.rbac-table-wrapper{display:none}.rbac-table-card-list{display:flex;flex-direction:column;gap:10px;padding:10px;overflow-y:auto;flex:1}.rbac-table-card{background:#ffffff;border-radius:10px;border:1px solid #e0e0e0;box-shadow:0 1px 4px #00000012;overflow:hidden;cursor:pointer;transition:box-shadow .2s ease,border-color .2s ease}.rbac-table-card:hover{box-shadow:0 3px 10px #667eea26;border-color:#a5b4fc}.rbac-table-card.rbac-card-selected{border-color:#667eea;background:#f0f4ff;box-shadow:0 0 0 2px #667eea4d}.rbac-table-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:10px 14px 8px;background:linear-gradient(135deg,#f8f9ff 0%,#f0f4ff 100%);border-bottom:1px solid #e8eeff}.rbac-table-card-title{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.rbac-table-card-title strong{font-size:.95rem;color:#333;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rbac-table-card-title code{font-size:.78rem;color:#667eea;background:#e8eeff;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;width:-moz-fit-content;width:fit-content;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbac-table-card-badges{display:flex;flex-wrap:wrap;gap:4px;flex-shrink:0;justify-content:flex-end;max-width:50%}.rbac-table-card-body{padding:8px 14px;display:flex;flex-direction:column;gap:5px}.rbac-table-card-row{display:flex;align-items:baseline;gap:6px;font-size:.82rem;line-height:1.4}.rbac-table-card-label{color:#888;font-size:.76rem;white-space:nowrap;flex-shrink:0;min-width:70px}.rbac-table-card-value{color:#444;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.rbac-table-card-value.rbac-card-value-wrap{white-space:normal;word-break:break-word}.rbac-table-card-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-top:1px solid #f0f0f0;background:#fafafa;gap:8px}.rbac-table-card-actions{display:flex;align-items:center;gap:8px}.rbac-table-card .rbac-badge{font-size:.72rem;padding:2px 7px;border-radius:10px}}@media (max-width: 480px){.rbac-tabs{gap:4px;padding:0 6px}.rbac-tab-btn{padding:6px 9px;gap:4px}.tab-icon{font-size:.95rem}.tab-label{font-size:.7rem}.rbac-header{padding:8px 10px;gap:7px}.rbac-header h1{font-size:1.1rem}.rbac-description{font-size:.8rem;display:none}.rbac-table th,.rbac-table td{padding:7px 8px;font-size:.78rem}.rbac-sidebar-item{flex:1 1 100%}.rbac-empty,.rbac-loading{min-height:200px;padding:30px 20px;margin:10px}}.rbac-split-layout{display:flex;flex-direction:row;gap:0;height:100%;overflow:hidden}.rbac-split-layout>.rbac-sidebar-groups{width:280px;min-width:280px;background:#f8f9fa;border-right:2px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden}.rbac-sidebar-groups .rbac-sidebar-header{padding:10px 16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;display:flex;justify-content:space-between;align-items:center}.rbac-sidebar-header h3{margin:0;font-size:1.1rem;font-weight:600}.rbac-sidebar-item-reset{padding:6px 12px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);border-radius:6px;color:#fff;font-size:.85rem;cursor:pointer;transition:all .2s ease}.rbac-sidebar-item-reset:hover{background:rgba(255,255,255,.3);transform:translateY(-1px)}.rbac-sidebar-item-reset.active{background:white;color:#667eea;font-weight:600}.rbac-sidebar-list{flex:1;overflow-y:auto;padding:8px}.rbac-sidebar-empty{padding:40px 20px;text-align:center;color:#999;font-style:italic}.rbac-sidebar-item{padding:12px;margin-bottom:6px;background:white;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease}.rbac-sidebar-item:hover{border-color:#667eea;background:#f8f9ff;transform:translate(4px)}.rbac-sidebar-item.active{border-color:#667eea;background:linear-gradient(135deg,#f0f4ff 0%,#e8eeff 100%);box-shadow:0 2px 8px #667eea33}.rbac-sidebar-item-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.rbac-sidebar-item-title strong{font-size:.95rem;color:#333}.rbac-sidebar-item.active .rbac-sidebar-item-title strong{color:#667eea}.rbac-sidebar-item-badge{background:#667eea;color:#fff;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.rbac-sidebar-item.active .rbac-sidebar-item-badge{background:#764ba2}.rbac-sidebar-item-subtitle{font-size:.85rem;color:#666}.rbac-sidebar-item-subtitle code{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:.8rem}.rbac-sidebar-item.active .rbac-sidebar-item-subtitle code{background:#d0d8ff;color:#667eea}.rbac-split-layout>.rbac-content-right{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.rbac-content-right .rbac-content-header-info{padding:12px 20px;background:#f0f4ff;border-bottom:2px solid #667eea;color:#333;font-size:.95rem}.rbac-content-header-info strong{color:#667eea;font-weight:600}@media (max-width: 1024px){.rbac-split-layout>.rbac-sidebar-groups{width:220px;min-width:220px}}.rbac-empty,.rbac-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:60px 40px;text-align:center;color:#667eea;font-size:16px;font-weight:500;background:white;border-radius:12px;margin:20px;box-shadow:0 2px 8px #0000000d}.rbac-empty:before{content:"📋";font-size:64px;margin-bottom:20px;opacity:.3;display:block}.rbac-loading:before{content:"⏳";font-size:64px;margin-bottom:20px;animation:rbac-pulse 1.5s ease-in-out infinite;display:block}@keyframes rbac-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.rbac-table .rbac-sortable-header{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background-color .2s ease}.rbac-table .rbac-sortable-header:hover{background-color:#ffffff1a}.rbac-table .rbac-sortable-header:active{background-color:#fff3}.rbac-table .rbac-header-content{display:inline-flex;align-items:center;justify-content:center;gap:4px;flex-wrap:nowrap;white-space:nowrap;vertical-align:middle}.rbac-table .rbac-sort-icon{display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;color:#ffffffe6;min-width:12px;flex-shrink:0}.rbac-pagination{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:5px 20px;border-top:2px solid #e0e0e0;background:white;flex-shrink:0}.rbac-pagination-controls{display:flex;align-items:center;gap:8px}.rbac-pagination button{padding:8px 14px;border:1px solid #667eea;background:white;color:#667eea;border-radius:5px;cursor:pointer;transition:all .3s ease;font-weight:500;font-size:.9rem;min-width:40px}.rbac-pagination button:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 2px 8px #667eea4d}.rbac-pagination button:disabled{opacity:.3;cursor:not-allowed;transform:none}.rbac-pagination-info{color:#333;font-weight:600;font-size:.9rem;padding:0 10px}.rbac-pagination-range{color:#666;font-weight:400;font-size:.85rem}.rbac-pagination-selector{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#666}.rbac-pagination-selector label{font-weight:500}.rbac-pagination-selector select{padding:6px 10px;border:1px solid #d0d0d0;border-radius:5px;background:white;cursor:pointer;font-size:.9rem;transition:all .3s ease}.rbac-pagination-selector select:hover{border-color:#667eea}.rbac-pagination-selector select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.rbac-table-filter{position:relative;display:inline-block}.rbac-filter-btn{margin-left:10px;position:relative;background:transparent;border:none;border-radius:4px;padding:6px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;color:#0af80a;width:30px;height:30px}.rbac-filter-btn svg{width:16px;height:16px;transition:all .2s ease}.rbac-filter-btn:hover{background:#f0f0f0;color:#4caf50;transform:scale(1.1)}.rbac-filter-btn.active{background:#4CAF50;color:#fff}.rbac-filter-btn.active:hover{background:#45a049}.filter-active-dot{width:8px;height:8px;background:#ff9800;border-radius:50%;position:absolute;top:0;right:0;border:2px solid white;box-shadow:0 0 0 1px #0000001a}.rbac-filter-btn.active .filter-active-dot{background:#fff;border-color:#4caf50}.rbac-filter-dropdown{background:white;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:9999;min-width:280px;max-width:400px;animation:filterDropdownFadeIn .2s ease}@keyframes filterDropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rbac-filter-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #eee;background:#f9f9f9;border-radius:6px 6px 0 0}.filter-title{font-weight:600;font-size:13px;color:#333}.filter-close-btn{background:transparent;border:none;font-size:16px;cursor:pointer;color:#999;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s ease}.filter-close-btn:hover{background:#e0e0e0;color:#333}.rbac-filter-body{padding:12px;max-height:450px;overflow-y:auto;overflow-x:hidden}.rbac-filter-input,.rbac-filter-select{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;transition:all .2s ease;box-sizing:border-box}.rbac-filter-input:focus,.rbac-filter-select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.rbac-filter-select{cursor:pointer;background:white}.rbac-filter-values-list{margin-top:8px;border-top:1px solid #eee;padding-top:8px}.filter-values-items{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto;overflow-x:hidden;padding-right:4px}.filter-values-items::-webkit-scrollbar{width:6px}.filter-values-items::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.filter-values-items::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.filter-values-items::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.filter-value-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;padding:6px 10px;font-size:12px;text-align:left;cursor:pointer;transition:all .2s ease;color:#333;white-space:normal;word-wrap:break-word;width:100%;max-width:100%;line-height:1.4;display:flex;justify-content:space-between;align-items:center;gap:8px}.filter-value-text{flex:1;text-align:left;word-break:break-word}.filter-value-count{flex-shrink:0;background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;min-width:24px;text-align:center}.filter-value-item:hover{background:#4CAF50;color:#fff;border-color:#4caf50;transform:translate(2px)}.filter-value-item:hover .filter-value-count{background:rgba(255,255,255,.3);color:#fff}.rbac-filter-footer{display:flex;gap:8px;padding:10px 12px;border-top:1px solid #eee;background:#f9f9f9;border-radius:0 0 6px 6px}.rbac-filter-footer .rbac-btn{flex:1}.rbac-btn-sm{padding:6px 12px;font-size:12px}@media (max-width: 768px){.rbac-filter-dropdown{min-width:240px;max-width:300px;right:auto;left:0}.filter-values-items{max-height:220px}}.rbac-filter-dropdown *{box-sizing:border-box}.rbac-action-menu{background:white;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 6px 16px #00000026,0 3px 6px #0000001a;z-index:99999;min-width:180px;width:-moz-max-content;width:max-content;overflow:hidden}.rbac-action-dropdown{position:relative;display:inline-block;z-index:10}.rbac-action-btn{background:#ffffff;border:1px solid #e0e0e0;border-radius:50%;padding:0;cursor:pointer;font-size:18px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;width:34px;height:34px;box-shadow:0 1px 3px #00000014}.rbac-action-btn:hover{background:#f5f5f5;border-color:#bdbdbd;box-shadow:0 2px 6px #0000001f;transform:rotate(90deg) scale(1.05)}.rbac-action-btn:active{transform:rotate(90deg) scale(.95);box-shadow:0 1px 2px #0000001a}@keyframes rbac-action-menu-appear{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.rbac-action-item{width:100%;padding:10px 14px;border:none;background:white;text-align:left;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;font-size:13px;color:#333;border-bottom:1px solid #f0f0f0}.rbac-action-item:last-child{border-bottom:none}.rbac-action-item .action-icon{font-size:16px;display:flex;align-items:center;justify-content:center;min-width:20px}.rbac-action-item .action-label{flex:1;white-space:nowrap}.rbac-action-item.primary:hover{background:#e3f2fd;color:#1976d2}.rbac-action-item.warning:hover{background:#fff3e0;color:#f57c00}.rbac-action-item.danger:hover{background:#ffebee;color:#d32f2f}.rbac-action-item.success:hover{background:#e8f5e9;color:#388e3c}.rbac-action-item.info:hover{background:#e0f2f1;color:#00796b}.rbac-action-item.disabled{opacity:.5;cursor:not-allowed;background:#f9f9f9}.rbac-action-item.disabled:hover{background:#f9f9f9;color:#999}@media (max-width: 768px){.rbac-action-menu{min-width:160px;right:auto;left:0}.rbac-action-item{padding:8px 12px;font-size:12px}.rbac-action-item .action-icon{font-size:14px}}.rbac-slide-panel-overlay{display:none}.rbac-slide-panel{position:absolute;top:1px;right:0;bottom:0;max-height:100%;width:500px;background:white;box-shadow:-4px 0 20px #00000026;z-index:100;display:flex;flex-direction:column;overflow:hidden;visibility:hidden;opacity:0}.rbac-slide-panel.rbac-slide-panel-wide{width:calc(100% - 280px);max-width:1400px}.rbac-slide-panel.open{visibility:visible;opacity:1}.rbac-slide-panel-header{display:flex;align-items:center;justify-content:space-between;padding:2px 24px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-bottom:1px solid rgba(255,255,255,.2);flex-shrink:0}.rbac-cpn-slide-panel-header-content{display:flex;align-items:center;gap:12px;flex:1}.rbac-cpn-slide-panel-mode-icon{font-size:28px;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:rgba(255,255,255,.2);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rbac-cpn-slide-panel-header-text{display:flex;flex-direction:column;gap:2px}.rbac-cpn-slide-panel-title{margin:0;font-size:18px;font-weight:600;letter-spacing:-.3px}.rbac-cpn-slide-panel-mode-label{font-size:12px;opacity:.9;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.rbac-cpn-slide-panel-header-actions{display:flex;align-items:center;gap:8px}.rbac-cpn-slide-panel-close-btn{background:rgba(255,255,255,.2);border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.rbac-cpn-slide-panel-close-btn:hover{background:rgba(255,255,255,.3);transform:rotate(90deg)}.rbac-cpn-slide-panel-close-btn:active{transform:rotate(90deg) scale(.9)}.rbac-slide-panel-body{flex:1;overflow-y:auto;padding:24px;background:#f8f9fa;display:flex;flex-direction:column}.rbac-slide-panel-body::-webkit-scrollbar{width:8px}.rbac-slide-panel-body::-webkit-scrollbar-track{background:#f1f1f1}.rbac-slide-panel-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.rbac-slide-panel-body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.rbac-slide-panel-footer{display:flex;gap:12px;padding:9px 24px;background:white;border-top:3px solid #e0e0e0;flex-shrink:0;box-shadow:0 -2px 10px #0000000d;position:sticky;bottom:0;z-index:10}.rbac-slide-panel-footer .rbac-btn{flex:1;padding:10px 20px;font-size:14px;font-weight:600;border-radius:8px;transition:all .2s ease}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group{margin-bottom:20px}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group label{display:block;font-weight:600;font-size:13px;color:#333;margin-bottom:8px;letter-spacing:.3px}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group label .rbac-cpn-slide-panel-required{color:#e74c3c;margin-left:4px}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group input,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group select,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s ease;background:white}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group input:focus,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group select:focus,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group select[multiple]{min-height:200px;padding:8px}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group select[multiple] option{padding:8px 12px;margin:2px 0;border-radius:4px;cursor:pointer;transition:all .15s ease}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group select[multiple] option:hover{background:#f0f4ff}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group select[multiple] option:checked{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;font-weight:500}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-form-help{font-size:12px;color:#7f8c8d;margin-top:6px;display:block}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-form-error{font-size:12px;color:#e74c3c;margin-top:6px;display:block}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-checkbox-group,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-radio-group{display:flex;flex-direction:column;gap:10px}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-checkbox-item,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-radio-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;cursor:pointer;transition:background .2s ease}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-checkbox-item:hover,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-radio-item:hover{background:#f0f0f0}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-checkbox-item input,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-radio-item input{width:auto;margin:0}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-checkbox-item label,.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group .rbac-cpn-slide-panel-radio-item label{margin:0;cursor:pointer;font-weight:400}.rbac-cpn-slide-panel-checkbox-list{overflow-y:auto;border:1px solid #ddd;border-radius:6px;padding:8px;background:#fafafa}.rbac-cpn-slide-panel-checkbox-list::-webkit-scrollbar{width:8px}.rbac-cpn-slide-panel-checkbox-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.rbac-cpn-slide-panel-checkbox-list::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.rbac-cpn-slide-panel-checkbox-list::-webkit-scrollbar-thumb:hover{background:#5568d3}.rbac-cpn-slide-panel-checkbox-item{display:flex;align-items:center;padding:6px 8px;margin-bottom:4px;border-radius:4px;transition:background .15s ease;cursor:pointer}.rbac-cpn-slide-panel-checkbox-item:hover{background:#f0f0f0}.rbac-cpn-slide-panel-checkbox-item input[type=checkbox]{margin:0 10px 0 0;cursor:pointer;width:18px;height:18px;flex-shrink:0}.rbac-cpn-slide-panel-checkbox-item label{margin:0;cursor:pointer;flex:1;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1.4}.rbac-slide-panel-body .rbac-cpn-slide-panel-divider{height:1px;background:#e0e0e0;margin:24px 0}.rbac-slide-panel-body .rbac-cpn-slide-panel-section-heading{font-size:14px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #667eea}.rbac-slide-panel-body .rbac-cpn-slide-panel-info-box{background:#e3f2fd;border-left:4px solid #2196f3;padding:12px 16px;border-radius:6px;margin-bottom:20px}.rbac-slide-panel-body .rbac-cpn-slide-panel-info-box p{margin:0;font-size:13px;color:#1976d2;line-height:1.5}.rbac-slide-panel-body .rbac-cpn-slide-panel-warning-box{background:#fff3e0;border-left:4px solid #ff9800;padding:12px 16px;border-radius:6px;margin-bottom:20px}.rbac-slide-panel-body .rbac-cpn-slide-panel-warning-box p{margin:0;font-size:13px;color:#f57c00;line-height:1.5}.rbac-cpn-slide-panel-two-column-layout{display:grid;grid-template-columns:400px 1fr;gap:12px;flex:1;min-height:0;overflow:hidden}.rbac-cpn-slide-panel-left-column{display:flex;flex-direction:column;gap:16px;padding:24px;border-right:1px solid #e5e7eb;min-height:0;overflow-y:auto}.rbac-cpn-slide-panel-right-column{display:flex;flex-direction:column;padding:12px 0;gap:0;min-height:0;overflow:hidden}.rbac-cpn-slide-panel-right-column>.rbac-cpn-slide-panel-section-heading{flex-shrink:0;margin-bottom:12px}.rbac-cpn-slide-panel-right-column>.rbac-cpn-slide-panel-checkbox-item:first-of-type{flex-shrink:0;margin-bottom:8px}.rbac-cpn-slide-panel-right-column>.rbac-cpn-slide-panel-checkbox-list{flex:1;overflow-y:auto;overflow-x:hidden}.rbac-cpn-slide-panel-right-column>.rbac-cpn-slide-panel-form-help{flex-shrink:0;margin-top:8px}@media (max-width: 1200px){.rbac-cpn-slide-panel-two-column-layout{grid-template-columns:1fr}.rbac-cpn-slide-panel-left-column{border-right:none;padding-right:0;border-bottom:1px solid #e5e7eb;padding-bottom:16px}}.rbac-editable-select-wrapper{display:flex;flex-direction:column;gap:8px}.rbac-editable-select-wrapper .rbac-editable-select{width:100%}.rbac-editable-select-wrapper .rbac-custom-input{width:100%;padding:10px 12px;border:2px solid #667eea;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s ease;background:#f0f4ff;animation:slideDown .2s ease}.rbac-editable-select-wrapper .rbac-custom-input:focus{outline:none;border-color:#764ba2;box-shadow:0 0 0 3px #667eea33;background:white}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group input[list]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23667eea' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;padding-right:36px;cursor:pointer;position:relative}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group input[list]:hover{border-color:#667eea;background-color:#f8f9ff}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group input[list]:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23667eea' d='M6 3L1 8h10z'/%3E%3C/svg%3E")}.rbac-slide-panel-body .rbac-cpn-slide-panel-form-group input[list]:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.7;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23999' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}@media (max-width: 768px){.rbac-slide-panel{width:100%!important;max-width:100%}.rbac-slide-panel-header{padding:16px 20px}.rbac-cpn-slide-panel-title{font-size:16px}.rbac-slide-panel-body{padding:20px}.rbac-slide-panel-footer{padding:12px 20px}}.toggle-switch{position:relative;display:inline-block;vertical-align:middle;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;transition:background-color .3s ease;border-radius:34px}.toggle-slider:before{position:absolute;content:"";background-color:#fff;transition:transform .3s ease;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch-sm{width:32px;height:18px;margin-left:6px}.toggle-switch-sm .toggle-slider:before{height:14px;width:14px;left:2px;bottom:2px}.toggle-switch-sm input:checked+.toggle-slider:before{transform:translate(14px)}.toggle-switch-md{width:44px;height:24px;margin-left:8px}.toggle-switch-md .toggle-slider:before{height:18px;width:18px;left:3px;bottom:3px}.toggle-switch-md input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch-lg{width:56px;height:30px;margin-left:10px}.toggle-switch-lg .toggle-slider:before{height:24px;width:24px;left:3px;bottom:3px}.toggle-switch-lg input:checked+.toggle-slider:before{transform:translate(26px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.toggle-switch input:disabled+.toggle-slider:before{cursor:not-allowed}.toggle-switch:hover .toggle-slider:not(:has(input:disabled)){filter:brightness(1.05)}.toggle-switch:active .toggle-slider:not(:has(input:disabled)):before{width:calc(100% - 6px)}.rbac-cpn-bulk-action-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.rbac-cpn-bulk-selection-info{font-size:14px;font-weight:600;color:#667eea;background:rgba(102,126,234,.1);padding:6px 12px;border-radius:6px;white-space:nowrap}.rbac-cpn-bulk-filter-info{font-size:14px;font-weight:600;color:#ff9800;background:rgba(255,152,0,.1);padding:6px 12px;border-radius:6px;white-space:nowrap}.rbac-cpn-bulk-action-bar{animation:bulkActionBarFadeIn .2s ease-out}@keyframes bulkActionBarFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.rbac-cpn-bulk-action-bar{flex-direction:column;align-items:flex-start}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal-content{background:white;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;padding:30px;animation:slideUp .3s ease-out;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal-icon{display:flex;align-items:center;justify-content:center;margin-bottom:20px}.confirm-modal-warning .confirm-modal-icon{color:#f39c12}.confirm-modal-danger .confirm-modal-icon{color:#e74c3c}.confirm-modal-success .confirm-modal-icon{color:#27ae60}.confirm-modal-info .confirm-modal-icon{color:#3498db}.confirm-modal-body{text-align:center;margin-bottom:25px}.confirm-modal-title{font-size:20px;font-weight:600;color:#2c3e50;margin:0 0 10px}.confirm-modal-message{font-size:15px;color:#7f8c8d;line-height:1.5;margin:0;white-space:pre-line}.confirm-modal-footer{display:flex;gap:12px;justify-content:center}.confirm-modal-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px}.confirm-modal-btn:focus{outline:none;box-shadow:0 0 0 3px #3498db33}.confirm-modal-btn-cancel{background:#ecf0f1;color:#7f8c8d}.confirm-modal-btn-cancel:hover{background:#bdc3c7;color:#2c3e50}.confirm-modal-btn-confirm{color:#fff}.confirm-modal-btn-warning{background:#f39c12}.confirm-modal-btn-warning:hover{background:#e67e22;transform:translateY(-1px);box-shadow:0 4px 12px #f39c124d}.confirm-modal-btn-danger{background:#e74c3c}.confirm-modal-btn-danger:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c4d}.confirm-modal-btn-success{background:#27ae60}.confirm-modal-btn-success:hover{background:#229954;transform:translateY(-1px);box-shadow:0 4px 12px #27ae604d}.confirm-modal-btn-info{background:#3498db}.confirm-modal-btn-info:hover{background:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}@media (max-width: 768px){.confirm-modal-content{padding:24px;max-width:90%}.confirm-modal-title{font-size:18px}.confirm-modal-message{font-size:14px}.confirm-modal-footer{flex-direction:column-reverse}.confirm-modal-btn{width:100%}}.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px 16px;background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;pointer-events:auto;animation:slideInRight .3s ease-out;border-left:4px solid;min-width:300px;position:relative;overflow:hidden}.toast.toast-closing{animation:slideOutRight .3s ease-out forwards}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.toast-success{border-left-color:#27ae60}.toast-success .toast-icon{color:#27ae60}.toast-error{border-left-color:#e74c3c}.toast-error .toast-icon{color:#e74c3c}.toast-warning{border-left-color:#f39c12}.toast-warning .toast-icon{color:#f39c12}.toast-info{border-left-color:#3498db}.toast-info .toast-icon{color:#3498db}.toast-icon{display:flex;align-items:center;flex-shrink:0}.toast-message{flex:1;font-size:14px;color:#2c3e50;line-height:1.4}.toast-close{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#7f8c8d;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;flex-shrink:0}.toast-close:hover{background:#ecf0f1;color:#2c3e50}.toast-progress-bar{position:absolute;bottom:0;left:0;right:0;height:4px;background:rgba(0,0,0,.05);overflow:hidden}.toast-progress-fill{height:100%;background:currentColor;transition:width 50ms linear;opacity:.7}.toast-success .toast-progress-fill{background:#27ae60}.toast-error .toast-progress-fill{background:#e74c3c}.toast-warning .toast-progress-fill{background:#f39c12}.toast-info .toast-progress-fill{background:#3498db}@media (max-width: 768px){.toast-container{top:70px;right:10px;left:10px;max-width:none}.toast{min-width:auto;padding:12px 14px}.toast-message{font-size:13px}}.rbac-tab-container{position:relative;height:100%;overflow:hidden}.rbac-cpn-user-permissions-tab{display:flex;height:100%;overflow:hidden}.rbac-cpn-up-sidebar{width:280px;flex-shrink:0;background:#fff;overflow:hidden;display:flex;flex-direction:column}.rbac-cpn-up-sidebar-header{padding:13px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;display:flex;justify-content:space-between;align-items:center}.rbac-cpn-up-sidebar-header h3{margin:0;font-size:.9rem;font-weight:600}.rbac-cpn-up-sidebar-header .rbac-btn{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3);padding:.25rem .75rem;font-size:.75rem}.rbac-cpn-up-sidebar-header .rbac-btn:hover{background:rgba(255,255,255,.3)}.rbac-cpn-up-sidebar-header .rbac-btn.rbac-btn-primary{background:white;color:#667eea;font-weight:600}.rbac-cpn-up-sidebar-list{flex:1;overflow-y:auto;padding:.5rem}.rbac-cpn-up-user-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem;margin-bottom:.5rem;background:#f8f9fa;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;text-align:left}.rbac-cpn-up-user-item:hover{background:#e9ecef;transform:translate(2px)}.rbac-cpn-up-user-item.active{background:linear-gradient(135deg,#667eea15 0%,#764ba215 100%);border-color:#667eea}.rbac-cpn-up-user-info{flex:1;min-width:0}.rbac-cpn-up-user-name{font-weight:600;font-size:.85rem;color:#2c3e50;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rbac-cpn-up-user-email{font-size:.7rem;color:#6c757d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rbac-cpn-up-user-count{display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;background:#667eea;color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;margin-left:.5rem}.rbac-cpn-up-user-item.active .rbac-cpn-up-user-count{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 2px 8px #667eea4d}.rbac-cpn-up-main{position:relative;flex:1;min-width:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.rbac-cpn-up-main .rbac-table-container{flex:1;overflow-x:auto;overflow-y:auto;position:relative;min-height:0}.rbac-cpn-up-main .rbac-table-container::-webkit-scrollbar{height:8px;width:8px}.rbac-cpn-up-main .rbac-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.rbac-cpn-up-main .rbac-table-container::-webkit-scrollbar-thumb{background:#cbd3da;border-radius:10px}.rbac-cpn-up-main .rbac-table-container::-webkit-scrollbar-thumb:hover{background:#667eea}.rbac-cpn-up-main .rbac-table{min-width:100%;width:-moz-max-content;width:max-content;border-collapse:collapse;font-size:.9rem}.rbac-cpn-up-main .rbac-table thead{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;overflow:visible}.rbac-cpn-up-panel-layout{display:grid;grid-template-columns:520px 1fr;gap:5px;height:100%;overflow:hidden;padding:0}.rbac-cpn-up-panel-left{display:flex;flex-direction:column;gap:5px;overflow-y:auto}.rbac-cpn-up-panel-left::-webkit-scrollbar{width:6px}.rbac-cpn-up-panel-left::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.rbac-cpn-up-panel-left::-webkit-scrollbar-thumb{background:#cbd3da;border-radius:10px}.rbac-cpn-up-panel-left::-webkit-scrollbar-thumb:hover{background:#667eea}.rbac-cpn-up-panel-right{border-left:3px solid #e9ecef;overflow-y:auto;padding:5px}.rbac-cpn-up-panel-right::-webkit-scrollbar{width:8px}.rbac-cpn-up-panel-right::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.rbac-cpn-up-panel-right::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px}.rbac-cpn-up-panel-right::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2 0%,#667eea 100%)}.rbac-cpn-up-permissions-header{display:flex;justify-content:space-between;align-items:center;padding:10px}.rbac-cpn-up-permissions-header .rbac-label{margin:0}.rbac-cpn-up-permissions-counter{margin:0;font-size:.9rem;font-weight:600;color:#667eea}.rbac-cpn-up-permissions-list{display:flex;flex-direction:column;gap:5px;padding-right:.5rem}.rbac-cpn-up-permission-item{display:grid;grid-template-columns:22px 180px 1fr 200px 80px 50px;align-items:center;gap:1.25rem;padding:1rem 1.5rem;background:white;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 1px 3px #0000000d}.rbac-cpn-up-permission-item:hover{background:#f8f9fa;border-color:#cbd3da;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.rbac-cpn-up-permission-item.checked{background:linear-gradient(135deg,#667eea08 0%,#764ba208 100%);border-color:#667eea;box-shadow:0 4px 16px #667eea33;cursor:pointer}.rbac-cpn-up-permission-item.checked:hover{background:linear-gradient(135deg,#667eea12 0%,#764ba212 100%);transform:translateY(-3px);box-shadow:0 6px 20px #667eea40}.rbac-cpn-up-permission-item:not(.checked){cursor:default}.rbac-cpn-up-permission-item:not(.checked):hover{cursor:default}.rbac-cpn-up-permission-item.existing{background:linear-gradient(135deg,#fff9e6 0%,#fffbf0 100%);border-color:#ffc107;border-left-width:4px}.rbac-cpn-up-permission-item.existing.checked{background:linear-gradient(135deg,#fff3cd 0%,#667eea08 100%);border-color:#667eea;border-left-width:4px;border-left-color:#ffc107}.rbac-cpn-up-permission-item input[type=checkbox]{width:22px;height:22px;cursor:pointer;accent-color:#667eea;transition:transform .2s ease}.rbac-cpn-up-permission-item input[type=checkbox]:hover{transform:scale(1.1)}.rbac-cpn-up-permission-item input[type=checkbox]:checked{transform:scale(1.15)}.rbac-cpn-up-permission-item .rbac-badge{white-space:nowrap;font-size:14px;padding:.35rem .75rem;border-radius:6px;justify-self:start}.rbac-cpn-up-permission-name{font-size:.9rem;color:#2c3e50;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;justify-self:start}.rbac-cpn-up-permission-code{font-weight:700;font-size:.85rem;color:#6c757d;font-family:Courier New,monospace;letter-spacing:-.3px;white-space:nowrap;justify-self:start}.rbac-cpn-up-permission-item.checked .rbac-cpn-up-permission-code{color:#667eea}.rbac-cpn-up-existing-badge{background:linear-gradient(135deg,#ffc107 0%,#ff9800 100%);color:#fff;padding:.35rem .85rem;border-radius:16px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #ffc1074d;white-space:nowrap;justify-self:center}.rbac-cpn-up-selected-badge{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:.35rem .85rem;border-radius:16px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #667eea4d;white-space:nowrap;justify-self:center}.rbac-cpn-up-permission-item.selected{background:linear-gradient(135deg,rgba(102,126,234,.1) 0%,rgba(118,75,162,.1) 100%);border-color:#667eea!important;box-shadow:0 4px 12px #667eea33}.rbac-cpn-up-permission-item.selected .rbac-cpn-up-permission-name{color:#667eea;font-weight:600}.rbac-cpn-up-permission-item.selected .rbac-cpn-up-permission-code{color:#764ba2;font-weight:600}.rbac-cpn-up-panel-left .rbac-form-group{background:#f8f9fa;padding:10px;border-radius:10px;border:1px solid #e9ecef;transition:all .2s ease}.rbac-cpn-up-panel-left .rbac-form-group:focus-within{background:white;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.rbac-cpn-up-panel-left .rbac-label{font-weight:600;color:#2c3e50;font-size:.9rem;margin-bottom:.75rem;display:block}.rbac-cpn-up-panel-left .rbac-label.required:after{content:" *";color:#dc3545;font-weight:700}.rbac-cpn-up-panel-left .rbac-select,.rbac-cpn-up-panel-left .rbac-input,.rbac-cpn-up-panel-left .rbac-textarea{background:white;border:2px solid #dee2e6;border-radius:8px;padding:.85rem;font-size:.9rem;transition:all .2s ease;width:100%}.rbac-cpn-up-panel-left .rbac-select:focus,.rbac-cpn-up-panel-left .rbac-input:focus,.rbac-cpn-up-panel-left .rbac-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.rbac-cpn-up-panel-left .rbac-textarea{resize:vertical;min-height:90px;font-family:inherit}.rbac-cpn-up-panel-left .rbac-toggle-group{display:flex;gap:1rem;margin-top:.75rem}.rbac-cpn-up-panel-left .rbac-radio-label{flex:1;display:flex;align-items:center;gap:.75rem;padding:5px 15px;background:white;border:2px solid #dee2e6;border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.rbac-cpn-up-panel-left .rbac-radio-label:hover{border-color:#cbd3da;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.rbac-cpn-up-panel-left .rbac-radio-label:has(input:checked){background:linear-gradient(135deg,#667eea08 0%,#764ba208 100%);border-color:#667eea;box-shadow:0 4px 16px #667eea26}.rbac-cpn-up-panel-left .rbac-radio-label input[type=radio]{width:20px;height:20px;accent-color:#667eea;cursor:pointer}.rbac-cpn-up-panel-left .rbac-badge{padding:.5rem 1rem;font-size:.85rem;font-weight:600;border-radius:8px;transition:all .2s ease}.rbac-cpn-up-panel-left .rbac-radio-label:has(input:checked) .rbac-badge-success{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);box-shadow:0 2px 8px #28a7454d}.rbac-cpn-up-panel-left .rbac-radio-label:has(input:checked) .rbac-badge-danger{background:linear-gradient(135deg,#dc3545 0%,#c82333 100%);box-shadow:0 2px 8px #dc35454d}.rbac-cpn-up-panel-left .rbac-info-box{background:linear-gradient(135deg,#e7f3ff 0%,#f0f7ff 100%);border:2px solid #b8daff;border-left-width:4px;border-left-color:#007bff;padding:1.25rem;border-radius:10px;box-shadow:0 2px 8px #007bff1a}.rbac-cpn-up-panel-left .rbac-info-box p{margin:0;font-size:.9rem;color:#004085;font-weight:600;display:flex;align-items:center;gap:.5rem}.rbac-cpn-up-panel-left .rbac-hint{font-size:.8rem;color:#6c757d;margin-top:.5rem;display:block;line-height:1.5;font-style:italic}.rbac-cpn-up-main .rbac-table th{text-align:center;font-weight:600;padding:12px 10px;font-size:14px;color:#fff}.rbac-cpn-up-main .rbac-table th:nth-child(1):has(input[type=checkbox]){width:40px}.rbac-cpn-up-main .rbac-table th:first-child:not(:has(input)){width:120px}.rbac-cpn-up-main .rbac-table th:nth-child(2):not(:last-child){width:120px}.rbac-cpn-up-main .rbac-table th:nth-child(5),.rbac-cpn-up-main .rbac-table th:nth-child(6){width:130px}.rbac-cpn-up-main .rbac-table th:nth-child(7),.rbac-cpn-up-main .rbac-table th:nth-child(8){width:120px}.rbac-cpn-up-main .rbac-table th:nth-child(8),.rbac-cpn-up-main .rbac-table th:nth-child(9){width:120px}.rbac-cpn-up-main .rbac-table th:nth-child(9),.rbac-cpn-up-main .rbac-table th:nth-child(10){width:150px}.rbac-cpn-up-main .rbac-table th:nth-child(10),.rbac-cpn-up-main .rbac-table th:nth-child(11){width:140px}.rbac-cpn-up-main .rbac-table th:last-child{width:150px}.rbac-cpn-up-user-info-cell{display:flex;flex-direction:column;gap:.25rem}.rbac-cpn-up-username{font-weight:600;font-size:.9rem;color:#2c3e50}.rbac-cpn-up-email{font-size:.75rem;color:#6c757d;font-style:italic}.rbac-cpn-up-actions-group{display:flex;align-items:center;gap:.75rem;justify-content:center}.rbac-cpn-up-table-row{-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background-color .2s ease}.rbac-cpn-up-selectable{cursor:pointer}.rbac-cpn-up-selectable:hover{background-color:#f8f9fa}.rbac-cpn-up-selected{background-color:#e3f2fd!important}.rbac-cpn-up-selected:hover{background-color:#bbdefb!important}.rbac-cpn-up-empty-cell{text-align:center;padding:2rem}.rbac-cpn-up-grant-badge{margin-left:.5rem}@media (max-width: 1200px){.rbac-cpn-up-sidebar{width:220px}.rbac-cpn-up-user-name{font-size:.8rem}.rbac-cpn-up-user-email{font-size:.65rem}}@media (max-width: 768px){.rbac-cpn-user-permissions-tab{flex-direction:column}.rbac-cpn-up-sidebar{width:100%;max-height:200px}.rbac-cpn-up-sidebar-list{display:flex;flex-wrap:wrap;gap:.5rem}.rbac-cpn-up-user-item{flex:1 1 calc(50% - .25rem);min-width:150px}}.rbac-cpn-up-info-box{display:flex;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%);border:2px solid #2196f3;border-radius:12px;margin-bottom:1rem;animation:fadeInUp .3s ease}.rbac-cpn-up-info-icon{font-size:1.5rem;flex-shrink:0}.rbac-cpn-up-info-content{flex:1;font-size:.875rem;line-height:1.5;color:#0d47a1}.rbac-cpn-up-info-content strong{color:#01579b}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rbac-global-search{grid-column:2;justify-self:center;display:flex;align-items:center;gap:12px;width:100%;max-width:100%}.rbac-global-search-input-wrapper{position:relative;flex:1;display:flex;align-items:center}.rbac-global-search-icon{position:absolute;left:12px;font-size:16px;pointer-events:none;color:#7f8c8d;z-index:1}.rbac-global-search-input{width:100%;padding:10px 40px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s ease;background:#fff}.rbac-global-search-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.rbac-global-search-input::-moz-placeholder{color:#aaa;font-style:italic}.rbac-global-search-input::placeholder{color:#aaa;font-style:italic}.rbac-global-search-clear{position:absolute;right:10px;background:transparent;border:none;font-size:18px;color:#95a5a6;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease;z-index:1}.rbac-global-search-clear:hover{background:#ecf0f1;color:#e74c3c}.rbac-global-search-results{white-space:nowrap;font-size:13px;color:#7f8c8d;min-width:80px;text-align:right}.rbac-global-search-count{font-weight:500;color:#3498db}.rbac-global-search-loading{font-style:italic;color:#95a5a6}@media (max-width: 1200px){.rbac-global-search{min-width:250px;max-width:350px}}@media (max-width: 768px){.rbac-global-search{min-width:200px;max-width:100%}.rbac-global-search-input{font-size:13px;padding:8px 35px}.rbac-global-search-results{display:none}}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;max-width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f8fafc;color:#1a202c;line-height:1.6}.main-layout{display:flex;min-height:100vh;overflow-x:hidden;width:100%}.sidebar{width:50px;background:linear-gradient(180deg,#2d3748 0%,#1a202c 100%);color:#fff;position:fixed;top:0;left:0;height:100vh;z-index:1000;transition:all .3s ease;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;overflow:hidden}.sidebar:not(.collapsed){width:280px;box-shadow:2px 0 20px #0003}.sidebar.collapsed{width:50px}.sidebar-backdrop{position:fixed;top:0;left:50px;width:calc(100% - 50px);height:100vh;background-color:#0000004d;z-index:999;opacity:0;visibility:hidden;transition:all .3s ease;pointer-events:none}.sidebar:not(.collapsed)~.main-content .sidebar-backdrop,.sidebar-backdrop.active{opacity:1;visibility:visible;pointer-events:auto}.sidebar-header{border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;min-height:70px;padding:0}.sidebar-toggle{background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s ease;width:50px;height:70px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-toggle:hover{background-color:#ffffff1a}.logo,.sidebar-logo{display:flex;align-items:center;font-weight:700;font-size:1.125rem;min-height:70px;flex:1;padding-right:1rem}.logo-icon{width:50px;height:70px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;min-width:50px;max-width:50px;transition:none}.logo-text{font-size:1.25rem;font-weight:600;white-space:nowrap;opacity:1;max-width:200px;overflow:hidden;padding-right:1rem;transition:all .4s cubic-bezier(.4,0,.2,1);transform:translate(0)}.sidebar.collapsed .logo-text{opacity:0;max-width:0;padding-right:0;transform:translate(-10px)}.sidebar.collapsed.open .logo-text{opacity:1;max-width:200px;padding-right:1rem;transform:translate(0)}.hamburger{display:flex;flex-direction:column;gap:3px;width:18px;height:12px}.hamburger span{width:100%;height:2px;background-color:#fff;border-radius:1px;transition:all .3s ease}.sidebar.collapsed:not(.open) .hamburger span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.sidebar.collapsed:not(.open) .hamburger span:nth-child(2){opacity:0;transform:scale(0)}.sidebar.collapsed:not(.open) .hamburger span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.hamburger{width:18px;height:12px;position:relative}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;min-height:0}.sidebar-menu{flex:1;padding:1rem 0;overflow-y:auto;list-style:none;margin:0;min-height:0}.sidebar.collapsed:not(.open){overflow:hidden!important}.sidebar.collapsed:not(.open) .sidebar-nav,.sidebar.collapsed:not(.open) .sidebar-menu{overflow-y:hidden!important;overflow-x:hidden!important}.nav-list{list-style:none}.nav-item,.menu-item{margin-bottom:.25rem}.nav-link,.menu-link{display:flex;align-items:center;color:#fffc;text-decoration:none;transition:all .2s ease;position:relative;min-height:48px}.nav-link:hover,.menu-link:hover{background-color:#ffffff1a;color:#fff}.nav-link.active,.menu-link.active{background-color:#4299e1;color:#fff;border-right:3px solid #fff}.nav-link.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:#63b3ed}.nav-icon,.menu-icon{width:50px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;transition:none;min-width:50px;max-width:50px}.nav-label,.menu-label{font-weight:500;white-space:nowrap;padding:.875rem 1rem .875rem 0;opacity:1;max-width:200px;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);transform:translate(0)}.sidebar.collapsed .nav-label,.sidebar.collapsed .menu-label{opacity:0;max-width:0;padding-left:0;padding-right:0;transform:translate(-10px)}.sidebar.collapsed.open .nav-label,.sidebar.collapsed.open .menu-label{opacity:1;max-width:200px;padding-right:1rem;transform:translate(0)}.menu-tooltip{position:absolute;left:55px;top:50%;transform:translateY(-50%);background-color:#333;color:#fff;padding:.5rem .75rem;border-radius:4px;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:1001}.menu-tooltip:before{content:"";position:absolute;top:50%;left:-5px;transform:translateY(-50%);border-right:5px solid #333;border-top:5px solid transparent;border-bottom:5px solid transparent}.sidebar.collapsed:not(.open) .menu-link:hover .menu-tooltip{opacity:1;visibility:visible}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1);text-align:center;transition:all .3s ease;flex-shrink:0;margin-top:auto}.footer-info{transition:opacity .3s ease}.footer-text{font-size:.75rem;color:#fff9;margin-bottom:.25rem}.footer-version{font-size:.7rem;color:#fff6}.footer-info{transition:all .4s cubic-bezier(.4,0,.2,1);opacity:1;max-height:60px;overflow:hidden;transform:translateY(0)}.sidebar.collapsed .sidebar-footer{padding:.25rem 0}.sidebar.collapsed .footer-info{opacity:0;max-height:0;transform:translateY(-10px)}.main-content{flex:1;margin-left:50px;display:flex;flex-direction:column;min-width:0}.main-header{background:white;box-shadow:0 1px 3px #0000001a;padding:0 1.5rem;height:70px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:1rem}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;width:40px;height:40px;flex-shrink:0}.mobile-menu-toggle:hover{background-color:#f7fafc}.mobile-menu-toggle .hamburger{display:flex;flex-direction:column;gap:4px;width:20px;height:14px;position:relative}.mobile-menu-toggle .hamburger span{display:block;width:100%;height:2px;background-color:#4a5568;border-radius:1px;transition:all .3s ease;transform-origin:center}.mobile-menu-toggle .hamburger-close span:nth-child(1){transform:translateY(6px) rotate(45deg)}.mobile-menu-toggle .hamburger-close span:nth-child(2){opacity:0;transform:scale(0)}.mobile-menu-toggle .hamburger-close span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.breadcrumb{display:flex;align-items:center;gap:.5rem}.breadcrumb-item{font-size:35px;font-weight:600;color:#2c6fe2}.header-center{flex:1;display:flex;justify-content:center}.system-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#f0fff4;border-radius:20px;border:1px solid #9ae6b4}.status-indicator{width:8px;height:8px;border-radius:50%;background-color:#38a169;animation:pulse 2s infinite}.status-indicator.online{background-color:#38a169}.status-indicator.offline{background-color:#e53e3e}.status-text{font-size:.875rem;color:#2f855a;font-weight:500}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.header-right{display:flex;align-items:center;gap:1rem}.current-time{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#edf2f7;border-radius:8px}.time-icon{font-size:1rem}.time-text{font-size:.875rem;font-weight:500;color:#4a5568}.user-menu{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.user-menu:hover{background-color:#f7fafc}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;font-size:.875rem;color:#2d3748}.user-role{font-size:.75rem;color:#718096}.user-menu-button{background:none;border:none;cursor:pointer;color:#a0aec0;font-size:.75rem}.header-actions{display:flex;align-items:center;gap:.5rem}.action-button{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:6px;transition:background-color .2s ease;position:relative;font-size:1.25rem}.action-button:hover{background-color:#f7fafc}.action-button.logout:hover{background-color:#fed7d7;color:#e53e3e}.notification-badge{position:absolute;top:0;right:0;background-color:#e53e3e;color:#fff;font-size:.7rem;padding:.125rem .375rem;border-radius:10px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center}.page-wrapper{flex:1;overflow-y:auto}@media (max-width: 1024px){.sidebar{transform:translate(-100%);width:280px}.sidebar.open{transform:translate(0)}.sidebar.collapsed:not(.open){transform:translate(-100%)}.main-content{margin-left:0;width:100%}.header-center,.current-time .time-text,.user-info{display:none}.sidebar-backdrop{display:block;left:0;width:100%}}@media (max-width: 768px){.main-header{padding:0 1rem}.page-wrapper{padding:0}.header-actions .action-button:not(.logout){display:none}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999;display:none}.sidebar-overlay.active{display:block}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.card{background:white;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:hidden;transition:box-shadow .2s ease}.card:hover{box-shadow:0 4px 12px #00000026}.card-header{padding:12px 24px;border-bottom:1px solid #e2e8f0;background-color:#f8fafc}.card-title{font-size:1.25rem;font-weight:600;color:#2d3748;margin:0}.card-subtitle{font-size:.875rem;color:#718096;margin:.5rem 0 0}.card-body{padding:2px}.card-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background-color:#f8fafc}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#4299e1;color:#fff;border-color:#4299e1}.btn-primary:hover:not(:disabled){background-color:#3182ce;border-color:#3182ce}.btn-secondary{background-color:#718096;color:#fff;border-color:#718096}.btn-secondary:hover:not(:disabled){background-color:#4a5568;border-color:#4a5568}.btn-success{background-color:#38a169;color:#fff;border-color:#38a169}.btn-success:hover:not(:disabled){background-color:#2f855a;border-color:#2f855a}.btn-warning{background-color:#d69e2e;color:#fff;border-color:#d69e2e}.btn-warning:hover:not(:disabled){background-color:#b7791f;border-color:#b7791f}.btn-danger{background-color:#e53e3e;color:#fff;border-color:#e53e3e}.btn-danger:hover:not(:disabled){background-color:#c53030;border-color:#c53030}.btn-outline{background-color:transparent;color:#4a5568;border-color:#e2e8f0}.btn-outline:hover:not(:disabled){background-color:#f7fafc;color:#2d3748}.btn-sm{padding:.25rem .75rem;font-size:.75rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:12px;white-space:nowrap}.badge-primary{background-color:#bee3f8;color:#2b6cb0}.badge-success{background-color:#c6f6d5;color:#2f855a}.badge-warning{background-color:#faf089;color:#b7791f}.badge-danger{background-color:#fed7d7;color:#c53030}.badge-info{background-color:#bee3f8;color:#2c5282}.table-container{overflow-x:auto;border-radius:8px;border:1px solid #e2e8f0}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th{background-color:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#4a5568;border-bottom:1px solid #e2e8f0;white-space:nowrap}.table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.table tbody tr:hover{background-color:#f8fafc}.table tbody tr:last-child td{border-bottom:none}.form-group{margin-bottom:1.5rem}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.form-col-6{flex:1;margin-bottom:.5rem}.form-col-12{width:100%}@media (max-width: 768px){.form-row{flex-direction:column;gap:0}.form-col-6{margin-bottom:1rem}}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.form-select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background-color:#fff;cursor:pointer}.form-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;resize:vertical;min-height:100px}.form-text{display:block;margin-top:.25rem;font-size:.75rem;color:#6b7280}.form-text.text-muted{color:#9ca3af}.alert{padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem}.alert-success{background-color:#f0fff4;border:1px solid #9ae6b4;color:#2f855a}.alert-warning{background-color:#fffbeb;border:1px solid #f6e05e;color:#b7791f}.alert-danger{background-color:#fed7d7;border:1px solid #fc8181;color:#c53030}.alert-info{background-color:#ebf8ff;border:1px solid #90cdf4;color:#2c5282}.spinner{width:20px;height:20px;border:2px solid #e2e8f0;border-top:2px solid #4299e1;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:white;border-radius:12px;max-width:90vw;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a}.modal-fixed{width:600px;min-height:500px;max-width:none}@media (max-width: 768px){.modal-fixed{width:95vw;min-height:auto;max-width:95vw}}.modal-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:600;color:#2d3748}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#a0aec0;padding:.25rem}.modal-close:hover{color:#718096}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end}.tooltip{position:relative;display:inline-block}.tooltip:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#2d3748;color:#fff;padding:.5rem;border-radius:4px;font-size:.75rem;white-space:nowrap;z-index:1000}.pagination{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-top:1.5rem}.pagination-item{padding:.5rem .75rem;border:1px solid #e2e8f0;background-color:#fff;color:#4a5568;text-decoration:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.pagination-item:hover:not(.disabled){background-color:#f7fafc;border-color:#cbd5e0}.pagination-item.active{background-color:#4299e1;border-color:#4299e1;color:#fff}.pagination-item.disabled{opacity:.5;cursor:not-allowed}.page-header{margin-bottom:2rem}.page-title{font-size:2rem;font-weight:700;color:#1a202c;margin-bottom:.5rem}.page-description{font-size:1rem;color:#718096;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;display:flex;align-items:center;gap:1rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-icon.blue{background-color:#dbeafe;color:#2563eb}.stat-icon.green{background-color:#dcfce7;color:#16a34a}.stat-icon.red{background-color:#fee2e2;color:#dc2626}.stat-icon.yellow{background-color:#fef3c7;color:#d97706}.stat-icon.purple{background-color:#f3e8ff;color:#9333ea}.stat-content h3{font-size:1.875rem;font-weight:700;color:#1a202c;margin:0 0 .25rem}.stat-content p{font-size:.875rem;color:#718096;margin:0}.dashboard-grid{display:grid;gap:2rem;grid-template-columns:2fr 1fr}.dashboard-main{display:flex;flex-direction:column;gap:2rem}.dashboard-sidebar{display:flex;flex-direction:column;gap:1.5rem}.chart-container{height:300px;display:flex;align-items:center;justify-content:center;background-color:#f8fafc;border-radius:8px;color:#718096;font-size:.875rem}.activity-list{max-height:400px;overflow-y:auto}.activity-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 0;border-bottom:1px solid #f1f5f9}.activity-item:last-child{border-bottom:none}.activity-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.activity-content{flex:1}.activity-title{font-weight:500;color:#2d3748;margin:0 0 .25rem;font-size:.875rem}.activity-description{color:#718096;margin:0 0 .25rem;font-size:.75rem}.activity-time{color:#a0aec0;font-size:.7rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.service-card{background:white;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.service-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.service-card-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.service-info{display:flex;align-items:center;gap:1rem}.service-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background-color:#f7fafc}.service-details h3{font-size:1.125rem;font-weight:600;color:#2d3748;margin:0 0 .25rem}.service-details p{font-size:.875rem;color:#718096;margin:0}.service-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500}.service-status.running{color:#38a169}.service-status.stopped{color:#e53e3e}.service-status.loading{color:#d69e2e}.service-card-body{padding:1.5rem}.service-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.metric{text-align:center}.metric-value{font-size:1.25rem;font-weight:600;color:#2d3748;margin:0 0 .25rem}.metric-label{font-size:.75rem;color:#718096;margin:0}.service-actions{display:flex;gap:.75rem}.logs-container{background:#1a202c;color:#e2e8f0;border-radius:8px;padding:1.5rem;font-family:Consolas,Monaco,Courier New,monospace;font-size:.875rem;line-height:1.6;max-height:500px;overflow-y:auto}.log-entry{margin-bottom:.5rem;border-left:3px solid transparent;padding:.25rem 0 .25rem .75rem}.log-entry.error{border-left-color:#e53e3e;background-color:#e53e3e1a}.log-entry.warning{border-left-color:#d69e2e;background-color:#d69e2e1a}.log-entry.info{border-left-color:#4299e1;background-color:#4299e11a}.log-timestamp{color:#a0aec0;font-weight:500}.log-level{font-weight:600;margin:0 .5rem}.log-level.error{color:#fc8181}.log-level.warning{color:#f6e05e}.log-level.info{color:#90cdf4}.log-message{color:#e2e8f0}.system-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.system-card{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.system-card h4{font-size:1rem;font-weight:600;color:#2d3748;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.system-metric{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.system-metric:last-child{margin-bottom:0}.metric-name{font-size:.875rem;color:#718096}.metric-value{font-size:.875rem;font-weight:500;color:#2d3748}.progress-bar{width:100%;height:8px;background-color:#e2e8f0;border-radius:4px;overflow:hidden;margin-top:.5rem}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-fill.success{background-color:#38a169}.progress-fill.warning{background-color:#d69e2e}.progress-fill.danger{background-color:#e53e3e}.settings-nav{display:flex;gap:1rem;flex-wrap:wrap}.settings-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:white;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;text-decoration:none;color:#4a5568;font-weight:500}.settings-tab:hover{border-color:#cbd5e1;background-color:#f8fafc}.settings-tab.active{border-color:#4299e1;background-color:#ebf8ff;color:#2c5282}.tab-icon{font-size:1.25rem}.tab-label{font-size:.875rem}.settings-content{margin-top:2rem}.settings-actions{margin-top:2rem;padding:1.5rem;background:white;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.security-section,.advanced-section{padding:1.5rem 0;border-bottom:1px solid #f1f5f9}.security-section:last-child,.advanced-section:last-child{border-bottom:none}.security-section h4,.advanced-section h4{font-size:1.125rem;font-weight:600;color:#2d3748;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.api-key-section{background:#f8fafc;padding:1rem;border-radius:6px;border:1px solid #e2e8f0}.email-config{padding:1rem 0}.email-config h4{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:1rem}.backup-config{padding:1rem 0}.backup-actions{margin:2rem 0}.backup-actions h4{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:1rem}.backup-status{margin:2rem 0}.backup-status h4{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:1rem}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.status-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.status-label{font-size:.875rem;color:#718096}.status-value{font-size:.875rem;font-weight:500;color:#2d3748}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.import-export,.debug-settings{padding:1rem 0}.danger-zone{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:1.5rem;margin-top:2rem}.danger-zone h4{color:#dc2626}.danger-actions{display:flex;gap:1rem;flex-wrap:wrap}.storage-item{background:white;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0}.storage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.storage-header h4{font-size:1rem;font-weight:600;color:#2d3748;margin:0}.storage-details{margin-bottom:1rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.info-item:last-child{border-bottom:none}.info-label{font-size:.875rem;color:#718096}.info-value{font-size:.875rem;font-weight:500;color:#2d3748}.system-info .info-item{padding:.25rem 0}.service-info-details{margin:1rem 0;padding:1rem;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.info-row:last-child{margin-bottom:0}.info-row span:first-child{font-size:.875rem;color:#718096}.info-row span:last-child{font-size:.875rem;font-weight:500;color:#2d3748}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.switch-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.switch input:checked+.switch-slider{background-color:#4299e1}.switch input:checked+.switch-slider:before{transform:translate(20px)}.log-detail{font-family:var(--font-mono);font-size:.875rem}.detail-row{display:flex;margin-bottom:1rem;gap:1rem}.detail-row strong{min-width:100px;color:#4a5568}.detail-content{background:#f8fafc;padding:.75rem;border-radius:6px;border:1px solid #e2e8f0;font-family:var(--font-mono);white-space:pre-wrap;margin-top:.5rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.settings-nav{flex-direction:column}.settings-tab{justify-content:center}.tools-grid,.status-grid{grid-template-columns:1fr}.danger-actions{flex-direction:column}}.text-right{text-align:right}.text-left{text-align:left}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mt-0{margin-top:0}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.align-center{align-items:center}@media (max-width: 768px){.mobile-hidden{display:none}.mobile-block{display:block}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 221.2 83.2% 53.3%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96%;--secondary-foreground: 222.2 84% 4.9%;--muted: 210 40% 96%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96%;--accent-foreground: 222.2 84% 4.9%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 221.2 83.2% 53.3%;--radius: .5rem}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground))}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-5{margin-top:1.25rem}.block{display:block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-2{height:.5rem}.h-24{height:6rem}.h-32{height:8rem}.min-h-screen{min-height:100vh}.w-16{width:4rem}.w-2{width:.5rem}.w-24{width:6rem}.w-32{width:8rem}.w-full{width:100%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.rounded-full{border-radius:9999px}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border{border-width:1px}.border-b-2{border-bottom-width:2px}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.lowercase{text-transform:lowercase}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-muted{color:hsl(var(--muted))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}
