*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-overflow-scrolling:touch}html,body{overflow-x:hidden;max-width:100vw}.app-container{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#333}.app-header{background-color:#fff;color:#001529;padding:0 2.5rem;height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #00000026;z-index:100;border-bottom:1px solid #f0f0f0}.app-header h1{font-size:1.25rem;margin:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#001529}.app-logo{width:auto;height:5rem;flex-shrink:0}.header-nav{display:inline-flex;align-items:center;gap:.5rem;margin-left:2rem}.nav-btn{border:none;outline:none;height:40px;padding:0 1.5rem;border-radius:4px;background:transparent;color:#595959;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.nav-btn:hover{background-color:#0000000a;color:#001529}.nav-btn.active{background-color:#2bb158;color:#fff;box-shadow:0 2px 4px #2bb1584d}.sub-nav{background-color:#fafafa;border-bottom:1px solid #f0f0f0;padding:0 2.5rem;display:flex;align-items:center;gap:.5rem;box-shadow:0 1px 4px #0000000d;margin-top:15px}.sub-nav-btn{border:none;outline:none;height:40px;padding:0 1.5rem;border-radius:4px;background:transparent;color:#595959;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.sub-nav-btn:hover{color:#001529;background-color:#00000005}.sub-nav-btn.active{color:#1890ff;border-bottom-color:#1890ff;font-weight:600}@media(max-width:768px){.sub-nav{padding:0 1rem;overflow-x:auto}.sub-nav-btn{padding:0 1rem;font-size:.9rem;white-space:nowrap}}.auth-avatar-btn{background-color:#f0f0f0;border:none;padding:.5rem;border-radius:50%;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;width:48px;height:48px;position:relative}.auth-avatar-btn:hover{background-color:#2bb1581a;transform:scale(1.05)}.auth-avatar-btn:active{transform:scale(.95)}.avatar-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#001529}.avatar-icon svg{transition:color .3s}.auth-avatar-btn:hover{background-color:#2bb15826;transform:scale(1.05)}.auth-avatar-btn:hover .avatar-icon{color:#2bb158}.avatar-dropdown{position:relative;display:inline-block}.avatar-btn{background-color:#f0f0f0;border:none;padding:.5rem;border-radius:50%;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;width:48px;height:48px;position:relative}.avatar-btn:hover{background-color:#2bb15826;transform:scale(1.05)}.avatar-btn:active{transform:scale(.95)}.avatar-btn .avatar-icon{display:flex;align-items:center;justify-content:center;gap:4px;color:#001529}.avatar-btn .avatar-icon svg:first-child{width:24px;height:24px}.auth-avatar-btn .avatar-icon svg{width:24px;height:24px}.dropdown-arrow{transition:transform .3s ease;margin-left:2px}.dropdown-arrow.rotated{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #d9d9d9;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:160px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease;z-index:1000}.dropdown-menu.open{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:none;border:none;text-align:left;cursor:pointer;color:#001529;font-size:14px;font-weight:500;transition:background-color .2s;border-radius:0}.dropdown-item:first-child{border-radius:6px 6px 0 0}.dropdown-item:last-child{border-radius:0 0 6px 6px}.dropdown-item:hover{background-color:#f5f5f5}.dropdown-item svg{flex-shrink:0}.app-content{flex:1;width:100%;box-sizing:border-box;overflow-y:auto;min-height:calc(100vh - 64px);background-color:#f5f5f5}@media(max-width:1024px){.app-content{padding:1.25rem}}@media(max-width:768px){.app-content{padding:1rem}.auth-avatar-btn,.avatar-btn{width:44px;height:44px}.avatar-btn .avatar-icon svg:first-child,.auth-avatar-btn .avatar-icon svg{width:22px;height:22px}}@media(max-width:480px){.app-content{padding:.75rem}.auth-avatar-btn,.avatar-btn{width:40px;height:40px}.avatar-btn .avatar-icon svg:first-child,.auth-avatar-btn .avatar-icon svg{width:20px;height:20px}}@media(max-width:1024px){.app-header{padding:0 1.5rem}.app-header h1{font-size:1.1rem}.app-logo{height:4rem}.header-nav{margin-left:1rem;gap:.3rem}.nav-btn{padding:0 1rem;font-size:.9rem;height:36px}.logout-btn{padding:.4rem .8rem;font-size:.9rem}.app-content{padding:1.5rem}}@media(max-width:768px){.app-header{padding:0 1rem;height:auto;min-height:64px;flex-wrap:wrap;gap:.75rem}.app-header h1{font-size:1rem;flex:1;min-width:150px}.app-logo{height:3rem}.header-nav{margin-left:0;order:3;width:100%;justify-content:center;padding-bottom:.5rem}.nav-btn{flex:1;max-width:150px}.logout-btn{order:2}.app-content{padding:1rem}}@media(max-width:480px){.app-header{padding:.75rem;gap:.5rem}.app-header h1{font-size:.85rem}.app-logo{height:2.5rem}.nav-btn{padding:0 .75rem;font-size:.85rem;height:32px}.logout-btn{padding:.3rem .6rem;font-size:.85rem}.app-content{padding:.75rem}}.users-table-container{width:100%;max-width:100%;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;padding:0;overflow:visible;box-sizing:border-box;padding:1.5rem;display:flex;flex-direction:column}.users-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #f0f0f0;background:#fff}.users-title-section{display:flex;align-items:center;gap:12px}.users-title{margin:0;font-size:1.5rem;font-weight:500;color:#262626;display:flex;align-items:center;gap:8px}.users-title:before{content:"\1f465";font-size:1.5rem}.users-header-actions{display:flex;align-items:center;gap:12px}.search-wrapper{position:relative;display:flex;align-items:center;gap:8px}.users-search-input{padding:10px 36px 10px 12px;border:2px solid #d9d9d9;border-radius:6px;font-size:14px;width:300px;transition:all .3s cubic-bezier(.4,0,.2,1);background:#fff}.users-search-input:focus{outline:none;border-color:#1890ff;box-shadow:0 0 0 3px #1890ff1a;width:350px}.users-search-input::placeholder{color:#bfbfbf;transition:opacity .3s}.users-search-input:focus::placeholder{opacity:.5}.clear-search-btn{position:absolute;right:8px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:none;background:#d9d9d9;color:#fff;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;transition:all .3s;font-weight:700}.clear-search-btn:hover{background:#ff4d4f;transform:scale(1.1) rotate(90deg)}.search-results-count{font-size:12px;color:#8c8c8c;white-space:nowrap;padding:4px 8px;background:#f0f0f0;border-radius:12px;animation:fadeIn .3s ease-in}.add-user-btn{padding:8px 16px;background-color:#1890ff;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s}.add-user-btn:hover{background-color:#40a9ff}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid #d9d9d9;border-radius:4px;background:#fff;cursor:pointer;color:#595959;transition:all .3s}.icon-btn:hover:not(:disabled){border-color:#40a9ff;color:#1890ff}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn{transition:transform .3s ease}.refresh-btn:hover:not(:disabled){transform:rotate(90deg);border-color:#1890ff;color:#1890ff}.refresh-btn.refreshing{animation:spin 1s linear infinite}.refresh-btn.refreshing:hover{animation:spin .5s linear infinite}.users-description{padding:0 1.5rem 1rem;color:#8c8c8c;font-size:14px;background:#fafafa;border-bottom:1px solid #f0f0f0}.users-loading{padding:3rem;text-align:center;color:#8c8c8c}.loading-spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top-color:#1890ff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.users-table-wrapper{overflow-x:auto;overflow-y:visible;width:100%}.users-table{width:100%;border-collapse:collapse;background:#fff;table-layout:auto}.users-table thead{background:#fafafa}.users-table th{padding:16px 20px;text-align:left;font-weight:500;font-size:14px;color:#262626;border-bottom:2px solid #f0f0f0;border-right:1px solid #f0f0f0;white-space:nowrap}.users-table th:nth-child(1){min-width:150px}.users-table th:nth-child(2){min-width:200px}.users-table th:nth-child(3){min-width:180px}.users-table th:nth-child(4){min-width:100px}.users-table th:nth-child(5){min-width:120px}.users-table th:last-child{border-right:none}.users-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;padding-right:32px}.users-table th.sortable:hover{background:#f5f5f5}.users-table th.sortable:hover .sort-indicator{opacity:1;color:#1890ff}.sort-indicator{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#8c8c8c;font-size:14px;font-weight:600;opacity:.6;transition:all .3s;display:inline-block;min-width:16px;text-align:center}.sort-indicator.active{color:#1890ff;opacity:1;font-weight:700}.users-table th.sortable:hover .sort-indicator{opacity:1}.users-table td{padding:16px 20px;border-bottom:1px solid #f0f0f0;border-right:1px solid #f0f0f0;font-size:14px;color:#595959;word-wrap:break-word;word-break:break-word;white-space:normal;position:static;vertical-align:top;line-height:1.5;background-color:#fff}.users-table td:first-child{padding-left:20px;position:relative;z-index:3;visibility:visible;opacity:1;display:table-cell;border-left:0 solid #1890ff;transition:border-left .3s ease,padding-left .3s ease}.users-table tbody tr:hover td{background-color:transparent}.username-cell{position:relative;z-index:3;max-width:300px;min-width:150px;display:table-cell;visibility:visible;opacity:1}.email-cell,.name-cell{position:relative;z-index:2;max-width:300px;min-width:120px}.users-table td:last-child{border-right:none}.users-table tbody tr{transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideInRow .4s ease-out backwards}.user-row{cursor:pointer;position:relative}.user-row:hover{background:linear-gradient(90deg,#f0f8ff,#fafafa);box-shadow:0 2px 8px #00000014}.user-row:hover td:first-child{border-left:4px solid #1890ff;padding-left:16px}.user-row:hover td{color:#1890ff}.user-row:hover .username-cell,.user-row:hover .email-cell,.user-row:hover .name-cell{font-weight:500}.user-row:hover .edit-btn{transform:scale(1.1);box-shadow:0 4px 12px #1890ff4d}.user-row:active{transform:none}.users-table tbody tr:last-child td{border-bottom:none}.email-cell,.name-cell{transition:all .3s ease;position:relative;z-index:2}@keyframes slideInRow{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.actions-column{width:100px;text-align:center}.actions-column-header{width:100px;text-align:center;font-weight:600;color:#262626;position:relative}.edit-btn{min-width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:2px solid #1890ff;border-radius:6px;background:linear-gradient(135deg,#e6f7ff,#bae7ff);cursor:pointer;color:#1890ff;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0 12px;font-weight:500;position:relative;overflow:hidden}.edit-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#1890ff33;transform:translate(-50%,-50%);transition:width .6s,height .6s}.edit-btn:hover:before{width:300px;height:300px}.edit-btn:hover{border-color:#40a9ff;color:#1890ff;background:linear-gradient(135deg,#bae7ff,#91d5ff);transform:scale(1.08) translateY(-2px);box-shadow:0 6px 20px #1890ff66}.edit-btn:active{transform:scale(1.02) translateY(0);box-shadow:0 2px 8px #1890ff4d}.edit-btn svg{width:18px;height:18px;position:relative;z-index:1;transition:transform .3s}.edit-btn:hover svg{transform:rotate(15deg)}.edit-btn-text{position:relative;z-index:1;font-size:13px;display:none}.edit-btn:hover .edit-btn-text{display:inline}.edit-btn:hover svg{margin-right:0}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:16px;font-size:12px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:default;position:relative;overflow:hidden}.status-badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.status-badge:hover:before{left:100%}.status-badge.enabled{background:linear-gradient(135deg,#f6ffed,#d9f7be);color:#52c41a;border:1px solid #b7eb8f;box-shadow:0 2px 4px #52c41a33}.status-badge.enabled:hover{transform:scale(1.05);box-shadow:0 4px 8px #52c41a4d}.status-badge.disabled{background:linear-gradient(135deg,#fff2e8,#ffe7ba);color:#fa8c16;border:1px solid #ffd591;box-shadow:0 2px 4px #fa8c1633}.status-badge.disabled:hover{transform:scale(1.05);box-shadow:0 4px 8px #fa8c164d}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;animation:pulse 2s infinite}.status-badge.enabled .status-dot{background:#52c41a;box-shadow:0 0 #52c41ab3}.status-badge.disabled .status-dot{background:#fa8c16;box-shadow:0 0 #fa8c16b3}@keyframes pulse{0%{box-shadow:0 0 #52c41ab3}70%{box-shadow:0 0 0 6px #52c41a00}to{box-shadow:0 0 #52c41a00}}.no-data{text-align:center;color:#8c8c8c;padding:4rem 2rem!important}.no-data-row{animation:fadeIn .5s ease-in}.no-data-content{display:flex;flex-direction:column;align-items:center;gap:16px}.no-data-content svg{color:#d9d9d9;opacity:.5;animation:float 3s ease-in-out infinite}.no-data-content p{margin:0;font-size:16px;color:#8c8c8c}.no-data-content p:first-of-type{font-size:18px;font-weight:500;color:#595959}.no-data-hint{font-size:14px!important;color:#bfbfbf!important;font-style:italic}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.user-management-container{display:flex;height:calc(100vh - 64px - 3rem);background:#fff;overflow:hidden;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.user-list-panel{flex:0 0 465px;display:flex;flex-direction:column;border-right:1px solid #f0f0f0;background-color:#fafafa}@media(max-width:1024px){.user-management-container{height:calc(100vh - 64px - 2.5rem);border-radius:6px}.user-list-panel{flex:0 0 380px}}@media(max-width:768px){.user-management-container{flex-direction:column;height:auto;min-height:calc(100vh - 64px - 2rem);border-radius:6px}.user-list-panel{flex:0 0 auto;max-height:45vh;border-right:none;border-bottom:1px solid #f0f0f0}}@media(max-width:480px){.user-management-container{height:auto;min-height:calc(100vh - 64px - 1.5rem);border-radius:4px}.user-list-panel{max-height:40vh}}.panel-header{padding:1.5rem 1.5rem 1rem;background-color:#fafafa}.panel-header h2{margin:0 0 1rem;font-size:1.125rem;font-weight:400;color:#262626}@media(max-width:768px){.panel-header{padding:1rem}.panel-header h2{font-size:1rem}}@media(max-width:480px){.panel-header{padding:.75rem}.panel-header h2{font-size:.95rem}}.search-input{width:100%;padding:10px 12px;border:1px solid #d9d9d9;border-radius:2px;box-sizing:border-box;font-size:14px;background:#fff;transition:border-color .3s}.search-input:focus{border-color:#40a9ff;outline:none}.user-list{flex:1;overflow-y:auto;padding:0;margin:0;list-style:none;background:#fff}.user-list-item{padding:16px 20px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .15s;background:#fff}.user-list-item:hover{background-color:#f5f5f5}.user-list-item.selected{background-color:#e6f7ff;border-left:4px solid #1890ff;padding-left:16px}.user-username{display:block;font-weight:500;color:#262626;font-size:14px;margin-bottom:4px}.user-email{display:block;font-size:13px;color:#8c8c8c}.user-detail-panel{flex:1;padding:2.5rem 3rem;overflow-y:auto;background-color:#fff;height:fit-content;min-height:fit-content}@media(max-width:1024px){.user-detail-panel{padding:2rem 2.5rem}}@media(max-width:768px){.user-detail-panel{padding:1.5rem;flex:1;height:fit-content;min-height:fit-content}}@media(max-width:480px){.user-detail-panel{padding:1rem}}.detail-header{margin-bottom:2.5rem;padding-bottom:0;border-bottom:none}.detail-header h2{margin:0 0 8px;color:#262626;font-size:1.75rem;font-weight:400}@media(max-width:768px){.detail-header{margin-bottom:1.5rem}.detail-header h2{font-size:1.5rem}}@media(max-width:480px){.detail-header{margin-bottom:1rem}.detail-header h2{font-size:1.25rem}.user-id{font-size:11px}}.user-id{color:#bfbfbf;font-size:13px;font-family:monospace;margin-top:6px}.roles-section{margin-bottom:2.5rem}.roles-section h3{font-size:.875rem;color:#8c8c8c;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}@media(max-width:768px){.roles-section{margin-bottom:1.5rem}.roles-section h3{font-size:.8rem}}@media(max-width:480px){.roles-section{margin-bottom:1rem}}.assigned-roles-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px}.role-tag{display:inline-flex;align-items:center;background-color:#e6f7ff;border:1px solid #91d5ff;color:#1890ff;padding:5px 12px;border-radius:2px;font-size:14px;width:auto;white-space:normal}.role-display{display:flex;flex-direction:column;line-height:1.4}.dashboard-name{font-weight:600;display:block}.role-name-line{font-weight:400;font-size:.9em;opacity:.8;display:block;margin-top:2px}.remove-role-btn{background:none;border:none;color:#1890ff;margin-left:6px;cursor:pointer;padding:0;font-size:16px;line-height:1;font-weight:400;opacity:.7}.remove-role-btn:hover{opacity:1;color:#ff4d4f}.add-roles-container{border:none;padding:0;background-color:transparent}.roles-grid{display:flex;flex-wrap:wrap;gap:10px;max-height:280px;overflow-y:auto;margin-bottom:1.25rem}@media(max-width:768px){.roles-grid{max-height:240px}}@media(max-width:480px){.roles-grid{max-height:200px}.role-checkbox-label,.role-tag{white-space:normal}}.role-checkbox-label{display:inline-flex;align-items:center;padding:10px 12px;background:#fff;border:1px solid #d9d9d9;border-radius:2px;cursor:pointer;transition:all .2s;font-size:14px;color:#262626;width:fit-content;white-space:normal;flex-shrink:0}.role-checkbox-label:hover{border-color:#40a9ff}.role-checkbox-label.checked{background-color:#e6f7ff;border-color:#1890ff;color:#262626}.role-checkbox-label input{margin-right:10px;cursor:pointer}.add-btn{background-color:#2bb158;color:#fff;border:none;padding:10px 20px;border-radius:2px;cursor:pointer;font-size:14px;font-weight:400;transition:background-color .3s;width:max-content}.add-btn:hover:not(:disabled){background-color:#249e4d}.add-btn:disabled{background-color:#f5f5f5;color:#00000040;cursor:not-allowed;border:1px solid #d9d9d9}.remove-btn{background-color:#ff4d4f;color:#fff;border:none;padding:10px 20px;border-radius:2px;cursor:pointer;font-size:14px;font-weight:400;transition:background-color .3s;width:max-content}.remove-btn:hover:not(:disabled){background-color:#ff7875}.remove-btn:disabled{background-color:#f5f5f5;color:#00000040;cursor:not-allowed;border:1px solid #d9d9d9}.assigned-roles-container{display:flex;flex-direction:column}.empty-state{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#bfbfbf;font-size:15px;text-align:center;padding:1rem}@media(max-width:768px){.user-list-item{padding:12px 16px}.user-username{font-size:13px}.user-email{font-size:12px}}@media(max-width:480px){.user-list-item{padding:10px 12px}.user-username{font-size:12px}.user-email{font-size:11px;word-break:break-all}}@media(max-width:480px){.role-tag{font-size:12px;padding:4px 10px}.assigned-roles-list{gap:6px}}@media(max-width:768px){.add-btn{width:100%;padding:12px 20px}}@media(max-width:480px){.add-btn{font-size:13px;padding:10px 16px}.role-checkbox-label{font-size:13px;padding:8px 10px}}@media(max-width:480px){.search-input{font-size:13px;padding:8px 10px}}@media(max-width:768px){body{overflow-x:hidden}*{word-wrap:break-word}button,a,input[type=checkbox]{min-height:44px;min-width:44px}input[type=checkbox]{transform:scale(1.3)}}img{max-width:100%;height:auto}@media(max-width:768px){.user-list-item,.nav-btn{-webkit-tap-highlight-color:rgba(0,0,0,.1)}}@media(prefers-reduced-motion:no-preference){*{scroll-behavior:smooth}}@media(max-width:896px)and (orientation:landscape){.user-management-container{flex-direction:row}.user-list-panel{flex:0 0 320px;max-height:none;border-right:1px solid #f0f0f0;border-bottom:none}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto}.modal-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:1.5rem 2rem;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;background:#fff}.modal-header h3{margin:0;font-size:1.75rem;font-weight:400;color:#262626}.modal-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;color:#595959;border-radius:4px;transition:all .3s}.modal-close-btn:hover{background:#f5f5f5;color:#262626}.modal-body{padding:2.5rem 3rem;overflow-y:auto;flex:1;background-color:#fff}.modal-loading{text-align:center;padding:3rem;color:#8c8c8c}.modal-section{margin-bottom:2.5rem}.modal-section:last-child{margin-bottom:0}.modal-section h4{margin:0 0 1rem;font-size:.875rem;color:#8c8c8c;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.empty-roles{padding:1rem;text-align:center;color:#999;font-style:italic}.roles-list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-wrap:wrap;gap:8px}.modal-section .role-item{display:inline-flex;align-items:center;background-color:#e6f7ff;border:1px solid #91d5ff;color:#1890ff;padding:5px 12px;border-radius:2px;font-size:14px;width:auto;white-space:normal;gap:8px}.modal-section .role-checkbox{margin:0 8px 0 0;cursor:pointer}.modal-section .role-display{display:flex;flex-direction:column;line-height:1.4}.modal-section .dashboard-name{font-weight:600;display:block}.modal-section .role-name-line{font-weight:400;font-size:.9em;opacity:.8;display:block;margin-top:2px}.modal-section .remove-role-btn{background:none;border:none;color:#1890ff;margin-left:6px;cursor:pointer;padding:0;font-size:16px;line-height:1;font-weight:400;opacity:.7;width:auto;height:auto}.modal-section .remove-role-btn:hover:not(:disabled){opacity:1;color:#ff4d4f;background:none}.modal-section .remove-role-btn:disabled{opacity:.3;cursor:not-allowed}.roles-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;max-height:280px;overflow-y:auto;padding:4px}.role-checkbox-label{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;transition:all .3s;white-space:nowrap}.role-checkbox-label:hover{border-color:#40a9ff;background:#f0f8ff}.role-checkbox-label.checked{border-color:#1890ff;background:#e6f7ff}.role-checkbox-label input[type=checkbox]{margin:0;cursor:pointer}.modal-action-btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;margin-top:12px}.modal-action-btn.add-btn{background-color:#2bb158;color:#fff}.modal-action-btn.add-btn:hover:not(:disabled){background-color:#52c41a}.modal-action-btn.remove-btn{background-color:#ff4d4f;color:#fff}.modal-action-btn.remove-btn:hover:not(:disabled){background-color:#ff7875}.modal-action-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1024px){.modal-body{padding:2rem 2.5rem}}@media(max-width:768px){.modal-content{max-width:95%;margin:1rem}.modal-body{padding:1.5rem}.modal-section{margin-bottom:1.5rem}.modal-section h4{font-size:.8rem}.roles-grid{max-height:200px}}@media(max-width:480px){.modal-overlay{padding:1rem}.modal-content{max-width:100%;margin:0;max-height:95vh}.modal-header{padding:1rem 1.5rem}.modal-header h3{font-size:1.25rem}.modal-body{padding:1rem}.modal-section{margin-bottom:1rem}.modal-action-btn{width:100%;padding:12px 20px}}.toast-center-center{top:50%;left:50%;transform:translate(-50%,-50%)}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}.toast-title{font-weight:700}.toast-message{word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;text-shadow:0 1px 0 #ffffff}.toast-close-button:hover,.toast-close-button:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.4}button.toast-close-button{padding:0;cursor:pointer;background:transparent;border:0}.toast-container{pointer-events:none;position:fixed;z-index:999999}.toast-container *{box-sizing:border-box}.toast-container .ngx-toastr{position:relative;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;background-size:24px;box-shadow:0 0 12px #999;color:#fff}.toast-container .ngx-toastr:hover{box-shadow:0 0 12px #000;opacity:1;cursor:pointer}.toast-info{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCA1MTIgNTEyJyB3aWR0aD0nNTEyJyBoZWlnaHQ9JzUxMic+PHBhdGggZmlsbD0ncmdiKDI1NSwyNTUsMjU1KScgZD0nTTI1NiA4QzExOS4wNDMgOCA4IDExOS4wODMgOCAyNTZjMCAxMzYuOTk3IDExMS4wNDMgMjQ4IDI0OCAyNDhzMjQ4LTExMS4wMDMgMjQ4LTI0OEM1MDQgMTE5LjA4MyAzOTIuOTU3IDggMjU2IDh6bTAgMTEwYzIzLjE5NiAwIDQyIDE4LjgwNCA0MiA0MnMtMTguODA0IDQyLTQyIDQyLTQyLTE4LjgwNC00Mi00MiAxOC44MDQtNDIgNDItNDJ6bTU2IDI1NGMwIDYuNjI3LTUuMzczIDEyLTEyIDEyaC04OGMtNi42MjcgMC0xMi01LjM3My0xMi0xMnYtMjRjMC02LjYyNyA1LjM3My0xMiAxMi0xMmgxMnYtNjRoLTEyYy02LjYyNyAwLTEyLTUuMzczLTEyLTEydi0yNGMwLTYuNjI3IDUuMzczLTEyIDEyLTEyaDY0YzYuNjI3IDAgMTIgNS4zNzMgMTIgMTJ2MTAwaDEyYzYuNjI3IDAgMTIgNS4zNzMgMTIgMTJ2MjR6Jy8+PC9zdmc+)}.toast-error{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCA1MTIgNTEyJyB3aWR0aD0nNTEyJyBoZWlnaHQ9JzUxMic+PHBhdGggZmlsbD0ncmdiKDI1NSwyNTUsMjU1KScgZD0nTTI1NiA4QzExOSA4IDggMTE5IDggMjU2czExMSAyNDggMjQ4IDI0OCAyNDgtMTExIDI0OC0yNDhTMzkzIDggMjU2IDh6bTEyMS42IDMxMy4xYzQuNyA0LjcgNC43IDEyLjMgMCAxN0wzMzggMzc3LjZjLTQuNyA0LjctMTIuMyA0LjctMTcgMEwyNTYgMzEybC02NS4xIDY1LjZjLTQuNyA0LjctMTIuMyA0LjctMTcgMEwxMzQuNCAzMzhjLTQuNy00LjctNC43LTEyLjMgMC0xN2w2NS42LTY1LTY1LjYtNjUuMWMtNC43LTQuNy00LjctMTIuMyAwLTE3bDM5LjYtMzkuNmM0LjctNC43IDEyLjMtNC43IDE3IDBsNjUgNjUuNyA2NS4xLTY1LjZjNC43LTQuNyAxMi4zLTQuNyAxNyAwbDM5LjYgMzkuNmM0LjcgNC43IDQuNyAxMi4zIDAgMTdMMzEyIDI1Nmw2NS42IDY1LjF6Jy8+PC9zdmc+)}.toast-success{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCA1MTIgNTEyJyB3aWR0aD0nNTEyJyBoZWlnaHQ9JzUxMic+PHBhdGggZmlsbD0ncmdiKDI1NSwyNTUsMjU1KScgZD0nTTE3My44OTggNDM5LjQwNGwtMTY2LjQtMTY2LjRjLTkuOTk3LTkuOTk3LTkuOTk3LTI2LjIwNiAwLTM2LjIwNGwzNi4yMDMtMzYuMjA0YzkuOTk3LTkuOTk4IDI2LjIwNy05Ljk5OCAzNi4yMDQgMEwxOTIgMzEyLjY5IDQzMi4wOTUgNzIuNTk2YzkuOTk3LTkuOTk3IDI2LjIwNy05Ljk5NyAzNi4yMDQgMGwzNi4yMDMgMzYuMjA0YzkuOTk3IDkuOTk3IDkuOTk3IDI2LjIwNiAwIDM2LjIwNGwtMjk0LjQgMjk0LjQwMWMtOS45OTggOS45OTctMjYuMjA3IDkuOTk3LTM2LjIwNC0uMDAxeicvPjwvc3ZnPg==)}.toast-warning{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCA1NzYgNTEyJyB3aWR0aD0nNTc2JyBoZWlnaHQ9JzUxMic+PHBhdGggZmlsbD0ncmdiKDI1NSwyNTUsMjU1KScgZD0nTTU2OS41MTcgNDQwLjAxM0M1ODcuOTc1IDQ3Mi4wMDcgNTY0LjgwNiA1MTIgNTI3Ljk0IDUxMkg0OC4wNTRjLTM2LjkzNyAwLTU5Ljk5OS00MC4wNTUtNDEuNTc3LTcxLjk4N0wyNDYuNDIzIDIzLjk4NWMxOC40NjctMzIuMDA5IDY0LjcyLTMxLjk1MSA4My4xNTQgMGwyMzkuOTQgNDE2LjAyOHpNMjg4IDM1NGMtMjUuNDA1IDAtNDYgMjAuNTk1LTQ2IDQ2czIwLjU5NSA0NiA0NiA0NiA0Ni0yMC41OTUgNDYtNDYtMjAuNTk1LTQ2LTQ2LTQ2em0tNDMuNjczLTE2NS4zNDZsNy40MTggMTM2Yy4zNDcgNi4zNjQgNS42MDkgMTEuMzQ2IDExLjk4MiAxMS4zNDZoNDguNTQ2YzYuMzczIDAgMTEuNjM1LTQuOTgyIDExLjk4Mi0xMS4zNDZsNy40MTgtMTM2Yy4zNzUtNi44NzQtNS4wOTgtMTIuNjU0LTExLjk4Mi0xMi42NTRoLTYzLjM4M2MtNi44ODQgMC0xMi4zNTYgNS43OC0xMS45ODEgMTIuNjU0eicvPjwvc3ZnPg==)}.toast-container.toast-top-center .ngx-toastr,.toast-container.toast-bottom-center .ngx-toastr{width:300px;margin-left:auto;margin-right:auto}.toast-container.toast-top-full-width .ngx-toastr,.toast-container.toast-bottom-full-width .ngx-toastr{width:96%;margin-left:auto;margin-right:auto}.ngx-toastr{background-color:#030303;pointer-events:auto}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4}@media all and (max-width:240px){.toast-container .ngx-toastr.div{padding:8px 8px 8px 50px;width:11em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px)and (max-width:480px){.toast-container .ngx-toastr.div{padding:8px 8px 8px 50px;width:18em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px)and (max-width:768px){.toast-container .ngx-toastr.div{padding:15px 15px 15px 50px;width:25em}}
