@import"https://fonts.googleapis.com/css2?family=Quicksand:wght@300;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Quicksand:wght@300&display=swap";*{font-family:Quicksand,sans-serif}.welcome-text{text-align:center;margin-left:5%;margin-top:10vh;max-width:600px}.welcome-text h1{font-size:3em;font-weight:700;color:#fff440}.welcome-text p{font-size:1.2em;color:#ccc}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 768px){.login{width:90%}.ring{display:none}.welcome-text{text-align:center;margin-bottom:20px}.welcome-text h1{font-size:2.5em}.welcome-text p{font-size:1.1em}}.auth-signin-wrapper{position:fixed;top:0;left:0;width:100%;height:100vh;background:#111!important;display:flex;justify-content:center;align-items:center;z-index:9999;margin:0;padding:0;font-family:Quicksand,sans-serif}.auth-signin-wrapper *{margin:0;padding:0;box-sizing:border-box;font-family:Quicksand,sans-serif}.auth-container{display:flex;width:100%;height:80vh;align-items:center;justify-content:center;position:relative;padding:0 50px}.auth-left-text{flex:1;color:#fff;font-size:2em;max-width:400px;padding-right:40px;animation:authFadeIn 2s ease-in-out}.auth-left-text h3{font-size:1.5em;color:#fffd44;margin-bottom:10px}.auth-left-text p{line-height:1.6;color:#ddd}@keyframes authFadeIn{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.auth-ring{position:relative;width:420px;height:420px;display:flex;justify-content:center;align-items:center}.auth-ring i{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid #fff;transition:.5s}.auth-ring i:nth-child(1){border-radius:38% 62% 63% 37%/41% 44% 56% 59%;animation:authAnimate 6s linear infinite}.auth-ring i:nth-child(2){border-radius:41% 44% 56% 59%/38% 62% 63% 37%;animation:authAnimate 4s linear infinite}.auth-ring i:nth-child(3){border-radius:41% 44% 56% 59%/38% 62% 63% 37%;animation:authAnimate2 10s linear infinite}.auth-ring:hover i{border:6px solid var(--clr);filter:drop-shadow(0 0 20px var(--clr))}@keyframes authAnimate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes authAnimate2{0%{transform:rotate(360deg)}to{transform:rotate(0)}}.auth-login{position:absolute;width:260px;height:75%;display:flex;justify-content:center;align-items:center;flex-direction:column;gap:20px}.auth-login h2{font-size:1.8em;color:#fff}.auth-input-box{position:relative;width:100%;margin-bottom:15px}.auth-input-box input{position:relative;width:100%;height:56px;padding:0 20px;background:transparent;border:2px solid #fff;border-radius:40px;font-size:1.1em;color:#fff;box-shadow:none;outline:none}.auth-input-box input[type=submit],.auth-input-box input::placeholder{color:#ffffffbf}.auth-links{position:relative;width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 20px}.auth-links a{color:#fff;text-decoration:none}.auth-btn:hover{background:linear-gradient(90deg,#fffd44,#ff0057);box-shadow:0 0 15px #fffd44cc,0 0 25px #ff005799;transform:translateY(-2px)}.auth-btn{height:60px;padding:0 28px;font-size:1.2em;font-weight:600;border-radius:50px;border:none;background:linear-gradient(90deg,#ff0057,#fffd44);color:#fff;cursor:pointer;box-shadow:0 0 15px #ff005780,0 0 25px #fffd4466;transition:all .3s ease-in-out;box-sizing:border-box;width:100%}.auth-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.spinner{width:20px;height:20px;border:3px solid white;border-top:3px solid transparent;border-radius:50%;animation:spin .8s linear infinite;margin:auto}@keyframes spin{to{transform:rotate(360deg)}}.auth-error{margin-top:10px;padding:12px 20px;background-color:#ffeaea;color:#d32f2f;border:1px solid #f5c6cb;border-radius:10px;font-size:15px;font-weight:500;width:100%;text-align:center;animation:slideDown .3s ease-in-out;box-shadow:0 2px 8px #0000001a}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.dashboard-container{padding:1rem}.dashboard-header{margin-bottom:1rem}.dashboard-content{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dashboard-card{background:var(--bg-secondary);border-radius:8px;padding:1rem;box-shadow:var(--shadow)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-top:1rem}.stat-item{background:var(--bg-tertiary);padding:.75rem;border-radius:6px;text-align:center}.stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.85rem;color:var(--text-secondary)}.admin-sidebar{width:280px;height:100vh;background:linear-gradient(180deg,#004ff9,#000)!important;color:#fff!important;display:flex;flex-direction:column;transition:width .3s ease;position:fixed;left:0;top:0;z-index:1000;font-family:Poppins,sans-serif;font-size:.97rem;box-shadow:2px 0 8px #00000026}.admin-sidebar-collapsed{width:80px}.admin-sidebar-header{padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.08);background:transparent;position:sticky;top:0;z-index:10;height:64px;gap:0}.admin-logo{height:48px;width:auto;object-fit:contain;margin:0;max-width:220px}.admin-sidebar-header h2{color:#fff!important;font-size:1.25rem;font-weight:600;margin:0;letter-spacing:.5px}.admin-sidebar-toggle{background:#ffffff1a;border:none;color:#fff!important;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s ease;min-width:32px;height:32px;flex-shrink:0}.admin-sidebar-toggle:hover{background-color:#fff3}.admin-sidebar-profile{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;background-color:#ffffff1a;margin-bottom:16px}.admin-profile-image{width:40px;height:40px;border-radius:50%;background-color:#fff3;display:flex;align-items:center;justify-content:center;color:#fff!important}.admin-profile-info{flex:1}.admin-profile-name{font-weight:600;margin:0;font-size:.9rem;color:#fff!important}.admin-profile-role{margin:0;font-size:.8rem;color:#ffffffb3!important}.admin-sidebar-nav{flex:1;overflow-y:auto;padding:1rem 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.admin-sidebar-nav::-webkit-scrollbar{width:6px}.admin-sidebar-nav::-webkit-scrollbar-track{background:transparent}.admin-sidebar-nav::-webkit-scrollbar-thumb{background-color:#fff3;border-radius:3px}.admin-sidebar-nav::-webkit-scrollbar-thumb:hover{background-color:#ffffff4d}.admin-sidebar-item{display:flex;align-items:center;padding:.75rem 1.5rem;color:#ffffffe0!important;text-decoration:none;cursor:pointer;transition:all .2s ease;gap:.75rem;font-size:.97em}.admin-sidebar-item:hover{background-color:#004ff921;color:#fff!important}.admin-sidebar-item.active{background-color:#004ff92e;color:#fff!important;font-weight:500}.admin-sidebar-item svg{min-width:20px;font-size:1.15em}.admin-sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.08);background:transparent;position:sticky;bottom:0;z-index:10}.admin-sidebar-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:12px 0}@media (max-width: 768px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar-collapsed{transform:translate(0)}}.navbar{height:64px;width:100%;background:linear-gradient(to right,#ff4e50,#ffa801,#fd0);display:flex;align-items:center;justify-content:space-between;padding:0 24px;color:#1a1a1a;font-family:Poppins,sans-serif;font-weight:500;box-shadow:0 2px 6px #0003;position:sticky;top:0;z-index:10}.navbar .brand{font-size:1.2rem;font-weight:600;color:#1a1a1a}.navbar .nav-right{display:flex;align-items:center;gap:16px}.navbar .nav-item{color:#1a1a1a;text-decoration:none;font-weight:500;transition:color .3s ease}.navbar .nav-item:hover{color:#fff}:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #ffffff;--text-primary: #333333;--text-secondary: #666666;--border-color: #dddddd;--hover-bg: #f0f0f0;--active-bg: #e0e0e0;--shadow: 0 2px 4px rgba(0, 0, 0, .1)}:root[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2a2a2a;--bg-tertiary: #333333;--text-primary: #ffffff;--text-secondary: #cccccc;--border-color: #404040;--hover-bg: #3a3a3a;--active-bg: #404040;--shadow: 0 2px 4px rgba(0, 0, 0, .2)}body{margin:0;padding:0;overflow-x:hidden;background-color:var(--bg-primary)}.layout{min-height:100vh;display:flex;flex-direction:column;width:100%;background-color:var(--bg-primary);color:var(--text-primary)}.navbar{background:linear-gradient(to right,#004ff9,#000);color:var(--text-primary);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;right:0;z-index:1000;height:60px;box-shadow:var(--shadow)}.navbar-brand{font-size:1.5rem;font-weight:700}.navbar-right{display:flex;align-items:center;gap:1rem}.theme-toggle{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:background-color .2s}.theme-toggle:hover{background-color:var(--hover-bg)}.main-container{display:flex;flex:1 1 auto;margin-top:60px;position:relative;height:calc(100vh - 60px)}.sidebar{width:280px;background-color:var(--bg-secondary);color:var(--text-primary);padding:1rem;overflow-y:auto;position:fixed;left:0;top:60px;bottom:0;z-index:900;transition:all .3s ease}.content{flex:1;background-color:var(--bg-primary);padding:1.5rem 3rem 2.5rem 18px;text-align:left;display:block;height:100%;overflow-y:auto;box-sizing:border-box;margin-left:260px;transition:margin-left .3s ease}.main-container.sidebar-collapsed .content{margin-left:80px}.sidebar-menu{display:flex;flex-direction:column;gap:.5rem}.menu-item-wrapper{position:relative}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;border-radius:4px;transition:background-color .2s}.menu-header:active{background-color:var(--hover-bg)}.arrow{font-size:.8rem;transition:transform .2s}.arrow.open{transform:rotate(180deg)}.submenu{margin-left:1rem;margin-top:.25rem;display:flex;flex-direction:column;gap:.25rem}.menu-item{padding:.5rem 1rem;cursor:pointer;border-radius:4px;transition:all .2s;color:var(--text-primary);text-decoration:none;display:block}.menu-item:active{background-color:var(--hover-bg)}.menu-item.active{background-color:var(--active-bg);font-weight:500}*{margin:0;padding:0;box-sizing:border-box}.admin-navbar-profile{display:flex;align-items:center;gap:10px;background:#1e88e514;border-radius:20px;padding:4px 14px 4px 8px;border:none;cursor:pointer;transition:background-color .2s ease}.admin-navbar-profile:hover{background:#1e88e526}.admin-navbar-profile:active{background:#1e88e533}.admin-navbar-avatar{background:#1e88e5;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.admin-navbar-info{display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.admin-navbar-name{font-weight:600;font-size:1rem;color:#1e88e5}.admin-navbar-role{font-size:.85rem;color:#888;margin-top:-2px}:root[data-theme=dark] .admin-navbar-profile{background:#1e88e526}:root[data-theme=dark] .admin-navbar-profile:hover{background:#1e88e540}:root[data-theme=dark] .admin-navbar-profile:active{background:#1e88e54d}:root[data-theme=dark] .admin-navbar-role{color:#aaa}.user-management-container{padding:.5rem .2rem;max-width:900px;max-height:80%;margin:0 auto;background:#f4f7fb;color:#232a33;font-family:Segoe UI,Roboto,Arial,sans-serif;font-size:.74rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.header h2{font-size:.74rem;font-weight:600;color:#23272f;letter-spacing:-1px}.header-actions{display:flex;gap:.1rem}.action-btn{display:flex;align-items:center;gap:.35rem;padding:.15rem .35rem;border:1px solid #e0e3ea;border-radius:3px;background:#fff;color:#2a3a4b;font-size:.74rem;font-weight:500;cursor:pointer;transition:background .18s,border .18s,color .18s,box-shadow .18s;box-shadow:none}.action-btn.primary{background:#2563eb;color:#fff;border:1px solid #2563eb}.action-btn.danger{background:#fff0f0;color:#d32f2f;border:1px solid #f3bcbc}.action-btn:hover,.action-btn:focus{background:#f0f4fa;color:#174ea6;border-color:#b6c6e3}.action-btn.primary:hover,.action-btn.primary:focus{background:#174ea6;color:#fff;border-color:#174ea6}.action-btn.danger:hover,.action-btn.danger:focus{background:#ffeaea;color:#b71c1c;border-color:#e57373}.stats-container{display:flex;gap:.14rem;margin-bottom:.3rem}.stat-card{flex:1;background:#f7faff;border:1px solid #dbeafe;border-radius:2px;padding:.14rem .1rem;box-shadow:none;display:flex;flex-direction:column;align-items:flex-start;transition:border .18s,box-shadow .18s,background .18s,transform .18s;cursor:pointer;min-width:0}.stat-card h3{font-size:.45rem;font-weight:500;color:#4b5563;margin-bottom:.05rem}.stat-value{font-size:.54rem;font-weight:700;color:#1e293b}.stat-card:hover,.stat-card:focus{background:#e0e7ef;border-color:#a5b4fc;box-shadow:0 2px 12px #2563eb14;transform:translateY(-2px) scale(1.03)}.stat-card:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.table-card{background:#fff;border-radius:3px;border:1px solid #e0e3ea;box-shadow:none;overflow:hidden}.table-actions{display:flex;justify-content:flex-end;align-items:center;padding:.1rem;background:#f4f6fa;border-bottom:1px solid #e0e3ea;gap:.1rem}.search-wrapper{position:relative;width:100px}.search-icon{position:absolute;top:50%;left:.7rem;transform:translateY(-50%);color:#b0b8c9}.search-input{width:100%;padding:.2rem .2rem .2rem .9rem;border:1px solid #e0e3ea;border-radius:2px;background:#f8f9fb;color:#23272f;font-size:.74rem;transition:border .18s}.search-input:focus{border-color:#2563eb;outline:none}.filters-panel{display:flex;gap:.5rem;padding:.3rem .4rem;background:#f8f9fb;border-bottom:1px solid #e0e3ea}.filter-group{display:flex;flex-direction:column;gap:.2rem}.filter-group label{font-size:.5rem;color:#6b7280;font-weight:500}.filter-group select{padding:.12rem .3rem;border:1px solid #e0e3ea;border-radius:2px;background:#fff;color:#23272f;font-size:.74rem;transition:border .18s}.filter-group select:focus{border-color:#2563eb;outline:none}.actions{display:flex;gap:.35rem}.action-icon-btn{background:none;border:none;cursor:pointer;padding:.08rem;border-radius:2px;transition:background .18s;display:flex;align-items:center;justify-content:center}.action-icon-btn svg{color:#2563eb;font-size:1rem}.action-icon-btn.danger svg{color:#d32f2f}.action-icon-btn:hover{background:#e8f0fe}.action-icon-btn.danger:hover{background:#ffeaea}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#2c33492e;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:3px;box-shadow:0 4px 24px #2c33491a;width:100%;max-width:200px;animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideIn{0%{transform:translateY(-24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:.35rem;border-bottom:1px solid #e0e3ea}.modal-header h3{font-size:.6rem;font-weight:600;color:#23272f}.modal-close-btn{background:none;border:none;color:#b0b8c9;font-size:1.3rem;cursor:pointer;border-radius:50%;transition:background .18s;padding:.15rem}.modal-close-btn:hover{background:#f0f4fa;color:#2563eb}.delete-dialog-content{padding:.35rem;text-align:center}.warning-icon{color:#f59e42;margin-bottom:.5rem}.delete-dialog-content h4{font-size:.58rem;font-weight:600;color:#d32f2f;margin-bottom:.4rem}.delete-dialog-content p{color:#6b7280;font-size:.5rem;margin-bottom:.35rem}.delete-dialog-actions{display:flex;justify-content:center;gap:.3rem}@media (max-width: 700px){.stats-container{flex-direction:column;gap:.6rem}}@media (max-width: 600px){.user-management-container{padding:.7rem .15rem}.header{flex-direction:column;gap:.6rem;align-items:flex-start}.stats-container{flex-direction:column;gap:.6rem}.table-actions{flex-direction:column;gap:.5rem;align-items:flex-start}.filters-panel{flex-direction:column;gap:.5rem}}:root[data-theme=dark] .user-management-container{background:#181c23;color:#e5e7eb}:root[data-theme=dark] .header,:root[data-theme=dark] .table-card,:root[data-theme=dark] .filters-panel{background:#23272f;border-color:#2d323b}:root[data-theme=dark] .stat-card{background:#23272f;border-color:#2d323b;color:#e5e7eb}:root[data-theme=dark] .stat-card h3{color:#b0b8c9}:root[data-theme=dark] .stat-value{color:#60a5fa}:root[data-theme=dark] .stat-card:hover,:root[data-theme=dark] .stat-card:focus{background:#232b3b;border-color:#3b4252;box-shadow:0 2px 12px #60a5fa1a}:root[data-theme=dark] .table-card{background:#23272f;border-color:#2d323b}:root[data-theme=dark] .users-table{background:#23272f}:root[data-theme=dark] .users-table th{background:#232b3b;color:#e5e7eb}:root[data-theme=dark] .users-table td{color:#e5e7eb}:root[data-theme=dark] .users-table tbody tr:hover{background:#232b3b}:root[data-theme=dark] .search-input,:root[data-theme=dark] .filter-group select{background:#181c23;color:#e5e7eb;border-color:#2d323b}:root[data-theme=dark] .modal-content{background:#23272f;color:#e5e7eb}:root[data-theme=dark] .modal-header{border-bottom:1px solid #2d323b}:root[data-theme=dark] .action-btn,:root[data-theme=dark] .action-btn.primary,:root[data-theme=dark] .action-btn.danger{background:#23272f;color:#e5e7eb;border-color:#2d323b}:root[data-theme=dark] .action-btn.primary{background:#2563eb;color:#fff;border-color:#2563eb}:root[data-theme=dark] .action-btn.danger{background:#3b2323;color:#f87171;border-color:#7f1d1d}:root[data-theme=dark] .action-btn:hover,:root[data-theme=dark] .action-btn:focus{background:#181c23;color:#60a5fa;border-color:#2563eb}:root[data-theme=dark] .action-btn.primary:hover,:root[data-theme=dark] .action-btn.primary:focus{background:#174ea6;color:#fff;border-color:#174ea6}:root[data-theme=dark] .action-btn.danger:hover,:root[data-theme=dark] .action-btn.danger:focus{background:#7f1d1d;color:#fff;border-color:#f87171}:root[data-theme=dark] .modal-close-btn{color:#b0b8c9}:root[data-theme=dark] .delete-dialog-content h4{color:#f87171}:root[data-theme=dark] .delete-dialog-content p{color:#b0b8c9}:root[data-theme=dark] .user-loader-spinner{border:4px solid #2d323b;border-top:4px solid #60a5fa}:root[data-theme=dark] .user-loader-text{color:#60a5fa}.toast-container{position:fixed;top:20px;right:20px;z-index:9999}.toast{display:flex;align-items:center;padding:12px 24px;margin-bottom:10px;border-radius:4px;box-shadow:0 2px 5px #0003;animation:slideIn .3s ease-in-out;min-width:300px}.toast-success{background-color:#d4edda;color:#155724;border-left:4px solid #28a745}.toast-error{background-color:#f8d7da;color:#721c24;border-left:4px solid #dc3545}.toast-warning{background-color:#fff3cd;color:#856404;border-left:4px solid #ffc107}.toast-icon{margin-right:12px;display:flex;align-items:center}.toast-message{flex-grow:1}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.table-responsive{width:100%;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:6px;overflow:hidden;font-size:.95rem}.data-table th,.data-table td{padding:.7rem .5rem;text-align:left;border-bottom:1px solid #f0f1f4;font-size:.95rem;color:#23272f}.data-table th{background:#f4f6fa;font-weight:600;color:#23272f;font-size:1rem;letter-spacing:.01em;cursor:pointer;-webkit-user-select:none;user-select:none}.data-table tbody tr:hover{background:#f0f4fa;transition:background .18s}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-cell{width:40px;text-align:center}.checkbox-wrapper{display:flex;align-items:center;justify-content:center}.status-badge{display:inline-block;padding:.1rem .6rem;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:capitalize;letter-spacing:.01em}:root[data-theme=dark] .data-table{background:#23272f}:root[data-theme=dark] .data-table th{background:#232b3b;color:#e5e7eb}:root[data-theme=dark] .data-table td{color:#e5e7eb}:root[data-theme=dark] .data-table tbody tr:hover{background:#232b3b}:root[data-theme=dark] .status-badge.active{background:#193c2f;color:#34d399}:root[data-theme=dark] .status-badge.inactive{background:#3b2323;color:#f87171}:root[data-theme=dark] .no-data{color:#b0b8c9}.login-search{background-image:url("data:image/svg+xml;utf8,<svg fill='%23b0b8c9' height='16' viewBox='0 0 24 24' width='16' xmlns='http://www.w3.org/2000/svg'><path d='M15.5 14h-.79l-.28-.27A6.471 6.471 0 0016 9.5 6.5 6.5 0 109.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99a1 1 0 001.41-1.41l-4.99-5zM9.5 14C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z'/></svg>");background-repeat:no-repeat;background-position:.5rem center;padding-left:2rem}.access-control-container{padding:1rem;max-width:1200px;margin:0 auto;color:var(--text-primary)}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.page-header h2{margin:0;font-size:1.4rem;color:var(--text-primary);font-weight:600}.back-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-primary);transition:all .2s;font-weight:500;font-size:.9rem}.back-button:hover{background:var(--bg-tertiary);transform:translate(-2px)}.form-card{background:var(--bg-secondary);border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1rem;border:1px solid var(--border-color)}.role-permission-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{display:flex;flex-direction:column;gap:.75rem}.form-section h3{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600;padding-bottom:.25rem;border-bottom:1px solid var(--border-color)}.form-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;width:100%;max-width:300px;background:var(--bg-primary);color:var(--text-primary)}.form-select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.module-section{background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-color);overflow:hidden;margin-bottom:1rem}.module-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-secondary);cursor:pointer;transition:all .2s;border-bottom:1px solid var(--border-color)}.module-header:hover{background:var(--bg-tertiary)}.module-header-left{display:flex;align-items:center;gap:.5rem}.module-header-right{display:flex;align-items:center}.module-header svg{color:var(--text-primary);transition:transform .2s}.module-title{margin:0;font-size:1rem;font-weight:500;color:var(--text-primary)}.select-all-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s;font-size:.85rem}.select-all-label:hover{background:#0000000d}.select-all-label input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:#007bff}.select-all-label span{font-size:.9rem;color:var(--text-primary)}.permissions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;padding:1.25rem;background:var(--bg-primary)}.permission-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:1px solid var(--border-color);border-radius:6px;transition:all .2s;background:var(--bg-secondary);min-width:0}.permission-card:hover{border-color:#007bff;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.permission-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#007bff}.permission-label{display:flex;flex-direction:column;gap:.25rem;cursor:pointer;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.permission-module{font-weight:500;color:#333}.permission-action{color:#666;font-size:.9rem}.form-actions{display:flex;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.cancel-btn{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-primary);transition:all .2s;font-weight:500;font-size:.9rem}.cancel-btn:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.submit-btn{padding:.5rem 1rem;background:#007bff;border:none;border-radius:4px;cursor:pointer;color:#fff;transition:all .2s;font-weight:500;font-size:.9rem}.submit-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.filter-select{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;min-width:150px;background-color:var(--bg-primary);color:var(--text-primary)}.action-btn.small{padding:.25rem .5rem;font-size:.875rem}.action-btn.danger{background-color:#dc3545;color:#fff}:root[data-theme=dark] .form-card{background:var(--bg-secondary)}:root[data-theme=dark] .module-section{background:var(--bg-primary)}:root[data-theme=dark] .module-header{background:var(--bg-secondary)}:root[data-theme=dark] .permissions-grid{background:var(--bg-primary)}:root[data-theme=dark] .permission-card{background:var(--bg-secondary)}:root[data-theme=dark] .permission-card:hover{border-color:#0056b3}:root[data-theme=dark] .select-all-label:hover{background:#ffffff0d}.permissions-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.permissions-list li{background:#f0f0f0;padding:.25rem .75rem;border-radius:4px;font-size:.9rem;color:#666}.no-permissions{color:#999;font-style:italic}@media (max-width: 1200px){.permissions-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.permissions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.permissions-grid{grid-template-columns:1fr}}.permissions-table-container{overflow-x:auto;margin:.5rem 0;border-radius:4px;border:1px solid var(--border-color)}.permissions-table{width:100%;border-collapse:collapse;background:var(--bg-primary);font-size:.9rem}.permissions-table th,.permissions-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.permissions-table th{background:var(--bg-secondary);font-weight:600;white-space:nowrap;font-size:.85rem}.permissions-table tbody tr:hover{background:var(--bg-tertiary)}.checkbox-column{width:40px;text-align:center}.permission-checkbox{width:14px;height:14px;cursor:pointer;accent-color:#007bff}.date-input{padding:.35rem .5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;width:100%;min-width:110px}.date-input:disabled{background:var(--bg-tertiary);cursor:not-allowed;opacity:.7}.date-input:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 2px #007bff40}:root[data-theme=dark] .permissions-table th{background:var(--bg-secondary)}:root[data-theme=dark] .permissions-table tbody tr:hover{background:var(--bg-tertiary)}:root[data-theme=dark] .date-input{background:var(--bg-primary);color:var(--text-primary)}:root[data-theme=dark] .date-input:disabled{background:var(--bg-tertiary)}.search-wrapper{position:relative;width:300px}.search-input{width:100%;padding:.5rem .5rem .5rem 2rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-primary);pointer-events:none}.table-responsive{overflow-x:auto;margin-top:1rem}.access-control-table{width:100%;border-collapse:collapse;background-color:var(--bg-secondary);border-radius:8px;overflow:hidden}.access-control-table th,.access-control-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.access-control-table th{background-color:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.access-control-table tbody tr:hover{background-color:var(--hover-bg)}.table-actions{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}:root[data-theme=dark] .search-input{background-color:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}:root[data-theme=dark] .search-icon{color:var(--text-primary)}:root[data-theme=dark] .access-control-table{background-color:var(--bg-secondary)}:root[data-theme=dark] .access-control-table th{background-color:var(--bg-tertiary);color:var(--text-primary)}:root[data-theme=dark] .access-control-table th,:root[data-theme=dark] .access-control-table td{border-bottom-color:var(--border-color)}:root[data-theme=dark] .access-control-table tbody tr:hover{background-color:var(--hover-bg)}:root[data-theme=dark] .table-actions{background-color:var(--bg-tertiary);border-bottom-color:var(--border-color)}.table-card{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow);overflow:hidden}.table-actions{display:flex;gap:1rem;margin-bottom:1rem;align-items:center;background:var(--bg-tertiary);padding:1rem;border-bottom:1px solid var(--border-color)}.search-input{flex:1;padding:.5rem .5rem .5rem 2rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary)}.action-btn{display:flex;align-items:center;gap:.5rem;background-color:var(--bg-tertiary);color:var(--text-primary);padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.action-btn.primary{background-color:#007bff;color:#fff}.action-btn:hover{opacity:.9}.actions{display:flex;gap:.5rem}.action-icon-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center}.action-icon-btn svg{color:#004ff9}.action-icon-btn.danger svg{color:#dc3545}.action-icon-btn:hover{background-color:#004ff91a}.action-icon-btn.danger:hover{background-color:#dc35451a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--bg-primary);border-radius:8px;padding:1.5rem;width:100%;max-width:500px;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{margin:0;color:var(--text-primary)}.modal-close-btn{background:none;border:none;cursor:pointer;color:var(--text-primary);padding:.25rem}.modal-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-primary);font-weight:500}.form-group input{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.cancel-btn,.submit-btn,.delete-btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.cancel-btn{background-color:var(--bg-tertiary);color:var(--text-primary)}.submit-btn{background-color:#007bff;color:#fff}.delete-btn{background-color:#dc3545;color:#fff}.delete-modal .modal-content{max-width:400px}.delete-warning{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;padding:1rem 0}.warning-icon{color:#dc3545;font-size:2rem}.warning-text{color:#666;font-size:.9rem}.toast-container{position:fixed;top:1rem;right:1rem;z-index:1000}:root[data-theme=dark] .data-table td{color:#fff}:root[data-theme=dark] .data-table tbody tr:hover{background-color:#3a3a3a}:root[data-theme=dark] .table-card{background:#9a9a9a!important}.preview-section{margin:2rem 0;padding:1rem;background:var(--bg-tertiary);border-radius:8px}.preview-section h3{margin-bottom:1rem;color:var(--text-primary)}.preview-table{width:100%;border-collapse:collapse;background-color:var(--bg-primary);border-radius:4px;overflow:hidden}.preview-table th,.preview-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color)}.preview-table th{background-color:var(--bg-secondary);font-weight:600;color:var(--text-primary)}.preview-table td{color:var(--text-primary)}.preview-table td:nth-child(4){font-weight:600;color:#007bff}.role-profiles-table{margin:20px 0;overflow-x:auto}.role-profiles-table table{width:100%;border-collapse:collapse;background-color:#fff;box-shadow:0 1px 3px #0000001a;border-radius:8px}.role-profiles-table th,.role-profiles-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e0e0e0}.role-profiles-table th{background-color:#f5f5f5;font-weight:600;color:#333}.role-profiles-table tr:hover{background-color:#f8f9fa}.permissions-list{list-style:none;padding:0;margin:0}.permissions-list li{padding:4px 0;color:#555;font-size:.9em}.permissions-list li:before{content:"•";color:#2196f3;font-weight:700;margin-right:8px}.role-profiles-table td:first-child{font-weight:600;color:#1976d2}.role-profiles-table td:last-child{text-align:center;font-weight:600;color:#666}.access-control-container{padding:2rem;color:var(--text-primary)}.access-control-container h2{margin-bottom:1.5rem;color:var(--text-primary)}.assignment-form{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem}.roles-container{margin:2rem 0}.roles-container h3{margin-bottom:1rem;color:var(--text-primary)}.roles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:4px}.role-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-primary);border-radius:4px}.role-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.role-item label{cursor:pointer;color:var(--text-primary)}.submit-btn{background-color:#007bff;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.submit-btn:hover{background-color:#0056b3}.assignments-table{margin-top:2rem;overflow-x:auto}.assignments-table table{width:100%;border-collapse:collapse;background-color:var(--bg-secondary);box-shadow:var(--shadow);border-radius:8px}.assignments-table th,.assignments-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.assignments-table th{background-color:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.assignments-table tr:hover{background-color:var(--hover-bg)}.assignments-table td:first-child{font-weight:500;color:var(--text-primary)}.assignments-table td:nth-child(4){font-weight:600;color:#007bff}.module-access-container{padding:2rem;color:var(--text-primary)}.module-access-container h2{margin-bottom:1.5rem;color:var(--text-primary);font-size:1.5rem;font-weight:600}.module-access-actions{display:flex;justify-content:flex-end;margin-bottom:1.5rem}.module-access-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease}.module-access-btn.primary{background-color:#004ff9;color:#fff}.module-access-btn.primary:hover{background-color:#0039b3}.module-access-table{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow);overflow:hidden}.module-access-table table{width:100%;border-collapse:collapse}.module-access-table th,.module-access-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.module-access-table th{background-color:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.module-access-table tr:hover{background-color:var(--hover-bg)}.role-tags{display:flex;flex-wrap:wrap;gap:.5rem}.role-tag{background-color:#004ff91a;color:#004ff9;padding:.25rem .75rem;border-radius:16px;font-size:.85rem;font-weight:500}.status-badge.inactive{background-color:#ff52521a;color:#ff5252}.action-buttons{display:flex;gap:.5rem}.action-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center}.action-btn.edit svg{color:#004ff9}.action-btn.delete svg{color:#ff5252}.action-btn:hover{background-color:var(--hover-bg)}:root[data-theme=dark] .module-access-table td{color:#fff}:root[data-theme=dark] .module-access-table tr:hover{background-color:#3a3a3a}:root[data-theme=dark] .module-access-table{background:#2a2a2a}:root[data-theme=dark] .role-tag{background-color:#004ff933}.login-container{padding:.7rem .5rem;max-width:900px;margin:1rem auto;background:#f9fbfd;font-family:Segoe UI,Roboto,Arial,sans-serif;font-size:.84rem;color:#232a33;border-radius:10px;box-shadow:0 2px 12px #2c33491a}.login-title{font-size:1.1rem;color:#174ea6;margin-bottom:.8rem;font-weight:600}.login-controls{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.5rem;margin-bottom:.8rem}.login-search,.login-filter{padding:.4rem .5rem;border:1px solid #d4d8e1;border-radius:5px;font-size:.84rem;background:#fff;flex:1 1 180px;box-shadow:0 1px 2px #2c33490d}.login-search{background-image:url("data:image/svg+xml;utf8,<svg fill='%23b0b8c9' height='16' viewBox='0 0 24 24' width='16' xmlns='http://www.w3.org/2000/svg'><path d='M15.5 14h-.79l-.28-.27A6.471 6.471 0 0016 9.5 6.5 6.5 0 109.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99a1 1 0 001.41-1.41l-4.99-5zM9.5 14C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z'/></svg>");background-repeat:no-repeat;background-position:.5rem center;padding-left:2rem}.login-table-wrapper{overflow-x:auto}.login-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.login-table th,.login-table td{padding:.5rem;text-align:left;border-bottom:1px solid #f0f1f4;font-size:.75rem}.login-table th{background:#f1f3f7;font-weight:600;color:#174ea6}.login-table tbody tr:nth-child(2n){background:#f8fafc}.login-table tbody tr:hover{background:#e6f0fb}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.72rem;font-weight:600;text-transform:capitalize}.status-badge.success{background:#e6f9ec;color:#219653}.status-badge.failed{background:#fff0f0;color:#d32f2f}.login-loading,.login-error{text-align:center;margin:1.5rem 0;font-size:.9rem;font-weight:600}.login-loading{color:#2563eb}.login-error{color:#d32f2f}@media (max-width: 600px){.login-controls{flex-direction:column;gap:.5rem}.login-table{font-size:.7rem}}:root[data-theme=dark] .login-container{background:#181c23;color:#e5e7eb;box-shadow:0 2px 16px #14142840}:root[data-theme=dark] .login-title{color:#60a5fa}:root[data-theme=dark] .login-search,:root[data-theme=dark] .login-filter{background:#23272f;color:#e5e7eb;border:1px solid #2d323b}:root[data-theme=dark] .login-search::placeholder{color:#b0b8c9}:root[data-theme=dark] .login-table-wrapper{background:transparent}:root[data-theme=dark] .login-table{background:#23272f;color:#e5e7eb}:root[data-theme=dark] .login-table th{background:#232b3b;color:#60a5fa}:root[data-theme=dark] .login-table td{color:#e5e7eb}:root[data-theme=dark] .login-table tbody tr:nth-child(2n){background:#20232a}:root[data-theme=dark] .login-table tbody tr:hover{background:#2a3140}:root[data-theme=dark] .status-badge.success{background:#193c2f;color:#34d399}:root[data-theme=dark] .status-badge.failed{background:#3b2323;color:#f87171}:root[data-theme=dark] .login-loading{color:#60a5fa}:root[data-theme=dark] .login-error{color:#f87171}.audit-logs-container{padding:2rem;color:var(--text-primary)}.audit-logs-container h2{margin-bottom:1.5rem;color:var(--text-primary);font-size:1.5rem;font-weight:600}.audit-logs-filters{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.search-box{display:flex;align-items:center;background:var(--bg-secondary);border-radius:8px;padding:.5rem 1rem;flex:1;max-width:400px;border:1px solid var(--border-color)}.search-box svg{color:var(--text-secondary);margin-right:.5rem}.search-box input{background:none;border:none;color:var(--text-primary);width:100%;outline:none}.search-box input::placeholder{color:var(--text-secondary)}.filter-buttons{display:flex;gap:.5rem}.filter-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.filter-btn:hover{background:var(--hover-bg)}.filter-btn.warning{background:#ff52521a;color:#ff5252}.filter-btn.warning:hover{background:#ff525233}.audit-logs-table{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow);overflow:hidden}.audit-logs-table table{width:100%;border-collapse:collapse}.audit-logs-table th,.audit-logs-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.audit-logs-table th{background-color:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.audit-logs-table tr:hover{background-color:var(--hover-bg)}.status-badge{padding:.25rem .75rem;border-radius:16px;font-size:.85rem;font-weight:500}.status-badge.success{background-color:#00e6761a;color:#00e676}.status-badge.failed{background-color:#ff52521a;color:#ff5252}.status-badge.active{background-color:#00e6761a;color:#00e676}.status-badge.idle{background-color:#ffc1071a;color:#ffc107}.session-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow)}.stat-card h3{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.stat-card p{color:var(--text-primary);font-size:1.5rem;font-weight:600}.session-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-bottom:1.5rem}.access-testing-controls{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.test-inputs{display:flex;gap:1rem;flex-wrap:wrap}.test-select{padding:.5rem 1rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);min-width:200px}.test-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.test-btn.primary{background:#004ff9;color:#fff}.test-btn.primary:hover{background:#0039b3}.test-btn:disabled{opacity:.5;cursor:not-allowed}:root[data-theme=dark] .audit-logs-table td{color:#fff}:root[data-theme=dark] .audit-logs-table tr:hover{background-color:#3a3a3a}:root[data-theme=dark] .audit-logs-table,:root[data-theme=dark] .search-box,:root[data-theme=dark] .filter-btn,:root[data-theme=dark] .stat-card,:root[data-theme=dark] .test-select{background:#2a2a2a}.reason-column{font-size:.85rem;max-width:400px;white-space:normal;word-wrap:break-word}.user-details-container{padding:.5rem;max-width:1250px;margin-left:20px;font-family:sans-serif;font-size:.85rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.3rem 0}.header-left{display:flex;align-items:center;gap:.5rem}.back-button{display:flex;align-items:center;gap:.4rem;padding:.25rem .6rem;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:.75rem}.back-button:hover{background:var(--hover-bg);border-color:var(--primary-color)}.header-actions{display:flex;gap:.4rem}.action-btn{display:flex;align-items:center;gap:.3rem;padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);font-size:.75rem;cursor:pointer}.action-btn:hover{background:var(--hover-bg);border-color:var(--primary-color)}.action-btn.danger{border-color:var(--border-color);color:var(--text-primary)}.action-btn.danger:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--text-primary)}.user-profile-header{display:flex;align-items:center;gap:1.2rem;padding:.7rem 1.2rem;margin-bottom:.7rem;background:#f8fafd;border-radius:10px;box-shadow:0 2px 12px #2563eb0f;width:100%;min-height:60px}.user-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;box-shadow:0 1px 4px #2c334914}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-basic-info{flex:1;display:flex;flex-direction:column;gap:.2rem}.user-basic-info h3{margin:0;font-size:1.1rem;font-weight:600;color:#232a33}.user-role,.user-email{font-size:.85rem;color:#6b7280;margin:0}.status-switch-container{display:flex;align-items:center;gap:.5rem;margin-top:.2rem;background:#f4f6fa;border-radius:6px;padding:.18rem .7rem .18rem .5rem;box-shadow:0 1px 4px #2c33490f;transition:box-shadow .18s,background .18s}.status-switch-container:hover{box-shadow:0 2px 8px #2563eb1a;background:#e8f0fe}.status-switch-label{font-size:.8rem;color:#232a33;font-weight:500;margin-right:.2rem}.status-switch-state{font-size:.8rem;color:#fff;font-weight:600;margin-left:.2rem;padding:.1rem .5rem;border-radius:4px;background:linear-gradient(90deg,#2563eb 60%,#174ea6);transition:background .18s}.status-switch-state.inactive{background:linear-gradient(90deg,#b0b8c9 60%,#6b7280)}.tabs-container{background:var(--bg-secondary);border-radius:3px;padding:.3rem;width:100%}.tabs{display:flex;gap:.3rem;border-bottom:1px solid var(--border-color);margin-bottom:.3rem}.tab{padding:.3rem .5rem;font-size:.75rem;background:none;border:none;cursor:pointer;color:var(--text-secondary)}.tab.active{color:var(--primary-color);border-bottom:2px solid var(--primary-color)}.tab-content{padding:.3rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.detail-item{display:flex;flex-direction:column;gap:.2rem;padding:.4rem .6rem;background:#f7f7f7;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 1px 2px #0000000d}.detail-item label{display:block;font-size:.65rem;color:var(--text-secondary);text-transform:uppercase}.detail-item p{margin:0;font-size:.8rem;color:var(--text-primary)}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.form-group{display:flex;flex-direction:column;gap:.2rem}.form-group label{display:block;font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;font-weight:500}.form-group input,.form-group select{width:100%;padding:.4rem .6rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.8rem;background:#f7f7f7;color:var(--text-primary);box-shadow:0 1px 2px #0000000d}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 1px rgba(var(--primary-rgb),.1);outline:none}.form-group.checkbox{display:flex;align-items:center;gap:.3rem;margin-top:.2rem}.form-group.checkbox label{margin-left:.3rem;font-size:.7rem;color:#232a33;font-weight:500;display:flex;align-items:center;gap:.2rem}.form-group.checkbox input[type=checkbox]{margin:0;vertical-align:middle;accent-color:#2563eb;width:1rem;height:1rem}.form-actions{display:flex;gap:.4rem;margin-top:.5rem;align-items:center}.cancel-button,.submit-button{padding:.22rem .7rem;font-size:.7rem;border-radius:4px;border:1px solid #e0e3ea;background:#fff;color:#232a33;font-weight:500;cursor:pointer;transition:background .18s,color .18s,border .18s}.cancel-button:hover{background:#f4f6fa;color:#174ea6}.submit-button{background:#2563eb;color:#fff;border:1px solid #2563eb}.submit-button:hover{background:#174ea6;color:#fff;border-color:#174ea6}.status-badge{display:inline-block;padding:.1rem .3rem;border-radius:3px;font-size:.65rem;text-transform:uppercase;font-weight:500}.status-badge.active{background:#28a7451a;color:#28a745}.status-badge.inactive{background:#dc35451a;color:#dc3545}@media (max-width: 768px){.header{flex-direction:column;align-items:flex-start;gap:.4rem}.header-actions{width:100%;justify-content:flex-end}.user-profile-header{flex-direction:column;text-align:center}.tabs{overflow-x:auto;white-space:nowrap}.detail-grid,.form-grid{grid-template-columns:1fr}}.roles-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem 1rem;margin-top:1rem}.role-item{display:flex;align-items:center;padding:.2rem 0;background:none;border:none;border-radius:0}.role-item input[type=checkbox]{margin-right:.5rem;margin-top:0;width:1rem;height:1rem}.role-item label{display:flex;align-items:center;cursor:pointer;flex-direction:row}.role-name{font-weight:400;color:var(--text-primary);margin-bottom:0}.role-description{display:none}.role-item:hover{background:none}.role-item input[type=checkbox]:disabled+label{opacity:.7;cursor:not-allowed}.role-actions{margin-bottom:1rem;display:flex;gap:.5rem;align-items:center}.role-actions .action-btn{margin-right:0;padding:.25rem .6rem;border-radius:3px}.role-name{font-size:.85rem}.user-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;width:100%}.user-loader-spinner{width:38px;height:38px;border:4px solid #e0e3ea;border-top:4px solid #2563eb;border-radius:50%;animation:user-loader-spin 1s linear infinite;margin-bottom:1rem}@keyframes user-loader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-loader-text{font-size:1rem;color:#2563eb;font-weight:500;letter-spacing:.02em}:root[data-theme=dark] .user-profile-header{background:#23272f;box-shadow:0 2px 12px #60a5fa1a;border-radius:10px}:root[data-theme=dark] .tabs-container{background:#181c23;border-radius:8px;box-shadow:0 1px 4px #60a5fa14}:root[data-theme=dark] .tab{color:#b0b8c9}:root[data-theme=dark] .tab.active{color:#60a5fa;border-bottom:2px solid #60a5fa}:root[data-theme=dark] .tab-content{background:#181c23}:root[data-theme=dark] .detail-item{background:#23272f;border:1px solid #2d323b;color:#e5e7eb;box-shadow:0 1px 4px #60a5fa0f}:root[data-theme=dark] .detail-item label{color:#b0b8c9}:root[data-theme=dark] .detail-item p{color:#e5e7eb}:root[data-theme=dark] .status-switch-container{background:#232b3b;box-shadow:0 1px 4px #60a5fa1a}:root[data-theme=dark] .status-switch-label{color:#b0b8c9}:root[data-theme=dark] .status-switch-state{background:linear-gradient(90deg,#2563eb 60%,#174ea6);color:#fff}:root[data-theme=dark] .status-switch-state.inactive{background:linear-gradient(90deg,#2d323b 60%,#6b7280);color:#b0b8c9}.user-access-container{display:flex;flex-direction:column;gap:1.5rem}.roles-section{padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.role-actions{display:flex;gap:1rem;margin-bottom:1rem}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.role-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px solid #e0e0e0;border-radius:4px;transition:background-color .2s}.role-item:hover{background-color:#f5f5f5}.role-name{font-size:.9rem;color:#333}.permissions-section{padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1rem}.permission-item{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;border:1px solid #e0e0e0;border-radius:4px;transition:background-color .2s}.permission-item:hover{background-color:#f5f5f5}.permission-name{display:block;font-weight:500;color:#333;margin-bottom:.25rem}.permission-description{display:block;font-size:.85rem;color:#666}.no-data{color:#666;text-align:center;padding:1rem}.form-actions{display:flex;gap:1rem;margin-top:1rem;justify-content:flex-end}.profile-container{padding:24px;max-width:1200px;margin:0 auto}.profile-header-section{margin-bottom:24px}.profile-header-section h2{font-size:24px;font-weight:600;color:var(--text-primary)}.profile-content{background:var(--card-bg);border-radius:8px;box-shadow:var(--card-shadow);overflow:hidden}.profile-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--card-bg);padding:0 24px}.profile-tab{display:flex;align-items:center;gap:8px;padding:16px 24px;border:none;background:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.profile-tab:hover{color:var(--primary-color)}.profile-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.profile-tab-content{padding:24px}.profile-info{display:flex;flex-direction:column;gap:24px}.profile-header{display:flex;align-items:center;gap:24px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff}.profile-basic-info h2{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.profile-role{color:var(--primary-color);font-weight:500;margin-bottom:4px}.profile-email{color:var(--text-secondary);font-size:14px}.profile-details{display:flex;flex-direction:column;gap:24px}.detail-section h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.detail-item{display:flex;align-items:flex-start;gap:12px}.detail-icon{color:var(--primary-color);font-size:20px;margin-top:2px}.detail-content label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:4px}.detail-content p{color:var(--text-primary);font-size:14px}.status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status.active{background:var(--success-bg);color:var(--success-color)}.profile-settings{display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--card-bg);border-radius:8px;padding:24px}.settings-section h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.settings-item{margin-bottom:16px}.settings-item label{display:flex;align-items:center;gap:8px;color:var(--text-primary);cursor:pointer}.settings-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}.profile-activity{display:flex;flex-direction:column;gap:24px}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color)}.activity-icon{width:40px;height:40px;border-radius:50%;background:var(--primary-bg);display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.activity-content{flex:1}.activity-description{color:var(--text-primary);margin-bottom:4px}.activity-time{color:var(--text-secondary);font-size:12px}[data-theme=dark] .profile-content{background:var(--card-bg)}[data-theme=dark] .profile-tab{color:var(--text-secondary)}[data-theme=dark] .profile-tab:hover,[data-theme=dark] .profile-tab.active{color:var(--primary-color)}[data-theme=dark] .activity-item{background:var(--card-bg);border-color:var(--border-color)}@media (max-width: 768px){.profile-container{padding:16px}.profile-header{flex-direction:column;text-align:center}.profile-tabs{padding:0 16px;overflow-x:auto}.profile-tab{padding:12px 16px;white-space:nowrap}.profile-tab-content{padding:16px}.detail-grid{grid-template-columns:1fr}}.erp-settings-root{display:flex;background:#f4f6fa;border-radius:8px;box-shadow:0 1px 6px #0000000f;max-width:700px;margin:2rem auto;min-height:380px}.erp-settings-sidebar{min-width:140px;background:#232e3c;color:#fff;border-radius:8px 0 0 8px;padding:1.2rem .5rem 1.2rem 1rem;display:flex;flex-direction:column;align-items:flex-start}.erp-settings-sidebar-title{font-size:1.1rem;font-weight:700;margin-bottom:1.2rem;color:#b6c2d1;letter-spacing:.5px}.erp-settings-tabs{list-style:none;padding:0;margin:0;width:100%}.erp-settings-tab{display:flex;align-items:center;gap:.5rem;padding:.45rem .7rem;border-radius:5px;font-size:.98rem;color:#cfd8e3;cursor:pointer;margin-bottom:.2rem;transition:background .15s,color .15s}.erp-settings-tab.active,.erp-settings-tab:hover{background:#31425b;color:#fff}.erp-settings-tab span{font-size:.97rem}.erp-settings-content{flex:1;padding:1.2rem 1.5rem;display:flex;flex-direction:column;justify-content:flex-start}.erp-settings-card{background:#fff;border-radius:7px;box-shadow:0 1px 4px #0000000a;padding:1.1rem 1.2rem 1rem;min-width:260px;max-width:350px;margin:0 auto}.erp-settings-card h4{display:flex;align-items:center;gap:.5rem;font-size:1.08rem;font-weight:600;color:#2d3748;margin-bottom:1.1rem}.erp-settings-form{display:flex;flex-direction:column;gap:.7rem}.erp-form-row{display:flex;align-items:center;gap:.7rem;margin-bottom:.2rem}.erp-form-row label{min-width:80px;font-size:.97rem;color:#4a5568;font-weight:500}.erp-form-row input[type=text],.erp-form-row input[type=email],.erp-form-row input[type=password]{padding:.35rem .7rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.97rem;background:#f7fafc;width:140px;transition:border .2s}.erp-form-row input:focus{border-color:#3182ce;outline:none}.erp-form-row.compact{gap:.5rem;margin-bottom:.1rem}.erp-form-row input[type=checkbox]{width:16px;height:16px;accent-color:#3182ce}.erp-btn{padding:.38rem 1.1rem;border:none;border-radius:4px;font-size:.97rem;font-weight:600;background:#3182ce;color:#fff;cursor:pointer;margin-top:.2rem;transition:background .18s}.erp-btn.primary{background:#3182ce}.erp-btn.danger{background:#e53e3e}.erp-btn:hover{background:#2563eb}.erp-btn.danger:hover{background:#c53030}@media (max-width: 600px){.erp-settings-root{flex-direction:column;max-width:98vw;min-width:0}.erp-settings-sidebar{flex-direction:row;min-width:0;border-radius:8px 8px 0 0;padding:.7rem .5rem .7rem .7rem;width:100%;align-items:center}.erp-settings-tabs{display:flex;flex-direction:row;gap:.2rem;width:100%}.erp-settings-tab{margin-bottom:0;font-size:.95rem;padding:.35rem .5rem}.erp-settings-content{padding:.7rem .3rem}.erp-settings-card{padding:.7rem .5rem;min-width:0;max-width:98vw}}
