:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error)}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:1em;left:1em}.Toastify__toast-container--top-center{top:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:1em;right:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:0;margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:0;transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:0;transform:translate(0)}.Toastify__toast-container--rtl{right:0;left:initial}}.Toastify__toast{position:relative;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:4px;box-shadow:0 1px 10px #0000001a,0 2px 15px #0000000d;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);overflow:hidden;font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.7s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width : 480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:5px;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{transform:perspective(400px) rotateX(-20deg);opacity:1}to{transform:perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(110%,0,0)}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(-110%,0,0)}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{width:240px;background:var(--sidebar-bg);color:#fff;display:flex;flex-direction:column;flex-shrink:0;height:100vh}.sidebar-logo{min-height:78px;padding:12px 18px;border-bottom:1px solid #334155;display:flex;align-items:center;justify-content:center}.sidebar-logo-img{width:168px;max-height:54px;object-fit:contain}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;color:var(--sidebar-text);font-size:13px;transition:all .15s;border-left:3px solid transparent}.nav-item:hover{background:var(--sidebar-hover);color:#fff}.nav-item.active{background:var(--sidebar-hover);color:#fff;border-left-color:var(--primary)}.nav-icon{width:20px;text-align:center;font-size:15px}.nav-group+.nav-group{margin-top:6px;padding-top:6px;border-top:1px solid #334155}.nav-section-title{padding:8px 18px 4px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#64748b}.nav-divider{height:1px;background:#334155;margin:8px 18px}.sidebar-user{padding:14px 18px;border-top:1px solid #334155;display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--sidebar-text)}.logout-btn{width:28px;height:28px;border-radius:6px;border:1px solid #334155;background:transparent;color:var(--sidebar-text);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;flex-shrink:0}.logout-btn:hover{background:#334155;color:#fff}@media (max-width: 768px){.sidebar{width:100%;height:auto}.sidebar-logo{min-height:64px;padding:10px 16px;justify-content:flex-start}.sidebar-logo-img{width:142px;max-height:44px}.sidebar-nav{display:flex;gap:4px;overflow-x:auto;padding:8px}.nav-item{border-left:0;border-radius:6px;flex:0 0 auto;padding:9px 12px;white-space:nowrap}.nav-item.active{border-left-color:transparent}.nav-divider{display:none}.nav-group{display:contents}.nav-group+.nav-group{margin-top:0;padding-top:0;border-top:0}.nav-section-title,.sidebar-user{display:none}}.fy-selector{position:relative}.fy-selector-btn{display:inline-flex;align-items:center;gap:8px;background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:8px;padding:6px 12px;font-size:13px;color:var(--text, #1f2937)}.fy-selector-btn .fy-label{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted, #6b7280);background:var(--bg-muted, #f3f4f6);border-radius:4px;padding:1px 5px}.fy-selector-btn .fy-value{font-weight:600}.fy-selector-btn .fy-caret{color:var(--text-muted, #6b7280);font-size:10px}.fy-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:200px;background:#fff;border:1px solid var(--border, #e5e7eb);border-radius:8px;box-shadow:0 8px 24px #0000001f;list-style:none;margin:0;padding:4px;z-index:50}.fy-menu li{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px}.fy-menu li:hover{background:var(--bg-muted, #f3f4f6)}.fy-menu li.active{font-weight:600}.fy-menu .fy-tag{font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;background:var(--danger-bg, #fee2e2);color:var(--danger, #dc2626)}.fy-menu .fy-tag.current{background:var(--success-bg, #dcfce7);color:var(--success, #16a34a)}.app-header{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:10px 24px;border-bottom:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);position:sticky;top:0;z-index:20}.topbar{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;background:var(--bg-white)}.topbar-title{font-size:18px;font-weight:700;color:var(--text);min-width:0}.topbar-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap;max-width:100%;min-width:0}@media (max-width: 768px){.topbar{align-items:flex-start;flex-direction:column;padding:14px 16px}.topbar-actions{width:100%;justify-content:flex-start}}.tree-container{padding:12px}.tree-node-wrapper{position:relative;display:flex;align-items:flex-start;gap:34px;margin-bottom:14px}.tree-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-white);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;width:280px;min-height:68px}.tree-card:hover{border-color:var(--primary);box-shadow:0 2px 8px #3b82f61a}.tree-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.tree-info{flex:1;min-width:0}.tree-name{font-size:14px;font-weight:600;color:var(--text)}.tree-role{font-size:12px;color:var(--text-muted);margin-top:1px}.tree-badge{width:28px;height:28px;background:var(--primary);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.tree-children{position:relative;display:flex;flex-direction:column;gap:14px;margin-left:0;padding-left:34px}.tree-children:before{content:"";position:absolute;left:0;top:34px;bottom:34px;width:2px;background:var(--border)}.tree-children.single-child:before{display:none}.tree-children:after{content:"";position:absolute;left:-34px;top:34px;width:34px;height:2px;background:var(--border)}.tree-connector-vertical{display:none}.tree-child{position:relative;padding-top:0}.tree-child:before{content:"";position:absolute;left:-34px;top:34px;width:34px;height:2px;background:var(--border)}.tree-children.single-child .tree-child:before{left:-68px;width:68px}.tree-children.single-child:after{display:none}.tree-connector-horizontal{display:none}.dept-tree-layout{display:flex;gap:20px;min-height:calc(100vh - 140px)}.dept-tree-left{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:10px}.dept-tree-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-white);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s}.dept-tree-card:hover{border-color:var(--primary)}.dept-tree-card.active{border-color:var(--primary);background:var(--primary-light)}.dept-icon{width:42px;height:42px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text-muted);flex-shrink:0}.dept-tree-card.active .dept-icon{background:var(--primary);color:#fff}.dept-tree-info{flex:1}.dept-tree-name{font-size:14px;font-weight:600;color:var(--text)}.dept-tree-sub{font-size:12px;color:var(--text-muted)}.dept-tree-count{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text);flex-shrink:0}.dept-tree-card.active .dept-tree-count{background:var(--primary);color:#fff;border-color:var(--primary)}.dept-tree-right{flex:1}.dept-members-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.dept-members-title{font-size:16px;font-weight:700;color:var(--text)}.dept-head-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-white);border:1px solid var(--border);border-radius:10px;margin-bottom:16px}.dept-head-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.dept-dir-layout{display:flex;gap:20px;min-height:calc(100vh - 140px)}.dept-dir-sidebar{width:260px;flex-shrink:0;background:var(--bg-white);border:1px solid var(--border);border-radius:10px;padding:16px;height:fit-content}.dept-dir-search{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;margin-bottom:12px;color:var(--text)}.dept-dir-item{padding:10px 12px;font-size:14px;color:var(--text);cursor:pointer;border-radius:6px;transition:all .12s}.dept-dir-item:hover{background:var(--bg)}.dept-dir-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.dept-dir-content{flex:1}.dept-dir-head{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--bg-white);border:1px solid var(--border);border-radius:10px;margin-bottom:20px}.emp-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.emp-card{background:var(--bg-white);border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center;transition:all .15s}.emp-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #0000000f}.emp-card-avatar{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:#fff;margin:0 auto 12px}.emp-card-code{font-size:12px;color:var(--text-muted)}.emp-card-name{font-size:15px;font-weight:700;color:var(--text);margin-top:4px}.emp-card-email{font-size:12px;color:var(--text-muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emp-card-designation{font-size:13px;color:var(--text);margin-top:6px}.emp-card-dept{font-size:12px;color:var(--text-muted);margin-top:2px}.settings-shell{display:grid;grid-template-columns:240px 1fr;gap:24px;padding:20px 24px;align-items:start}.settings-subnav{position:sticky;top:68px;max-height:calc(100vh - 88px);overflow-y:auto;background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:12px 8px}.settings-subnav-group{margin-bottom:14px}.settings-subnav-group:last-child{margin-bottom:0}.settings-subnav-title{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted, #9ca3af);padding:4px 10px 6px}.settings-subnav-item{display:block;padding:8px 10px;margin:2px 0;border-radius:7px;font-size:13.5px;color:var(--text, #374151);text-decoration:none;transition:background .12s,color .12s}.settings-subnav-item:hover{background:var(--bg-muted, #f3f4f6)}.settings-subnav-item.active{background:var(--primary-bg, #eef2ff);color:var(--primary, #4f46e5);font-weight:600}.settings-content{min-width:0}@media (max-width: 900px){.settings-shell{grid-template-columns:1fr}.settings-subnav{position:static;max-height:none;overflow-y:visible}}.roles-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:start}.roles-list{display:flex;flex-direction:column;gap:8px}.role-card{text-align:left;background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:12px 14px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.role-card:hover{border-color:var(--primary, #4f46e5)}.role-card.active{border-color:var(--primary, #4f46e5);box-shadow:0 0 0 3px var(--primary-bg, #eef2ff)}.role-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.role-card-name{font-weight:600;font-size:14px}.role-tag{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted, #6b7280);background:var(--bg-muted, #f3f4f6);border-radius:10px;padding:1px 7px}.role-card-meta{font-size:12px;color:var(--text-muted, #6b7280);margin-top:4px}.roles-editor{min-width:0}.roles-fullaccess{background:var(--primary-bg, #eef2ff);border:1px solid var(--primary, #c7d2fe);color:var(--text, #3730a3);border-radius:10px;padding:14px 16px;font-size:13px;margin-top:8px}.perm-matrix{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:8px}.perm-group{border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:10px 12px}.perm-group-head{border-bottom:1px solid var(--border, #eef0f3);padding-bottom:6px;margin-bottom:6px}.perm-group-title span{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text, #374151)}.perm-check{display:flex;align-items:center;gap:8px;cursor:pointer}.perm-item{padding:5px 2px;font-size:13px}.perm-item:hover{background:var(--bg-muted, #f9fafb);border-radius:6px}.perm-label{flex:1}.perm-key{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10.5px;color:var(--text-muted, #9ca3af)}.roles-actions{display:flex;align-items:center;justify-content:space-between;margin-top:18px;padding-top:14px;border-top:1px solid var(--border, #eef0f3)}@media (max-width: 820px){.roles-layout{grid-template-columns:1fr}}:root{--primary: #3b82f6;--primary-dark: #2563eb;--primary-light: #dbeafe;--sidebar-bg: #1e293b;--sidebar-hover: #334155;--sidebar-text: #94a3b8;--bg: #f8fafc;--bg-white: #ffffff;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-light: #94a3b8;--success: #16a34a;--success-bg: #dcfce7;--warning: #d97706;--warning-bg: #fef3c7;--danger: #dc2626;--danger-bg: #fef2f2;--info: #0ea5e9;--info-bg: #e0f2fe;--radius: 10px;--radius-sm: 6px;--shadow: 0 1px 3px rgba(0,0,0,.08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:13px;min-width:0}.app-layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.page-content{flex:1;padding:24px;overflow-y:auto;min-width:0}.btn{padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;display:inline-flex;align-items:center;justify-content:center;text-align:center;width:auto;flex:0 0 auto;gap:6px;transition:all .15s;white-space:nowrap;line-height:1.2;min-height:36px}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{background:var(--bg-white);border:1px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:5px 10px;font-size:12px;min-height:30px}.card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;min-width:0;overflow-x:auto}.card-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.card-title{font-size:14px;font-weight:700;color:var(--text)}.table{width:100%;border-collapse:collapse}.table th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);text-align:left;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--border);font-weight:600}.table td{font-size:13px;color:var(--text);padding:10px 14px;border-bottom:1px solid #f1f5f9}.table tr:hover{background:var(--bg)}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-gutter:stable}.table-wrap .table{min-width:760px}.table-wrap::-webkit-scrollbar{height:10px}.table-wrap::-webkit-scrollbar-track{background:#eef2f7;border-radius:999px}.table-wrap::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:999px}.table-wrap::-webkit-scrollbar-thumb:hover{background:#64748b}.card>.table{min-width:720px}.toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.toolbar .form-control,.toolbar .form-input{width:auto;min-width:96px}.responsive-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.responsive-grid.compact{gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.responsive-split{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:20px;align-items:start}.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 10px;border-radius:20px}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-approved,.badge-active,.badge-completed,.badge-cleared,.badge-paid{background:var(--success-bg);color:var(--success)}.badge-rejected,.badge-inactive{background:var(--danger-bg);color:var(--danger)}.badge-draft{background:var(--info-bg);color:var(--info)}.badge-probation{background:var(--primary-light);color:var(--primary)}.badge-on_leave{background:var(--warning-bg);color:var(--warning)}.badge-notice_period{background:var(--danger-bg);color:var(--danger)}.badge-half_day{background:var(--info-bg);color:var(--info)}.badge-processed{background:var(--success-bg);color:var(--success)}.badge-cancelled{background:var(--border);color:var(--text-muted)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.form-control,.form-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);background:var(--bg-white);transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.form-control:focus,.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:var(--text-light)}select.form-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;cursor:pointer}textarea.form-input{resize:vertical;min-height:60px}.form-row{display:flex;gap:16px;margin-bottom:16px}.form-row .form-group{margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.stat-card .stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-card .stat-value{font-size:28px;font-weight:700;color:var(--text);margin-top:4px}.stat-card .stat-sub{font-size:11px;color:var(--text-light);margin-top:2px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-title{font-size:20px;font-weight:700;color:var(--text)}.filters-bar{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}.filters-bar input,.filters-bar select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--bg-white);color:var(--text)}.filters-bar input{width:240px}.module-toolbar{display:flex;justify-content:space-between;align-items:stretch;gap:16px;margin-bottom:18px}.module-summary{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.module-summary>div{min-width:136px;padding:12px 14px;background:var(--bg-white);border:1px solid var(--border);border-radius:8px}.summary-value{display:block;font-size:20px;line-height:1;font-weight:700;color:var(--text)}.summary-label{display:block;margin-top:5px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.segmented-control{display:inline-flex;align-self:flex-start;padding:3px;border:1px solid var(--border);border-radius:8px;background:var(--bg-white)}.segmented-control button{min-width:86px;height:34px;padding:0 14px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:13px;font-weight:700}.segmented-control button.active{background:var(--primary);color:#fff}.employee-filters{padding:14px;background:var(--bg-white);border:1px solid var(--border);border-radius:8px}.employee-table-card{padding:0;overflow:visible}.employee-table-scroll{padding-bottom:8px}.employee-table-scroll .table{min-width:1120px}.employee-table-card .pagination{padding:0 16px 16px}.employee-tree-panel{min-height:420px;padding:20px;overflow-x:auto;background:var(--bg-white);border:1px solid var(--border);border-radius:8px}.employee-tree-container{min-width:max-content}.employee-tree-card{border-radius:8px;box-shadow:none}.dept-module-tree-panel{min-height:420px;padding:18px;overflow-x:auto}.dept-module-tree-container{min-width:max-content}.dept-module-tree-card{border-radius:8px}.tree-node.clickable .employee-tree-card{cursor:pointer}.empty-state{display:flex;min-height:280px;align-items:center;justify-content:center;text-align:center;color:var(--text-muted)}.empty-state.error{color:var(--danger)}.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:20px}.tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;font-size:13px;color:var(--text-muted)}.pagination-buttons{display:flex;gap:4px}.pagination-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-white);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;color:var(--text)}.pagination-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-white);border-radius:var(--radius);padding:24px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.employee-profile-modal{max-width:1180px;padding:0}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:16px;font-weight:700}.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer}.employee-profile-modal .modal-header{position:sticky;top:0;z-index:2;padding:20px 24px;margin-bottom:0;background:var(--bg-white);border-bottom:1px solid var(--border)}.employee-profile-modal form{padding:0 24px 24px}.employee-profile-modal .btn[type=submit]{height:42px}.modal-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding-top:18px;margin-top:18px;border-top:1px solid var(--border)}.profile-form-section{padding:22px 0;border-top:1px solid var(--border)}.profile-form-section:first-of-type{border-top:none;padding-top:0}.profile-form-section h3{margin-bottom:16px;font-size:14px;font-weight:700;color:var(--text)}.employee-profile-modal .form-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:16px}.employee-profile-modal .form-row:last-child{margin-bottom:0}.employee-profile-modal .form-row.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.employee-profile-modal .form-row.one-col{grid-template-columns:minmax(0,1fr);max-width:calc((100% - 32px) / 3)}.employee-profile-modal .form-group{min-width:0;margin-bottom:0}.employee-profile-modal .form-group label{min-height:17px;margin-bottom:6px;color:var(--text-muted);font-size:11px;line-height:1.2}.employee-profile-modal .form-control{min-height:38px}.profile-form-section textarea.form-control{min-height:82px;resize:vertical}.repeat-grid{display:grid;gap:10px;align-items:center;margin-bottom:10px}.repeat-grid .form-control{min-width:0}.repeat-header{margin-bottom:6px;padding:10px 12px;background:#eef2f8;border-radius:6px}.repeat-header span{color:var(--text-muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.2px}.work-exp-grid{grid-template-columns:minmax(150px,1.2fr) minmax(130px,1fr) 132px 132px minmax(170px,1.4fr) minmax(100px,.7fr)}.education-grid{grid-template-columns:minmax(190px,1.3fr) minmax(150px,1fr) minmax(160px,1fr) minmax(150px,.9fr)}.dependent-grid{grid-template-columns:minmax(180px,1fr) minmax(170px,1fr) minmax(150px,.8fr)}.profile-quick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.profile-quick-grid div,.profile-field{min-width:0}.profile-quick-grid span,.profile-field span{display:block;margin-bottom:5px;color:var(--text-muted);font-size:12px;font-weight:600}.profile-quick-grid strong,.profile-field strong{display:block;color:var(--text);font-size:14px;font-weight:600;overflow-wrap:anywhere;white-space:pre-line}.profile-section-card{margin-bottom:16px;padding:22px 24px;background:var(--bg-white);border:1px solid var(--border);border-radius:8px}.profile-section-title{display:flex;align-items:center;gap:18px;margin-bottom:18px}.profile-section-title h3{margin:0;font-size:16px;font-weight:700;color:var(--text);white-space:nowrap}.profile-section-title div{height:1px;flex:1;background:var(--border)}.profile-field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:56px;row-gap:18px}.profile-field{display:grid;grid-template-columns:minmax(150px,35%) minmax(0,1fr);gap:16px;padding-bottom:10px;border-bottom:1px solid #edf2f7}.profile-data-table th{background:#e8eaf3;color:var(--text-muted);font-size:13px;text-transform:none;letter-spacing:0}.profile-data-table td{height:54px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow)}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{font-size:22px;font-weight:700;color:var(--text)}.login-logo p{color:var(--text-muted);font-size:13px;margin-top:4px}.avatar{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0}.dept-tag{font-size:11px;padding:2px 10px;border-radius:20px;font-weight:600}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.settings-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);padding-bottom:0}.settings-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;border:none;background:none;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;border-radius:8px 8px 0 0}.settings-tab:hover{color:var(--text);background:var(--bg)}.settings-tab.active{color:var(--primary);font-weight:600;border-bottom-color:var(--primary);background:var(--primary-light)}.settings-section{font-size:13px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border)}.settings-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}.settings-save-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.settings-save-bar h3{font-size:16px;font-weight:700;color:var(--text)}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;color:var(--text)}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.day-toggle{min-width:110px;text-transform:capitalize;transition:all .15s}@media (max-width: 768px){.app-layout{flex-direction:column;height:auto;min-height:100vh;overflow:visible}.main-content{overflow:visible}.stats-grid{grid-template-columns:repeat(2,1fr)}.topbar{align-items:flex-start;flex-direction:column;gap:12px}.topbar-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.toolbar{width:100%;justify-content:flex-start}.toolbar .btn{flex:0 0 auto}.toolbar .form-control,.toolbar .form-input{min-width:88px}.responsive-grid,.responsive-grid.compact,.responsive-split{grid-template-columns:1fr}.module-toolbar,.profile-field-grid,.profile-quick-grid{grid-template-columns:1fr;display:grid}.employee-profile-modal{max-width:calc(100vw - 24px)}.employee-profile-modal .form-row,.repeat-grid{grid-template-columns:1fr}.employee-profile-modal .form-row.one-col{max-width:none}.repeat-header{display:none}.profile-field{grid-template-columns:1fr;gap:2px}.grid-2,.form-row{grid-template-columns:1fr}.grid-3{grid-template-columns:repeat(2,1fr)}.page-content{padding:16px}.table th,.table td{padding:8px 10px;font-size:12px}}@media (max-width: 480px){.stats-grid,.grid-3{grid-template-columns:1fr}.btn{min-height:34px;padding:8px 12px}.toolbar .btn{flex:1 1 auto}.card{padding:16px}}.autocomplete{position:relative}.autocomplete-list{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:50;margin:0;padding:4px;list-style:none;max-height:240px;overflow-y:auto;background:#fff;border:1px solid var(--border, #e5e7eb);border-radius:8px;box-shadow:0 8px 24px #0000001f}.autocomplete-list li{padding:8px 10px;font-size:13px;border-radius:6px;cursor:pointer}.autocomplete-list li.active,.autocomplete-list li:hover{background:var(--primary-light, #eff6ff);color:var(--primary, #2563eb)}.employee-form-page .profile-form-section{background:#fff;border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:18px 20px;margin-bottom:16px}.employee-form-page .profile-form-section h3{margin:0 0 14px;font-size:14px;font-weight:700;color:var(--text, #111827)}.form-actions-bar{display:flex;justify-content:flex-end;gap:10px;position:sticky;bottom:0;background:var(--bg, #f8fafc);padding:12px 0}
