: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-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--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-color-progress-bgo: .2}.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:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right)}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right)}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}}.Toastify__toast{--y: 0;position:relative;-ms-touch-action:none;touch-action:none;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0;overflow:hidden}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.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:.5s}.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;z-index:1}.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:100%;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.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;border-bottom-left-radius:initial;border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp{position:absolute;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.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,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),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,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),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,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 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,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 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:translate3d(0,var(--y),0) 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:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) 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:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),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;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.adm-shell{display:flex;min-height:100vh;background:var(--bg-page);transition:background var(--transition)}.adm-sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sw);background:var(--bg-sidebar);box-shadow:var(--shadow-sidebar);display:flex;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1),background var(--transition);overflow:hidden;z-index:100}.adm-logo{display:flex;align-items:center;gap:11px;padding:0 18px;height:60px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;overflow:hidden;white-space:nowrap}.adm-logo-icon{width:32px;height:32px;border-radius:9px;background:var(--logo-bg);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;box-shadow:0 2px 8px #3b82f659}.adm-logo-text{font-weight:700;font-size:15.5px;letter-spacing:-.4px;color:#f1f5f9;opacity:1;transition:opacity .2s;white-space:nowrap}.adm-sidebar.collapsed .adm-logo-text{opacity:0;pointer-events:none}.adm-nav{flex:1;padding:10px 0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.adm-nav::-webkit-scrollbar{display:none}.adm-nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#94a3b873;padding:14px 20px 4px;white-space:nowrap;overflow:hidden;transition:opacity .2s;-webkit-user-select:none;user-select:none}.adm-sidebar.collapsed .adm-nav-section-label{opacity:0;height:0;padding:0}.adm-nav-item{display:flex!important;align-items:center!important;height:38px!important;gap:10px!important;padding:0 14px!important;white-space:nowrap!important;text-decoration:none!important;color:var(--txt-sidebar)!important;transition:background .15s,color .15s!important;position:relative;margin:1px 8px;border-radius:var(--radius);border:none;background:transparent;width:calc(100% - 16px);cursor:pointer;font-family:var(--font);font-size:13.5px;font-weight:500;text-align:left}.adm-nav-item:hover{background:var(--sidebar-hover-bg)!important;color:#e2e8f0!important}.adm-nav-item.active{background:var(--sidebar-active-bg)!important;color:#fff!important;box-shadow:0 2px 8px #2563eb4d!important}.adm-nav-icon{flex-shrink:0!important;width:18px!important;height:18px!important;display:flex;align-items:center;justify-content:center}.adm-nav-icon svg{width:15px;height:15px}.adm-nav-label{flex:1!important;font-size:13px!important;font-weight:500!important;letter-spacing:-.1px;overflow:hidden;text-overflow:ellipsis}.adm-sidebar.collapsed .adm-nav-item{justify-content:center!important;padding:0!important;gap:0!important;margin:1px 6px;width:calc(100% - 12px)}.adm-sidebar.collapsed .adm-nav-icon{width:20px!important;height:20px!important}.adm-sidebar.collapsed .adm-nav-icon svg{width:17px!important;height:17px!important}.adm-sidebar.collapsed .adm-nav-label,.adm-sidebar.collapsed .adm-nav-chevron{display:none!important}.adm-sidebar.collapsed .adm-nav-item:after{content:attr(data-label);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--bg-card);border:1px solid var(--border);color:var(--txt-primary);padding:5px 11px;border-radius:7px;font-size:12px;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:0 4px 14px #0000002e;z-index:200}.adm-sidebar.collapsed .adm-nav-item:hover:after{opacity:1}.adm-nav-chevron{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;opacity:.55;transition:transform .22s cubic-bezier(.4,0,.2,1),opacity .15s}.adm-nav-chevron svg{width:13px;height:13px}.adm-nav-chevron.open{transform:rotate(180deg);opacity:.9}.adm-nav-item.active .adm-nav-chevron,.adm-nav-item:hover .adm-nav-chevron{opacity:1}.adm-nav-group{position:relative}.adm-nav-group.group-active>.adm-nav-group-trigger{color:#93c5fd!important}.adm-nav-dropdown{overflow:hidden;transition:max-height .25s cubic-bezier(.4,0,.2,1)}.adm-nav-child{height:34px!important;padding:0 14px 0 32px!important;margin:1px 8px!important;font-size:12.5px!important;color:#94a3b8cc!important}.adm-nav-child:hover{color:#e2e8f0!important}.adm-nav-child.active{background:var(--sidebar-active-bg)!important;color:#fff!important;box-shadow:0 1px 6px #2563eb40!important}.adm-nav-child-bullet{width:5px;height:5px;border-radius:50%;background:#94a3b859;flex-shrink:0;margin-right:4px;transition:background .15s}.adm-nav-child:hover .adm-nav-child-bullet{background:#94a3b8b3}.adm-nav-child.active .adm-nav-child-bullet{background:#60a5fa}.adm-nav-child-icon{opacity:.7}.adm-nav-child:hover .adm-nav-child-icon,.adm-nav-child.active .adm-nav-child-icon{opacity:1}.adm-nav-flyout{display:none;position:absolute;left:calc(var(--sw) + 8px);top:0;min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0003;padding:6px;z-index:300;white-space:nowrap}.adm-nav-group:hover .adm-nav-flyout{display:block}.adm-sidebar:not(.collapsed) .adm-nav-flyout{display:none!important}.adm-nav-flyout-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--txt-muted);padding:4px 10px 6px;border-bottom:1px solid var(--border);margin-bottom:4px}.adm-nav-flyout-item{display:flex;align-items:center;gap:8px;height:34px;padding:0 10px;border-radius:7px;font-size:12.5px;font-weight:500;color:var(--txt-secondary);text-decoration:none;transition:background .13s,color .13s}.adm-nav-flyout-item:hover{background:var(--bg-page);color:var(--txt-primary)}.adm-nav-flyout-item.active{background:var(--accent-dim);color:var(--accent)}.adm-sidebar-foot{padding:14px 0;display:flex;justify-content:center;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}.adm-main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}.adm-header{height:60px;background:var(--bg-header);box-shadow:var(--shadow-header);display:flex;align-items:center;padding:0 24px;position:sticky;top:0;z-index:50;gap:12px;border-bottom:1px solid var(--border);transition:background var(--transition),border-color var(--transition)}.adm-toggle-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--bg-page);color:var(--txt-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.adm-toggle-btn:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.adm-header-title{font-size:15px;font-weight:600;color:var(--txt-primary);flex:1;letter-spacing:-.2px}.adm-header-right{display:flex;align-items:center;gap:10px}.adm-theme-toggle{display:flex;align-items:center}.adm-theme-switch{width:44px;height:24px;background:var(--toggle-bg);border-radius:99px;position:relative;cursor:pointer;border:none;transition:background .25s;flex-shrink:0}.adm-theme-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--toggle-knob);transition:transform .25s cubic-bezier(.4,0,.2,1),background .25s;display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 1px 4px #00000040}[data-theme=dark] .adm-theme-knob{transform:translate(20px)}.adm-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:var(--logo-bg);display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:700;font-family:var(--font-mono)}.adm-avatar--sm{width:26px;height:26px;font-size:11px}.adm-content{flex:1;padding:28px}.adm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.desktop-only{display:flex}.mobile-only{display:none}@media (max-width: 900px){.desktop-only{display:none!important}.mobile-only{display:flex!important}.adm-content{padding:18px}.adm-sidebar{transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1),width .25s cubic-bezier(.4,0,.2,1);width:260px!important}.adm-sidebar.mobile-open{transform:translate(0)}.adm-main{margin-left:0!important}}.pdd-wrap{position:relative;display:flex;align-items:center}.pdd-trigger{display:flex;align-items:center;gap:8px;height:36px;padding:0 10px 0 4px;background:transparent;border:1px solid transparent;border-radius:10px;cursor:pointer;font-family:var(--font);transition:background .15s,border-color .15s;color:var(--txt-primary);flex-shrink:0}.pdd-trigger:hover,.pdd-trigger--open{background:var(--accent-dim);border-color:var(--border)}.pdd-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.pdd-avatar{width:30px;height:30px;border-radius:50%;background:var(--logo-bg);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;font-family:var(--font-mono);flex-shrink:0;box-shadow:0 0 0 2px #3b82f64d;transition:box-shadow .15s}.pdd-trigger--open .pdd-avatar,.pdd-trigger:hover .pdd-avatar{box-shadow:0 0 0 2px var(--accent)}.pdd-trigger-info{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.pdd-trigger-name{font-size:13px;font-weight:600;color:var(--txt-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;line-height:1.2}.pdd-trigger-role{font-size:10.5px;font-weight:500;color:var(--txt-muted);white-space:nowrap;text-transform:capitalize;line-height:1.2}.pdd-caret{display:flex;align-items:center;color:var(--txt-muted);transition:transform .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.pdd-caret--up{transform:rotate(180deg)}.pdd-caret svg{width:13px;height:13px}.pdd-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:230px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 30px #0000002e,0 2px 8px #00000014;padding:6px;z-index:200;animation:pdd-in .18s cubic-bezier(.34,1.3,.64,1) both;transform-origin:top right}@keyframes pdd-in{0%{opacity:0;transform:scale(.93) translateY(-6px)}to{opacity:1;transform:scale(1) translateY(0)}}.pdd-identity{display:flex;align-items:center;gap:11px;padding:10px 12px 10px 10px;border-radius:8px;background:var(--bg-page);margin-bottom:2px}.pdd-id-avatar{width:38px;height:38px;border-radius:50%;background:var(--logo-bg);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;font-family:var(--font-mono);flex-shrink:0;box-shadow:0 0 0 2.5px #3b82f659}.pdd-id-info{flex:1;min-width:0}.pdd-id-name{font-size:13.5px;font-weight:600;color:var(--txt-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.pdd-id-email{font-size:11.5px;color:var(--txt-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono);line-height:1.4;margin-top:1px}.pdd-id-badge{display:inline-flex;align-items:center;margin-top:4px;padding:2px 7px;border-radius:99px;font-size:10px;font-weight:600;background:var(--accent-dim);color:var(--accent);text-transform:capitalize;letter-spacing:.03em}.pdd-sep{height:1px;background:var(--border);margin:4px 2px}.pdd-item{display:flex;align-items:center;gap:10px;width:100%;height:36px;padding:0 10px;border-radius:8px;border:none;background:transparent;color:var(--txt-secondary);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:background .12s,color .12s}.pdd-item:hover{background:var(--bg-page);color:var(--txt-primary)}.pdd-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.pdd-item-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity .12s}.pdd-item:hover .pdd-item-icon{opacity:1}.pdd-item-icon svg{width:14px;height:14px}.pdd-item-label{flex:1}.pdd-item-arrow{font-size:15px;color:var(--txt-muted);line-height:1;transition:transform .12s}.pdd-item:hover .pdd-item-arrow{transform:translate(2px)}.pdd-item--danger{color:#f87171}.pdd-item--danger:hover{background:#ef44441a;color:#ef4444}.pdd-item--danger .pdd-item-icon{opacity:.8}.pdd-item--danger:hover .pdd-item-icon{opacity:1}@media (max-width: 600px){.pdd-trigger-info,.pdd-caret{display:none!important}.pdd-trigger{padding:4px;border-radius:50%}.pdd-panel{right:-4px;min-width:210px}}.pm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:pm-overlay-in .18s ease both}@keyframes pm-overlay-in{0%{opacity:0}to{opacity:1}}.pm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d,0 4px 16px #00000026;animation:pm-modal-in .22s cubic-bezier(.34,1.2,.64,1) both;overflow:hidden}@keyframes pm-modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.pm-header{display:flex;align-items:flex-start;gap:12px;padding:20px 20px 0}.pm-header-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.pm-header-icon svg{width:18px;height:18px}.pm-header-icon--blue{background:#3b82f626;color:#3b82f6}.pm-header-icon--amber{background:#f59e0b26;color:#f59e0b}.pm-title{font-size:17px;font-weight:700;color:var(--txt-primary);line-height:1.2;margin:0 0 2px}.pm-subtitle{font-size:12.5px;color:var(--txt-muted);margin:0}.pm-close{margin-left:auto;flex-shrink:0;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--txt-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .13s,color .13s,border-color .13s}.pm-close:hover{background:#ef44441a;color:#ef4444;border-color:#ef44444d}.pm-close svg{width:14px;height:14px}.pm-avatar-row{display:flex;align-items:center;gap:12px;padding:16px 20px 0}.pm-avatar-lg{width:52px;height:52px;border-radius:50%;background:var(--logo-bg);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;font-family:var(--font-mono);flex-shrink:0;box-shadow:0 0 0 3px #3b82f64d}.pm-avatar-name{font-size:14px;font-weight:600;color:var(--txt-primary);line-height:1.3}.pm-avatar-role{font-size:12px;color:var(--txt-muted);text-transform:capitalize}.pm-form{display:flex;flex-direction:column;gap:14px;padding:18px 20px 20px}.pm-error-banner{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:13px;font-weight:500;line-height:1.4}.pm-field{display:flex;flex-direction:column;gap:5px}.pm-label{font-size:12.5px;font-weight:600;color:var(--txt-secondary);letter-spacing:.01em;-webkit-user-select:none;user-select:none}.pm-input{height:40px;padding:0 12px;background:var(--bg-page);border:1.5px solid var(--border);border-radius:8px;color:var(--txt-primary);font-family:var(--font);font-size:13.5px;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box;outline:none}.pm-input::placeholder{color:var(--txt-muted);opacity:.7}.pm-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f626}.pm-input--error{border-color:#ef4444!important;box-shadow:0 0 0 3px #ef44441f!important}.pm-field-error{font-size:12px;color:#ef4444;line-height:1.3;margin:0}.pm-password-wrap{position:relative;display:flex;align-items:center}.pm-password-input{padding-right:38px!important}.pm-password-eye{position:absolute;right:10px;background:none;border:none;cursor:pointer;padding:0;color:var(--txt-muted);display:flex;align-items:center;transition:color .13s}.pm-password-eye:hover{color:var(--txt-primary)}.pm-password-eye svg{width:15px;height:15px}.pm-strength{display:flex;align-items:center;gap:8px;margin-top:4px}.pm-strength-bars{display:flex;gap:4px;flex:1}.pm-strength-bar{flex:1;height:4px;border-radius:99px;background:var(--border);transition:background .25s}.pm-strength-label{font-size:11.5px;font-weight:600;white-space:nowrap;min-width:38px;text-align:right;transition:color .25s}.pm-match-hint{font-size:12px;font-weight:500;margin:2px 0 0;transition:color .2s}.pm-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:2px;padding-top:4px;border-top:1px solid var(--border)}.pm-btn{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 18px;border-radius:9px;font-family:var(--font);font-size:13.5px;font-weight:600;cursor:pointer;border:none;transition:background .15s,color .15s,opacity .15s,transform .12s;letter-spacing:-.01em;white-space:nowrap}.pm-btn:disabled{opacity:.55;cursor:not-allowed}.pm-btn:not(:disabled):active{transform:scale(.97)}.pm-btn--primary{background:var(--accent, #2563eb);color:#fff;box-shadow:0 2px 8px #2563eb59}.pm-btn--primary:not(:disabled):hover{background:#1d4ed8;box-shadow:0 4px 14px #2563eb73}.pm-btn--ghost{background:var(--bg-page);color:var(--txt-secondary);border:1.5px solid var(--border)}.pm-btn--ghost:not(:disabled):hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.pm-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:pm-spin .65s linear infinite}@keyframes pm-spin{to{transform:rotate(360deg)}}@media (max-width: 480px){.pm-modal{border-radius:12px;max-width:100%}.pm-header,.pm-form,.pm-avatar-row{padding-left:16px;padding-right:16px}.pm-footer{flex-direction:column-reverse}.pm-btn{width:100%;justify-content:center;height:42px}}.dp-page *,.dp-page *:before,.dp-page *:after,.sc-card *,.sc-card *:before,.sc-card *:after{box-sizing:border-box}.dp-page{width:100%;box-sizing:border-box;max-width:1400px;padding:1.5rem;overflow-x:hidden}.dp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem;min-width:0;flex-wrap:wrap}.dp-header-text{min-width:0;flex:1 1 0}.dp-title{font-size:1.5rem;font-weight:700;color:var(--txt-primary, #111827);margin:0 0 .25rem;letter-spacing:-.025em;overflow-wrap:break-word;word-break:break-word}.dp-subtitle{font-size:.875rem;color:var(--txt-muted, #6b7280);margin:0;overflow-wrap:break-word}.dp-subtitle strong{color:var(--txt-primary, #111827);font-weight:600}.dp-header-badge{display:flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:500;color:var(--txt-muted, #6b7280);background:var(--bg-secondary, #f9fafb);border:1px solid var(--border, #e5e7eb);border-radius:9999px;padding:.3rem .75rem;white-space:nowrap;flex-shrink:0;align-self:flex-start}.dp-live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;animation:dp-pulse 2s cubic-bezier(.4,0,.6,1) infinite;flex-shrink:0}@keyframes dp-pulse{0%,to{opacity:1}50%{opacity:.4}}.dp-section{margin-bottom:2rem;min-width:0;width:100%}.dp-section-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt-muted, #9ca3af);margin-bottom:.75rem;padding-left:.125rem}.dp-grid{display:grid;gap:1rem;width:100%;min-width:0}.dp-grid--primary{grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr))}.dp-grid--secondary{grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr))}@media (max-width: 600px){.dp-page{padding:.875rem}.dp-grid{gap:.75rem}}@media (max-width: 420px){.dp-page{padding:.625rem}.dp-grid{gap:.5rem}.dp-grid--primary,.dp-grid--secondary{grid-template-columns:1fr}}.dp-footer-hint{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--txt-muted, #9ca3af);background:var(--bg-secondary, #f9fafb);border:1px solid var(--border, #e5e7eb);border-radius:.625rem;padding:.75rem 1rem;margin-top:.5rem;flex-wrap:wrap;overflow-wrap:break-word;word-break:break-word}.dp-footer-hint svg{flex-shrink:0}.sc-card{position:relative;display:flex;flex-direction:column;background:var(--bg-card, #ffffff);border:1px solid var(--border, #e5e7eb);border-radius:.875rem;padding:1.125rem 1.125rem 1rem;overflow:hidden;cursor:default;min-width:0;width:100%;box-sizing:border-box;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease;will-change:transform}.sc-card:hover,.sc-card--hovered{box-shadow:0 4px 6px -1px #0000000f,0 10px 24px -4px #00000014;transform:translateY(-2px);border-color:var(--sc-accent, #6366f1)}.sc-accent-bar{position:absolute;top:0;left:0;width:3px;height:100%;background:var(--sc-accent, #6366f1);border-radius:3px 0 0 3px;opacity:.7;transition:opacity .18s ease;pointer-events:none}.sc-card:hover .sc-accent-bar,.sc-card--hovered .sc-accent-bar{opacity:1}.sc-inner{display:flex;align-items:flex-start;gap:.875rem;min-width:0;width:100%}.sc-icon-wrap{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:42px;height:42px;min-width:42px;border-radius:.625rem;background:var(--sc-accent-bg, rgba(99, 102, 241, .08));color:var(--sc-accent, #6366f1);transition:background .18s ease}.sc-card:hover .sc-icon-wrap,.sc-card--hovered .sc-icon-wrap{background:var(--sc-accent-bg, rgba(99, 102, 241, .14))}.sc-body{flex:1 1 0%;min-width:0;display:flex;flex-direction:column;gap:.2rem;overflow:hidden}.sc-label{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--txt-muted, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.sc-value-row{display:flex;align-items:baseline;gap:.375rem;flex-wrap:wrap;min-width:0}.sc-value{font-size:1.6rem;font-weight:800;line-height:1.1;color:var(--txt-primary, #111827);letter-spacing:-.03em;font-variant-numeric:tabular-nums;overflow-wrap:break-word;word-break:break-word;min-width:0}.sc-subtitle{font-size:.72rem;color:var(--txt-muted, #9ca3af);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.sc-sparkline{display:flex;align-items:flex-end;padding-top:2px;flex-shrink:0;overflow:hidden;width:72px;min-width:72px;height:32px}.sc-trend{display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem;font-weight:700;border-radius:9999px;padding:.1rem .4rem;white-space:nowrap;line-height:1.6;flex-shrink:0}.sc-trend--up{color:#16a34a;background:#dcfce7}.sc-trend--down{color:#dc2626;background:#fee2e2}@media (prefers-color-scheme: dark){.sc-trend--up{color:#4ade80;background:#4ade801f}.sc-trend--down{color:#f87171;background:#f871711f}}.dark .sc-trend--up{color:#4ade80;background:#4ade801f}.dark .sc-trend--down{color:#f87171;background:#f871711f}.sc-card--skeleton{display:flex;align-items:center;gap:.875rem;padding:1.125rem;pointer-events:none;cursor:default;min-width:0;overflow:hidden}.sc-card--skeleton .sc-body{gap:.5rem;min-width:0;flex:1 1 0%;overflow:hidden}@keyframes sc-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.sc-skeleton{border-radius:.375rem;background:linear-gradient(90deg,var(--bg-secondary, #f3f4f6) 25%,var(--bg-hover, #e5e7eb) 50%,var(--bg-secondary, #f3f4f6) 75%);background-size:800px 100%;animation:sc-shimmer 1.4s ease-in-out infinite;max-width:100%}.sc-skeleton--icon{width:42px;height:42px;border-radius:.625rem;flex-shrink:0;min-width:42px}.sc-skeleton--label{width:70%;height:11px}.sc-skeleton--value{width:50%;height:28px}@media (max-width: 900px){.sc-sparkline{display:none}}@media (max-width: 600px){.sc-value{font-size:1.35rem}.sc-icon-wrap{width:36px;height:36px;min-width:36px}.sc-card{padding:.875rem .875rem .75rem}.sc-inner{gap:.625rem}}@media (max-width: 420px){.sc-value{font-size:1.2rem}.sc-icon-wrap{width:32px;height:32px;min-width:32px}.sc-card{padding:.75rem}.sc-label{font-size:.65rem}}@media (prefers-reduced-motion: reduce){.sc-card,.sc-accent-bar,.sc-icon-wrap{transition:none}.sc-card:hover,.sc-card--hovered{transform:none}.sc-skeleton,.dp-live-dot{animation:none}}.users-page{display:flex;flex-direction:column;gap:20px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.page-header h2{font-size:22px;font-weight:700;color:var(--color-text);margin:0 0 4px}.text-muted{font-size:13px;color:var(--color-text-muted);margin:0}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.search-bar{padding:16px 20px;border-bottom:1px solid var(--color-border)}.search-wrapper{position:relative;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none}.search-input{width:100%;padding:9px 12px 9px 36px;background:var(--color-background, var(--bg-input));color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:13px;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead th{background:var(--color-background, var(--bg-input));padding:10px 16px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table tbody td{padding:12px 16px;border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text)}.data-table tbody tr:hover{background:color-mix(in srgb,var(--color-primary) 4%,transparent)}.serial{color:var(--color-text-muted);font-size:12px;width:40px}.date-cell{white-space:nowrap;color:var(--color-text-muted);font-size:12px}.actions-cell{width:140px}.loading-cell,.empty-cell{text-align:center;color:var(--color-text-muted);padding:48px 16px!important}.user-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-weight:500;color:var(--color-text);font-size:13px}.user-email-sub{font-size:11px;color:var(--color-text-muted)}.badge-role{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;text-transform:capitalize;background:color-mix(in srgb,var(--color-primary) 12%,transparent);color:var(--color-primary);margin:1px}.badge-gray{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;background:var(--color-border);color:var(--color-text-muted)}.action-buttons{display:flex;gap:6px;flex-wrap:nowrap}.btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .15s;line-height:1}.btn-sm{padding:5px 10px;font-size:11px}.btn-outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-outline:hover{background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.btn-danger{background:#fee2e2;color:#ef4444;border:1px solid #fca5a5}.btn-danger:hover{background:#ef4444;color:#fff}.btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.empty-state-inline{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--color-text-muted);font-size:14px}.empty-state-inline span{font-size:36px;opacity:.5}.spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;width:100%;max-width:560px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:16px;font-weight:700;color:var(--color-text);margin:0}.modal-close{background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--color-text-muted);padding:0 4px;border-radius:4px;transition:color .15s}.modal-close:hover{color:var(--color-text)}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:0}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px 20px;border-top:1px solid var(--color-border)}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:8px;padding:8px 16px;font-size:13px;cursor:pointer;transition:all .15s}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px}.form-group input,.form-group select{padding:8px 12px;background:var(--color-background, var(--bg-input));color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:13px;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}.form-error{font-size:11px;color:#ef4444}.required{color:#ef4444}@media (max-width: 600px){.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:stretch}}.roles-page{display:flex;flex-direction:column;gap:20px}.roles-summary{display:flex;align-items:center;gap:0;background:var(--color-surface, var(--bg-card, #fff));border:1px solid var(--color-border, var(--border, #e2e8f0));border-radius:12px;overflow:hidden}.summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 24px;border-right:1px solid var(--color-border, var(--border, #e2e8f0));flex:1}.summary-num{font-size:22px;font-weight:700;color:var(--color-text, var(--txt-primary, #0f172a))}.summary-label{font-size:11px;color:var(--color-text-muted, var(--txt-muted, #94a3b8));text-transform:capitalize}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.role-card{background:var(--color-surface, var(--bg-card, #fff));border:1px solid var(--color-border, var(--border, #e2e8f0));border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s,border-color .2s}.role-card:hover{box-shadow:0 4px 16px #00000014;border-color:var(--accent, #2563eb)}.role-card__header{display:flex;align-items:center;gap:12px}.role-card__icon{width:42px;height:42px;border-radius:10px;background:var(--accent-dim, #dbeafe);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.role-card__meta{display:flex;flex-direction:column;gap:2px}.role-name{font-size:15px;font-weight:700;color:var(--color-text, var(--txt-primary, #0f172a));margin:0;text-transform:capitalize}.perm-count{font-size:12px;color:var(--color-text-muted, var(--txt-muted, #94a3b8))}.role-perms-preview{display:flex;flex-wrap:wrap;gap:5px;min-height:28px}.badge-perm-sm{font-size:10px;font-weight:600;font-family:Courier New,monospace;background:var(--accent-dim, #dbeafe);color:var(--accent, #2563eb);border-radius:4px;padding:2px 7px;white-space:nowrap}.badge-gray{font-size:10px;font-weight:600;background:var(--color-hover, var(--bg-hover, #f1f5f9));color:var(--color-text-muted, var(--txt-secondary, #475569));border-radius:4px;padding:2px 7px}.role-no-perms{font-size:12px;color:var(--color-text-muted, var(--txt-muted, #94a3b8));font-style:italic;margin:0}.role-card__actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:4px;border-top:1px solid var(--color-border, var(--border, #e2e8f0))}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--color-text-muted, var(--txt-muted, #94a3b8))}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border, var(--border, #e2e8f0));border-top-color:var(--accent, #2563eb);border-radius:50%;animation:spin .8s linear infinite}.perms-modal-body{display:flex;flex-direction:column;gap:12px;max-height:60vh;height:auto;min-height:300px;overflow:hidden}.perms-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex-shrink:0}.perms-search{flex:1;min-width:180px}.perms-toolbar-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.perm-count-badge{font-size:12px;font-weight:600;color:var(--accent, #2563eb);background:var(--accent-dim, #dbeafe);border-radius:999px;padding:3px 10px;white-space:nowrap}.perms-groups{flex:1;overflow-y:auto;min-height:200px;padding-right:4px}.perms-groups::-webkit-scrollbar{width:5px}.perms-groups::-webkit-scrollbar-track{background:transparent}.perms-groups::-webkit-scrollbar-thumb{background:var(--color-border, var(--border, #e2e8f0));border-radius:999px}.perm-group{border:1px solid var(--color-border, var(--border, #e2e8f0));border-radius:10px;overflow:hidden}.perm-group__header{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;background:var(--color-hover, var(--bg-hover, #f8fafc));border-bottom:1px solid var(--color-border, var(--border, #e2e8f0))}.perm-group__label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:600;font-size:13px;color:var(--color-text, var(--txt-primary, #0f172a));flex:1}.perm-checkbox{width:15px;height:15px;cursor:pointer;accent-color:var(--accent, #2563eb);flex-shrink:0}.perm-module-icon{font-size:16px}.perm-module-name{text-transform:capitalize}.perm-module-count{font-size:11px;font-weight:400;color:var(--color-text-muted, var(--txt-muted, #94a3b8))}.perm-group-selected{font-size:11px;font-weight:600;color:var(--accent, #2563eb);background:var(--accent-dim, #dbeafe);border-radius:999px;padding:2px 8px;white-space:nowrap}.perm-group__items{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:0}.perm-item{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;border-bottom:1px solid var(--color-border, var(--border, #e2e8f0));border-right:1px solid var(--color-border, var(--border, #e2e8f0));transition:background .1s;-webkit-user-select:none;user-select:none}.perm-item:hover{background:var(--color-hover, var(--bg-hover, #f8fafc))}.perm-item--checked{background:var(--accent-dim, #dbeafe)!important}.perm-action-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border-radius:4px;padding:2px 6px;min-width:46px;text-align:center;flex-shrink:0}.perm-action-badge[data-action=view]{background:#dbeafe;color:#1d4ed8}.perm-action-badge[data-action=create]{background:#dcfce7;color:#15803d}.perm-action-badge[data-action=edit]{background:#fef9c3;color:#a16207}.perm-action-badge[data-action=delete]{background:#fee2e2;color:#b91c1c}.perm-action-badge:not([data-action=view]):not([data-action=create]):not([data-action=edit]):not([data-action=delete]){background:var(--color-hover, #f1f5f9);color:var(--color-text-muted, #94a3b8)}.perm-full-name{font-size:12px;font-family:Courier New,monospace;white-space:nowrap;text-overflow:ellipsis}.perms-loading,.perms-empty,.perms-empty-notice{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:var(--color-text-muted, var(--txt-muted, #94a3b8));font-size:13px;text-align:center}.perms-empty-notice span{font-size:28px}.perms-modal-footer{padding-top:14px;border-top:1px solid var(--color-border, var(--border, #e2e8f0));margin-top:4px}@media (max-width: 640px){.roles-grid{grid-template-columns:1fr}.roles-summary{flex-wrap:wrap}.summary-stat{min-width:80px;padding:10px 12px}.perm-group__items{grid-template-columns:1fr}.perms-toolbar{flex-direction:column;align-items:stretch}.role-card__actions .btn{flex:1}}.perms-page{display:flex;flex-direction:column;gap:20px}.perms-summary{display:flex;align-items:center;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 20px;border-right:1px solid var(--border);flex:1}.summary-stat:last-child{border-right:none}.summary-num{font-size:22px;font-weight:700;color:var(--txt-primary)}.summary-label{font-size:11px;color:var(--txt-muted);text-transform:capitalize}.search-card{display:flex;align-items:center;gap:10px;padding:12px 16px!important}.module-list{display:flex;flex-direction:column;gap:10px}.module-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.module-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.module-header:hover{background:var(--bg-hover)}.module-header-left{display:flex;align-items:center;gap:10px}.module-icon{font-size:20px}.module-name{font-size:14px;font-weight:600;color:var(--txt-primary);text-transform:capitalize}.module-count{font-size:11px;font-weight:600;background:var(--bg-hover);color:var(--txt-muted);border-radius:999px;padding:2px 8px}.module-header-right{display:flex;align-items:center;gap:8px}.chevron{font-size:10px;color:var(--txt-muted)}.module-perms{border-top:1px solid var(--border);display:flex;flex-direction:column}.perm-row{display:flex;align-items:center;justify-content:space-between;padding:9px 18px;border-bottom:1px solid var(--border);transition:background .1s}.perm-row:last-child{border-bottom:none}.perm-row:hover{background:var(--bg-hover)}.perm-row-left{display:flex;align-items:center;gap:10px}.perm-row-right{display:flex;align-items:center;gap:6px;opacity:0;transition:opacity .15s}.perm-row:hover .perm-row-right{opacity:1}.action-pill{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 7px;min-width:52px;text-align:center}.action--view{background:#dbeafe;color:#1d4ed8}.action--create{background:#dcfce7;color:#15803d}.action--edit{background:#fef9c3;color:#a16207}.action--delete{background:#fee2e2;color:#b91c1c}.action--default{background:var(--bg-hover);color:var(--txt-muted)}.action-label{text-transform:capitalize}.action-label.action--view{color:#1d4ed8}.action-label.action--create{color:#15803d}.action-label.action--edit{color:#a16207}.action-label.action--delete{color:#b91c1c}.perm-code{font-size:13px;font-family:Courier New,Courier,monospace;color:var(--txt-muted);background:var(--bg-hover);border-radius:4px;padding:1px 6px}.btn-ghost--danger:hover{background:#fee2e2!important;color:#ef4444!important}.quick-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.quick-label{font-size:12px;color:var(--txt-muted)}.form-hint{font-size:12px;color:var(--txt-muted);margin-top:4px;line-height:1.5;display:block}.form-hint code{background:var(--bg-hover);border-radius:3px;padding:1px 4px;font-family:Courier New,monospace;font-size:11px}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--txt-muted)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 640px){.perms-summary{flex-wrap:wrap}.summary-stat{min-width:80px;padding:10px 12px}.module-header-right .btn{display:none}.module-header-right .btn:last-of-type{display:flex}}.img-uploader-wrapper{display:flex;flex-direction:column;gap:.4rem}.img-uploader-label{font-size:.8125rem;font-weight:600;color:var(--txt-secondary, #6b7280);text-transform:uppercase;letter-spacing:.04em}.img-uploader-required{color:var(--danger, #ef4444)}.img-uploader-dropzone{border:2px dashed var(--border-input, #d1d5db);border-radius:.625rem;padding:2rem 1rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg-input, #fff);outline:none}.img-uploader-dropzone:hover,.img-uploader-dropzone:focus{border-color:var(--accent, #6366f1);background:color-mix(in srgb,var(--accent, #6366f1) 4%,var(--bg-input, #fff))}.img-uploader-dropzone.drag-over{border-color:var(--accent, #6366f1);background:color-mix(in srgb,var(--accent, #6366f1) 8%,var(--bg-input, #fff))}.img-uploader-icon{font-size:2.25rem;display:block;margin-bottom:.5rem}.img-uploader-hint{margin:0 0 .25rem;font-size:.875rem;color:var(--txt-primary, #111)}.img-uploader-hint strong{color:var(--accent, #6366f1)}.img-uploader-meta{margin:0;font-size:.75rem;color:var(--txt-muted, #9ca3af)}.img-uploader-preview-wrap{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.img-uploader-preview{width:100%;max-height:200px;object-fit:cover;border-radius:.5rem;border:1px solid var(--border, #e5e7eb);display:block}.img-uploader-preview-actions{display:flex;gap:.5rem}.img-uploader-replace-btn,.img-uploader-remove-btn{font-size:.8125rem;padding:.3rem .75rem;border-radius:.375rem;cursor:pointer;border:1px solid var(--border-input, #d1d5db);background:var(--bg-hover, #f3f4f6);color:var(--txt-primary, #111);transition:all .15s;display:inline-flex;align-items:center;gap:.25rem}.img-uploader-replace-btn:hover{border-color:var(--accent, #6366f1);color:var(--accent, #6366f1);background:color-mix(in srgb,var(--accent, #6366f1) 6%,var(--bg-hover, #f3f4f6))}.img-uploader-remove-btn:hover{border-color:var(--danger, #ef4444);color:var(--danger, #ef4444);background:#ef44440f}.img-uploader-input{display:none}.img-uploader-error{font-size:.78rem;color:var(--danger, #ef4444)}.slider-page{padding:0}.slider-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.slider-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.slider-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.slider-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.slider-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.slider-card:hover .slider-card-image img{transform:scale(1.04)}.slider-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.slider-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slider-card-desc{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.slider-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.slider-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:640px}.slider-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.slider-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.slider-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.slider-table th.sortable:hover{color:var(--accent)}.slider-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.slider-table tbody tr:last-child td{border-bottom:none}.slider-table tbody tr:hover{background:var(--bg-hover)}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.slider-grid{grid-template-columns:1fr}.col-date{display:none}.slider-table{min-width:500px}.skel-table-head,.skel-table-row{grid-template-columns:48px 1fr 72px}.skel-td-date,.skel-table-head>.shimmer:nth-child(4){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.slider-card-body h3{font-size:.875rem}.slider-card-desc{font-size:.75rem;-webkit-line-clamp:2}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.client-page{padding:0}.client-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.client-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.client-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0,0,0,.1));transform:translateY(-2px)}.client-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.client-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.client-card:hover .client-card-image img{transform:scale(1.04)}.client-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.client-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.client-table{width:100%;border-collapse:collapse;font-size:.875rem}.client-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.client-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.client-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.client-table th.sortable:hover{color:var(--accent)}.client-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.client-table tbody tr:last-child td{border-bottom:none}.client-table tbody tr:hover{background:var(--bg-hover)}.skel-table-head{display:grid;grid-template-columns:64px 1fr 100px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:64px 1fr 100px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}@media (max-width: 768px){.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:64px 1fr 88px}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.client-grid{grid-template-columns:1fr}.skel-table-head,.skel-table-row{grid-template-columns:48px 1fr 72px}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.client-card-body h3{font-size:.875rem}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.rte-wrapper{display:flex;flex-direction:column;gap:0;border:1px solid var(--border-input, #d1d5db);border-radius:.5rem;overflow:hidden;background:var(--bg-input, #fff);transition:border-color .15s}.rte-wrapper:focus-within{border-color:var(--accent, #6366f1);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent, #6366f1) 15%,transparent)}.rte-wrapper.rte-error{border-color:var(--danger, #ef4444)}.rte-label{font-size:.8125rem;font-weight:600;color:var(--txt-secondary, #6b7280);text-transform:uppercase;letter-spacing:.04em;padding:.5rem .75rem 0;display:block;border-bottom:none}.rte-required{color:var(--danger, #ef4444)}.rte-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:.375rem .5rem;border-bottom:1px solid var(--border, #e5e7eb);background:var(--bg-hover, #f9fafb);align-items:center}.rte-toolbar-group{display:flex;gap:1px;align-items:center}.rte-toolbar-group+.rte-toolbar-group:before{content:"";display:inline-block;width:1px;height:1.25rem;background:var(--border, #e5e7eb);margin:0 4px}.rte-tool-btn{background:transparent;border:1px solid transparent;border-radius:.3rem;padding:.2rem .45rem;font-size:.78rem;line-height:1.4;cursor:pointer;color:var(--txt-primary, #111);min-width:1.9rem;display:inline-flex;align-items:center;justify-content:center;transition:all .12s;-webkit-user-select:none;user-select:none}.rte-tool-btn:hover{background:var(--bg-card, #fff);border-color:var(--border-input, #d1d5db);color:var(--accent, #6366f1)}.rte-tool-btn.rte-active{background:color-mix(in srgb,var(--accent, #6366f1) 12%,transparent);border-color:color-mix(in srgb,var(--accent, #6366f1) 40%,transparent);color:var(--accent, #6366f1)}.rte-body-wrap{position:relative}.rte-placeholder{position:absolute;top:.625rem;left:.75rem;color:var(--txt-muted, #9ca3af);font-size:.875rem;pointer-events:none;-webkit-user-select:none;user-select:none}.rte-content{padding:.625rem .75rem;outline:none;font-size:.875rem;color:var(--txt-primary, #111);line-height:1.65;overflow-y:auto;font-family:inherit}.rte-content h2{font-size:1.2em;font-weight:700;margin:.5em 0 .25em}.rte-content h3{font-size:1.05em;font-weight:700;margin:.5em 0 .25em}.rte-content p{margin:0 0 .5em}.rte-content ul,.rte-content ol{padding-left:1.5em;margin:.25em 0}.rte-content li{margin:.125em 0}.rte-content a{color:var(--accent, #6366f1);text-decoration:underline}.rte-error-msg{font-size:.78rem;color:var(--danger, #ef4444);padding:.25rem .75rem .375rem;border-top:1px solid var(--border, #e5e7eb);background:var(--bg-hover, #f9fafb)}@media (max-width: 480px){.rte-toolbar{gap:1px;padding:.25rem}.rte-tool-btn{min-width:1.6rem;font-size:.72rem;padding:.15rem .3rem}}.sectors-page{padding:0}.sectors-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.sector-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.sector-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.sector-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.sector-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.sector-card:hover .sector-card-image img{transform:scale(1.04)}.sector-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.sector-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sector-card-desc{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.sector-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.sector-table{width:100%;border-collapse:collapse;font-size:.875rem}.sector-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.sector-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.sector-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.sector-table th.sortable:hover{color:var(--accent)}.sector-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.sector-table tbody tr:last-child td{border-bottom:none}.sector-table tbody tr:hover{background:var(--bg-hover)}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.sectors-grid{grid-template-columns:1fr}.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:48px 1fr 80px 72px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(3){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.sector-card-body h3{font-size:.875rem}.sector-card-desc{font-size:.75rem;-webkit-line-clamp:2}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.services-page{padding:0}.services-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.service-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.service-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.service-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.service-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.service-card:hover .service-card-image img{transform:scale(1.04)}.service-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.service-sector-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:9999px;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(37,99,235,.2);width:fit-content}.service-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.service-card-desc{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.service-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.service-table{width:100%;border-collapse:collapse;font-size:.875rem}.service-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.service-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.service-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.service-table th.sortable:hover{color:var(--accent)}.service-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.service-table tbody tr:last-child td{border-bottom:none}.service-table tbody tr:hover{background:var(--bg-hover)}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.services-grid{grid-template-columns:1fr}.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:48px 1fr 80px 72px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(3){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.service-card-body h3{font-size:.875rem}.service-card-desc{font-size:.75rem;-webkit-line-clamp:2}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.news-page{padding:0}.news-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.news-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.news-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.news-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.news-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.news-card:hover .news-card-image img{transform:scale(1.04)}.news-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.news-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.news-card-desc{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.news-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.news-table{width:100%;border-collapse:collapse;font-size:.875rem}.news-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.news-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.news-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.news-table th.sortable:hover{color:var(--accent)}.news-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.news-table tbody tr:last-child td{border-bottom:none}.news-table tbody tr:hover{background:var(--bg-hover)}@media (max-width: 768px){.col-desc{display:none}.skel-table-head,.skel-table-row{grid-template-columns:64px 1fr 100px 88px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(3){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.news-grid{grid-template-columns:1fr}.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:48px 1fr 80px 72px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(3){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.news-card-body h3{font-size:.875rem}.news-card-desc{font-size:.75rem;-webkit-line-clamp:2}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.blog-page{padding:0}.btn-primary:hover{opacity:.9}.stats-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;padding:.75rem 1rem}.stat-label{font-size:.75rem;color:var(--txt-secondary);margin:0 0 .25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--txt-primary);margin:0}.posts-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.post-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s}.post-card:hover{box-shadow:var(--shadow-card)}.post-header{position:relative;aspect-ratio:16 / 8;display:flex;align-items:center;justify-content:center;background-size:cover}.post-image-icon{font-size:2.5rem;opacity:.5}.gradient-1{background:linear-gradient(135deg,#a855f7,#ec4899);opacity:.7}.gradient-2{background:linear-gradient(135deg,#0ea5e9,#06b6d4);opacity:.7}.gradient-3{background:linear-gradient(135deg,#10b981,#14b8a6);opacity:.7}.gradient-4{background:linear-gradient(135deg,#f59e0b,#f43f5e);opacity:.7}.status-badge{position:absolute;top:.75rem;left:.75rem;border-radius:9999px;padding:.2rem .6rem;font-size:.7rem;font-weight:700}.badge-published{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.3)}.badge-scheduled{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.badge-draft{background:var(--bg-hover);color:var(--txt-secondary);border:1px solid var(--border)}.post-content{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.category-badge{display:inline-block;width:fit-content;background:var(--bg-hover);color:var(--txt-secondary);border:1px solid var(--border);border-radius:9999px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.post-title{margin:0;font-size:1rem;font-weight:700;line-height:1.4;color:var(--txt-primary)}.post-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:.75rem;margin-top:.25rem;flex-wrap:wrap;gap:.5rem}.author-info{display:flex;align-items:center;gap:.5rem}.author-avatar{width:1.75rem;height:1.75rem;background:var(--accent-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--accent)}.author-name{font-size:.75rem;font-weight:600;color:var(--txt-primary)}.post-metrics{display:flex;gap:.75rem;font-size:.65rem;color:var(--txt-secondary)}.metric{display:inline-flex;align-items:center;gap:.2rem}.post-actions{display:flex;gap:.25rem;justify-content:flex-end;margin-top:.25rem}.icon-btn{background:transparent;border:1px solid var(--border);border-radius:.375rem;width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--txt-secondary)}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.posts-grid{grid-template-columns:1fr}.post-footer{flex-direction:column;align-items:flex-start}}.team-page{display:flex;flex-direction:column;gap:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:18px 20px;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 16px #00000014}.stat-label{font-size:12px;color:var(--color-text-muted);margin:0 0 6px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:28px;font-weight:700;color:var(--color-text);margin:0}.stat-value--success{color:var(--color-success, #22c55e)}.stat-value--muted{color:var(--color-text-muted)}.filter-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.filter-left{display:flex;align-items:center;gap:10px;flex:1;flex-wrap:wrap}.filter-select{width:auto;min-width:140px}.view-toggle{display:flex;gap:4px}.view-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);background:transparent;border-radius:8px;cursor:pointer;font-size:16px;color:var(--color-text-muted);transition:all .15s}.view-btn:hover,.view-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;padding:20px}.team-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;position:relative;transition:box-shadow .2s,transform .2s}.team-card:hover{box-shadow:0 8px 28px #0000001f;transform:translateY(-2px)}.card-top-bar{height:6px;width:100%}.card-status-dot{position:absolute;top:14px;right:14px}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;border:2px solid var(--color-surface)}.status-dot--active{background:#22c55e}.status-dot--inactive{background:#94a3b8}.avatar-wrapper{display:flex;justify-content:center;padding:18px 0 10px}.avatar{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;cursor:pointer;transition:transform .15s,box-shadow .15s;flex-shrink:0}.avatar:hover{transform:scale(1.08);box-shadow:0 4px 16px #0003}.avatar--sm{width:36px;height:36px;font-size:13px;cursor:default}.avatar--sm:hover{transform:none;box-shadow:none}.avatar--lg{width:80px;height:80px;font-size:26px;cursor:default}.card-content{padding:0 16px 16px;text-align:center;display:flex;flex-direction:column;gap:8px}.member-name{font-size:15px;font-weight:600;color:var(--color-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-role-row{display:flex;justify-content:center;flex-wrap:wrap;gap:4px}.member-email{font-size:12px;color:var(--color-text-muted);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-meta{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.join-date{font-size:11px;color:var(--color-text-muted)}.card-experience{position:relative;max-height:3em;overflow:hidden;text-align:left;-webkit-mask-image:linear-gradient(to bottom,black 40%,transparent 100%);mask-image:linear-gradient(to bottom,black 40%,transparent 100%)}.card-experience-inner{font-size:12px;color:var(--color-text-muted);line-height:1.5;word-break:break-word}.card-experience-inner p,.card-experience-inner h2,.card-experience-inner h3{margin:0 0 .25em}.card-experience-inner ul,.card-experience-inner ol{margin:0;padding-left:1.2em}.table-experience{font-size:13px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.contact-actions{display:flex;justify-content:center;gap:8px;margin-top:4px}.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--color-border);background:transparent;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}.icon-btn:hover{background:var(--color-hover);border-color:var(--color-primary)}.icon-btn--danger:hover{background:#fee2e2;border-color:#ef4444}.user-cell{display:flex;align-items:center;gap:10px}.user-name{font-weight:500;color:var(--color-text)}.user-email-sub{font-size:12px;color:var(--color-text-muted)}.row-inactive{opacity:.6}.badge-role{text-transform:capitalize;font-size:11px}.badge-perm{font-size:11px;font-family:monospace}.badge-status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;border-radius:999px;padding:2px 8px}.badge-status--active{background:#dcfce7;color:#16a34a}.badge-status--inactive{background:#f1f5f9;color:#64748b}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge--md{font-size:12px;padding:3px 10px}.gradient-1{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.gradient-2{background:linear-gradient(135deg,#3b82f6,#06b6d4)}.gradient-3{background:linear-gradient(135deg,#f59e0b,#f97316)}.gradient-4{background:linear-gradient(135deg,#10b981,#14b8a6)}.gradient-5{background:linear-gradient(135deg,#ef4444,#f43f5e)}.gradient-6{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.gradient-7{background:linear-gradient(135deg,#0ea5e9,#6366f1)}.gradient-8{background:linear-gradient(135deg,#84cc16,#10b981)}.member-detail{display:flex;flex-direction:column;gap:20px}.detail-avatar-row{display:flex;align-items:center;gap:16px}.detail-name{font-size:18px;font-weight:700;margin:0 0 4px}.detail-email{font-size:13px;color:var(--color-text-muted);margin:0 0 8px}.detail-section h4{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin:0 0 8px}.perms-grid{display:flex;flex-wrap:wrap;gap:6px;max-height:140px;overflow-y:auto}.detail-rich-text{font-size:14px;color:var(--color-text);line-height:1.65}.detail-rich-text h2{font-size:1.1em;font-weight:700;margin:.5em 0 .25em}.detail-rich-text h3{font-size:1em;font-weight:700;margin:.5em 0 .25em}.detail-rich-text p{margin:0 0 .5em}.detail-rich-text ul,.detail-rich-text ol{padding-left:1.4em;margin:.25em 0}.detail-rich-text li{margin:.125em 0}.detail-rich-text a{color:var(--accent, #6366f1);text-decoration:underline}.form-group--inline{display:flex;align-items:center}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-checkbox{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:42px;height:24px;background:#cbd5e1;border-radius:999px;transition:background .2s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s}.toggle-checkbox:checked+.toggle-slider{background:var(--color-primary)}.toggle-checkbox:checked+.toggle-slider:after{transform:translate(18px)}.toggle-text{font-size:13px;color:var(--color-text)}.confirm-dialog{max-width:400px!important}.confirm-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.confirm-icon{font-size:28px}.confirm-title{font-size:17px;font-weight:600;margin:0}.confirm-message{color:var(--color-text-muted);font-size:14px;margin:0;line-height:1.5}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--color-text-muted)}.empty-icon{font-size:48px;opacity:.5}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 540px){.form-row{grid-template-columns:1fr}}@media (max-width: 768px){.team-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:14px}.avatar{width:50px;height:50px;font-size:15px}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.team-grid{grid-template-columns:1fr 1fr}.filter-row{flex-direction:column;align-items:stretch}}.skel-card-top-bar,.skel-avatar{background:linear-gradient(90deg,#e2e8f0,#cbd5e1,#e2e8f0);animation:shimmer 1.4s infinite linear}.skel-line{height:.875rem;margin:.25rem 0;background:linear-gradient(90deg,#e2e8f0,#cbd5e1,#e2e8f0);animation:shimmer 1.4s infinite linear}.skel-btn{width:2rem;height:2rem;display:inline-block;background:linear-gradient(90deg,#e2e8f0,#cbd5e1,#e2e8f0);animation:shimmer 1.4s infinite linear;border-radius:.375rem}.modal-body{padding:1.25rem;overflow-y:auto;flex:1 1 auto;min-height:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group input,.form-group select{padding:.5625rem .75rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.error-banner{padding:.625rem .875rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#ef4444;font-size:.8rem;font-weight:500;margin-bottom:1rem}.tc-page{display:flex;flex-direction:column;gap:20px}.tc-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.tc-header h2{font-size:22px;font-weight:700;color:var(--color-text);margin:0 0 4px}.tc-subtitle{font-size:13px;color:var(--color-text-muted);margin:0}.tc-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.tc-search-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.tc-search-wrapper{position:relative;flex:1;max-width:360px}.tc-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none}.tc-search-input{width:100%;padding:8px 12px 8px 34px;background:var(--color-background, var(--bg-input));color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:13px;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.tc-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}.tc-count{font-size:12px;color:var(--color-text-muted);white-space:nowrap}.tc-table-wrap{overflow-x:auto}.tc-table{width:100%;border-collapse:collapse;font-size:13px}.tc-table thead th{background:var(--color-background, var(--bg-input));padding:10px 16px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.tc-table tbody td{padding:13px 16px;border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text)}.tc-table tbody tr:last-child td{border-bottom:none}.tc-row:hover{background:color-mix(in srgb,var(--color-primary) 3%,transparent)}.tc-serial{color:var(--color-text-muted);font-size:12px;width:40px}.tc-date{white-space:nowrap;color:var(--color-text-muted);font-size:12px}.tc-muted{color:var(--color-text-muted);font-size:12px}.tc-name{font-weight:500;color:var(--color-text)}.tc-badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:500;background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary)}.tc-actions{display:flex;gap:6px;flex-wrap:nowrap}.tc-btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.tc-btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.tc-btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.tc-input{padding:9px 12px;background:var(--color-background, var(--bg-input));color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:13px;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.tc-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}.tc-input--error{border-color:#ef4444}.tc-input--error:focus{box-shadow:0 0 0 3px #ef444426}.tc-hint{font-size:11px;color:var(--color-text-muted);line-height:1.4}.tc-state-cell{text-align:center;padding:52px 16px!important}.tc-loading{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--color-text-muted);font-size:13px}.tc-spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:tc-spin .8s linear infinite}@keyframes tc-spin{to{transform:rotate(360deg)}}.tc-empty{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--color-text-muted)}.tc-empty-icon{font-size:40px;opacity:.45}.tc-empty p{font-size:13px;margin:0}@media (max-width: 600px){.tc-header,.tc-search-bar{flex-direction:column;align-items:stretch}.tc-search-wrapper{max-width:100%}}.project-page{padding:0}.badge-year{background:#6366f11a;color:#6366f1;border-color:#6366f14d}.badge-ongoing{background:#10b9811a;color:#10b981;border-color:#10b9814d}.badge-complete{background:#6366f11f;color:#6366f1;border-color:#6366f14d}.badge-pending{background:#f59e0b1f;color:#f59e0b;border-color:#f59e0b4d}.badge-cancel{background:#ef44441f;color:#ef4444;border-color:#ef44444d}.badge-default{background:var(--bg-hover);color:var(--txt-secondary);border-color:var(--border)}.tags{display:flex;flex-wrap:wrap;gap:.25rem}.tag{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:.25rem;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent);white-space:nowrap}.project-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:1.25rem}.project-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.project-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.project-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.project-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-card-image img{transform:scale(1.04)}.project-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.project-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-meta{display:flex;gap:.5rem;flex-wrap:wrap}.project-sectors{display:flex;gap:.25rem;flex-wrap:wrap}.project-card-desc{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.project-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.project-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:900px}.project-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.project-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.project-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.project-table th.sortable:hover{color:var(--accent)}.project-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.project-table tbody tr:last-child td{border-bottom:none}.project-table tbody tr:hover{background:var(--bg-hover)}.col-year{width:80px}.col-sectors{min-width:150px}.col-status{width:100px}.col-client{min-width:120px}.table-thumb{width:56px;object-fit:cover;border-radius:.375rem;border:1px solid var(--border)}.table-thumb-placeholder{width:56px;display:flex;align-items:center;justify-content:center;font-size:1.375rem;background:var(--bg-hover);border-radius:.375rem;border:1px solid var(--border)}.form-group select[multiple]{height:120px;padding:.375rem}.help-text{font-size:.75rem;color:var(--txt-muted)}.skel-card-img{aspect-ratio:16 / 9;width:100%}.skel-table-head{display:grid;grid-template-columns:64px 1fr 80px 120px 100px 120px 100px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:64px 1fr 80px 120px 100px 120px 100px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-year,.skel-td-status,.skel-td-date,.skel-td-client{height:.75rem;width:70%}.skel-td-sectors{height:1.5rem;width:100%}@media (max-width: 1024px){.col-sectors{min-width:120px}.col-client{min-width:100px}}@media (max-width: 768px){.col-sectors,.col-client{display:none}.skel-table-head,.skel-table-row{grid-template-columns:64px 1fr 80px 100px 100px 88px}.skel-td-sectors,.skel-td-client,.skel-table-head>.shimmer:nth-child(4),.skel-table-head>.shimmer:nth-child(6){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.project-grid{grid-template-columns:1fr}.col-year,.col-status,.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:64px 1fr 88px}.skel-td-year,.skel-td-status,.skel-td-date,.skel-table-head>.shimmer:nth-child(3),.skel-table-head>.shimmer:nth-child(5),.skel-table-head>.shimmer:nth-child(7){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.form-row{grid-template-columns:1fr;gap:.75rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.project-card-body h3{font-size:.875rem}.project-card-desc{font-size:.75rem;-webkit-line-clamp:2}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.multi-select-inline{position:relative;width:100%}.multi-select-input-inline{border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:.375rem .75rem;min-height:42px;transition:border-color .15s}.multi-select-input-inline:hover{border-color:var(--accent)}.multi-select-tags-inline{display:flex;flex-wrap:wrap;gap:.375rem;flex:1}.multi-select-placeholder-inline{color:var(--txt-muted);font-size:.875rem}.multi-select-tag-inline{display:inline-flex;align-items:center;gap:.25rem;background:var(--accent-dim);color:var(--accent);font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:.375rem}.multi-select-tag-inline button{background:transparent;border:none;font-size:1rem;cursor:pointer;color:var(--accent);padding:0;margin:0;line-height:1}.multi-select-arrow-inline{font-size:.7rem;color:var(--txt-muted)}.multi-select-dropdown-inline{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 4px 12px #00000026;z-index:100;margin-top:4px;max-height:250px;display:flex;flex-direction:column;overflow:hidden}.multi-select-search-inline{padding:.5rem;border-bottom:1px solid var(--border)}.multi-select-search-inline input{width:100%;padding:.375rem .5rem;border:1px solid var(--border-input);border-radius:.375rem;background:var(--bg-input);color:var(--txt-primary);font-size:.8125rem;outline:none}.multi-select-options-inline{overflow-y:auto;max-height:200px}.multi-select-option-inline{padding:.5rem .75rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background .15s}.multi-select-option-inline:hover{background:var(--bg-hover)}.multi-select-option-inline.selected{background:var(--accent-dim)}.multi-select-checkbox-inline{display:inline-block;width:1.125rem;text-align:center}.multi-select-no-options-inline{padding:1rem;text-align:center;color:var(--txt-muted);font-size:.8125rem}.project-sectors-page{padding:0}.project-status-page{padding:0}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;padding:.5rem 1rem;border-radius:.5rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;transition:opacity .2s}.search-wrapper{position:relative;max-width:360px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:.875rem;pointer-events:none}.search-input{width:100%;padding:.5rem .75rem .5rem 2.25rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;box-sizing:border-box;transition:border-color .15s}.search-input::placeholder{color:var(--txt-muted)}.loading-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 0;color:var(--txt-secondary);font-size:.875rem}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;overflow:hidden;overflow-x:auto}.data-table thead tr{background:var(--bg-table-head);border-bottom:1px solid var(--border)}.data-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-secondary);white-space:nowrap}.data-table td{padding:.875rem 1rem;color:var(--txt-primary);vertical-align:middle;border-bottom:1px solid var(--border)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.cell-title{font-weight:600;color:var(--txt-primary)}.status-badge{display:inline-block;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:700;border:1px solid}.status-ongoing{background:#10b9811f;color:#10b981;border-color:#10b9814d}.status-completed{background:#6366f11f;color:#6366f1;border-color:#6366f14d}.status-pending{background:#f59e0b1f;color:#f59e0b;border-color:#f59e0b4d}.status-cancelled{background:#ef44441f;color:#ef4444;border-color:#ef44444d}.status-default{background:var(--bg-hover);color:var(--txt-secondary);border-color:var(--border)}.action-group{display:flex;gap:.375rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--txt-secondary);font-size:.9375rem}.table-footer{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-top:1px solid var(--border);font-size:.8125rem;color:var(--txt-secondary);flex-wrap:wrap;gap:.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg-card);border-radius:.875rem;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000040;border:1px solid var(--border)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.0625rem;font-weight:700;color:var(--txt-primary)}.modal-close{background:transparent;border:none;font-size:1.375rem;cursor:pointer;color:var(--txt-secondary);line-height:1;padding:0 .25rem;transition:color .15s}.modal-close:hover{color:var(--txt-primary)}.modal form{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.form-group input{padding:.5625rem .75rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s;font-family:inherit}.form-group input:focus{border-color:var(--accent)}.form-group input::placeholder{color:var(--txt-muted)}.error{font-size:.78125rem;color:var(--danger)}.modal-actions{display:flex;justify-content:flex-end;gap:.625rem;padding-top:.5rem;border-top:1px solid var(--border);margin-top:.25rem}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.search-wrapper{max-width:100%}}.product-page{padding:0}.products-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.product-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .15s;display:flex;flex-direction:column}.product-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.product-image{aspect-ratio:16 / 9;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.product-image img{width:100%;height:100%;object-fit:cover}.product-image-placeholder{font-size:2.5rem;opacity:.35}.product-content{padding:.875rem 1rem;flex:1;display:flex;flex-direction:column;gap:.375rem}.product-name{margin:0;font-size:.9rem;font-weight:700;color:var(--txt-primary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-desc{margin:0;font-size:.775rem;color:var(--txt-secondary);line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.product-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;border-top:1px solid var(--border);background:var(--bg-table-head)}.product-date{font-size:.7rem;color:var(--txt-muted)}.product-actions{display:flex;gap:.3rem}.td-img{width:2.5rem;height:2.5rem;border-radius:.375rem;object-fit:cover;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:1.1rem;overflow:hidden}.td-img img{width:100%;height:100%;object-fit:cover}.view-toggle{display:flex;gap:.375rem}.view-toggle-btn{height:2.125rem;width:2.125rem;border-radius:.375rem;border:1.5px solid var(--border);background:var(--bg-page);color:var(--txt-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;transition:all .15s}.view-toggle-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.view-toggle-btn:hover:not(.active){background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.empty-state{text-align:center;padding:3rem;color:var(--txt-secondary);font-size:.875rem;grid-column:1/-1}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:1rem;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:modal-in .22s cubic-bezier(.34,1.2,.64,1) both}.modal-head{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-form{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.modal-body{overflow-y:auto;flex:1 1 auto;min-height:0}.modal-foot{display:flex;justify-content:flex-end;gap:.625rem;padding:.875rem 1.25rem;border-top:1px solid var(--border);flex-shrink:0}.contact-page{padding:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.btn-outline{background:transparent;border:1.5px solid var(--border);border-radius:.5rem;padding:.5rem 1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;color:var(--txt-primary);transition:all .15s}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.stats-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;padding:.75rem 1rem;display:flex;align-items:center;gap:1rem}.stat-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--accent-dim);display:flex;align-items:center;justify-content:center}.stat-emoji{font-size:1.25rem}.stat-label{font-size:.7rem;color:var(--txt-secondary);margin:0 0 .2rem}.search-bar{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;padding:1rem;margin-bottom:1.5rem}.search-wrapper{position:relative}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:.875rem;opacity:.6}.search-input{width:100%;padding:.5rem .5rem .5rem 2rem;border:1.5px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none}.messages-list{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden}.message-item{display:flex;gap:1rem;padding:1rem;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}.message-item:hover{background:var(--bg-hover)}.message-item.unread{background:var(--accent-dim)}.message-avatar{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--txt-primary);flex-shrink:0}.message-content{flex:1;min-width:0}.message-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem}.sender-info{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.sender-name{font-size:.875rem;color:var(--txt-primary)}.sender-name.bold{font-weight:700}.sender-email{font-size:.7rem;color:var(--txt-secondary)}.star-indicator{font-size:.8rem}.unread-badge{background:var(--accent);color:#fff;padding:.1rem .4rem;border-radius:.25rem;font-size:.6rem;font-weight:700}.message-time{font-size:.7rem;color:var(--txt-secondary)}.message-subject{margin:0 0 .2rem;font-size:.8rem;color:var(--txt-primary)}.message-subject.bold{font-weight:700}.message-preview{margin:0;font-size:.75rem;color:var(--txt-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-actions{display:flex;gap:.25rem;flex-shrink:0}.icon-btn{background:transparent;border:1px solid var(--border);border-radius:.375rem;width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--txt-secondary);transition:all .15s}.star-btn:hover{color:#f59e0b;border-color:#f59e0b}.delete-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.empty-state{text-align:center;padding:3rem;color:var(--txt-secondary);font-size:.9rem}.contact-form-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;margin-bottom:1.5rem}.contact-form-head{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg-table-head)}.contact-form-head-icon{width:2.25rem;height:2.25rem;border-radius:.6rem;background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.contact-form-head h3{margin:0;font-size:1rem;font-weight:700;color:var(--txt-primary)}.contact-form-head p{margin:.1rem 0 0;font-size:.78rem;color:var(--txt-muted)}.contact-form-body{padding:1.25rem}.cf-grid{display:grid;gap:1rem}.cf-grid-2{grid-template-columns:1fr 1fr}.cf-field{display:flex;flex-direction:column;gap:.3rem}.cf-label{font-size:.78rem;font-weight:600;color:var(--txt-secondary)}.cf-input,.cf-textarea{padding:.5rem .75rem;background:var(--bg-page);border:1.5px solid var(--border-input);border-radius:.5rem;color:var(--txt-primary);font-size:.875rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.cf-input:focus,.cf-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61f}.cf-input.error,.cf-textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.cf-textarea{resize:vertical;min-height:100px}.cf-error{font-size:.75rem;color:#ef4444;margin:0}.cf-footer{display:flex;justify-content:flex-end;align-items:center;gap:.75rem;padding:.875rem 1.25rem;border-top:1px solid var(--border);flex-wrap:wrap}.cf-success{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:#16a34a1a;border:1px solid rgba(22,163,74,.25);border-radius:.5rem;color:var(--success);font-size:.875rem;font-weight:500;margin-bottom:1.25rem}.cf-error-banner{padding:.625rem .875rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#ef4444;font-size:.8rem;font-weight:500;margin-bottom:1rem}.btn-submit{background:var(--accent);color:#fff;border:none;border-radius:.5rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:background .15s,box-shadow .15s}.btn-submit:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 8px #2563eb4d}.btn-submit:disabled{opacity:.55;cursor:not-allowed}.btn-reset{background:var(--bg-page);color:var(--txt-secondary);border:1.5px solid var(--border);border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-reset:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.cf-spinner{display:inline-block;width:.875rem;height:.875rem;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:cf-spin .65s linear infinite}@keyframes cf-spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.message-item{flex-direction:column}.message-actions{justify-content:flex-end}.message-preview{white-space:normal}.cf-grid-2{grid-template-columns:1fr}.cf-footer{flex-direction:column;align-items:stretch}.btn-submit,.btn-reset{width:100%;justify-content:center}}.stat-emoji-shimmer,.stat-label-shimmer,.stat-value-shimmer{display:inline-block}.message-item.skeleton{cursor:default;pointer-events:none}.message-item.skeleton .message-avatar .shimmer{border-radius:50%}.message-item.skeleton .message-actions .shimmer{background:var(--bg-hover)}.pagination{display:flex;justify-content:center;margin-top:1rem}.page-btn{height:2rem;min-width:2rem;padding:0 .5rem;border-radius:.375rem;border:1.5px solid var(--border);background:var(--bg-page);color:var(--txt-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.req-page{padding:0}.req-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.req-header h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--txt-primary)}.req-header .text-muted{color:var(--txt-secondary);font-size:.875rem;margin:0}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:.5rem;padding:.5rem 1.1rem;font-size:.875rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:background .15s,box-shadow .15s}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 2px 8px #2563eb4d}.btn-icon{background:transparent;border:1px solid var(--border);border-radius:.375rem;width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:.875rem;color:var(--txt-secondary);transition:all .15s}.btn-icon:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.btn-icon.danger:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.stat-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;padding:.875rem 1rem;display:flex;align-items:center;gap:.875rem}.stat-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}.stat-label{font-size:.7rem;color:var(--txt-secondary);margin:0 0 .15rem}.stat-value{font-size:1.25rem;font-weight:700;color:var(--txt-primary);margin:0}table{width:100%;border-collapse:collapse;font-size:.875rem}.pagination-btns{display:flex;gap:.375rem}.empty-state{text-align:center;padding:3rem;color:var(--txt-secondary);font-size:.875rem}.loading-state{text-align:center;padding:3rem;color:var(--txt-secondary)}.spinner{display:inline-block;width:1.5rem;height:1.5rem;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .65s linear infinite;margin-bottom:.5rem}.form-textarea{resize:vertical;min-height:72px}.error-banner{padding:.625rem .875rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#ef4444;font-size:.8rem;font-weight:500}@media (max-width: 640px){.req-header{flex-direction:column;align-items:flex-start}.stats-row{grid-template-columns:1fr 1fr}.form-grid-2,.view-grid-2{grid-template-columns:1fr}.modal-card{max-width:100%}}.skel-table-head{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 90px 100px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 90px 100px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-name,.skel-td-company,.skel-td-project,.skel-td-contact,.skel-td-email{height:.8125rem;width:70%}.btn-download{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;background:var(--accent-dim);color:var(--accent);border:1.5px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:.375rem;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s;text-decoration:none}.btn-download:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.no-attachment{font-size:.75rem;color:var(--txt-muted);font-style:italic}.view-row-full{grid-column:1 / -1}.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 1fr 1fr 1fr 90px 100px 88px}.skel-td-attachment{height:1.6rem;width:80px;border-radius:.375rem}@media (max-width: 1024px){.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 1fr 90px 100px 88px}.skel-td-contact,.skel-table-head>.shimmer:nth-child(4){display:none}}@media (max-width: 768px){.data-table th:nth-child(4),.data-table td:nth-child(4){display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 90px 100px 88px}.skel-td-project,.skel-table-head>.shimmer:nth-child(3){display:none}}@media (max-width: 640px){.data-table th:nth-child(3),.data-table td:nth-child(3),.data-table th:nth-child(5),.data-table td:nth-child(5){display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 90px 88px}.skel-td-email,.skel-td-date,.skel-table-head>.shimmer:nth-child(5),.skel-table-head>.shimmer:nth-child(7){display:none}}.skel-table-head{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr 1fr 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr 1fr 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}@media (max-width: 768px){.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 1fr 110px 88px}.skel-td-mobile,.skel-td-email,.skel-td-experience,.skel-table-head>.shimmer:nth-child(4),.skel-table-head>.shimmer:nth-child(5),.skel-table-head>.shimmer:nth-child(6){display:none}}@media (max-width: 640px){.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 110px 88px}.skel-td-payment,.skel-table-head>.shimmer:nth-child(7){display:none}}.reg-page{padding:0}.reg-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.reg-header h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--txt-primary)}.reg-header .text-muted{color:var(--txt-secondary);font-size:.875rem;margin:0}.badge-payment{background:var(--badge-orange-bg);color:var(--badge-orange-c)}.badge-exp{background:var(--badge-blue-bg);color:var(--badge-blue-c)}.stats-row{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-bottom:1.5rem}.toolbar{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;padding:.875rem 1rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:180px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:.8rem;opacity:.55}.search-input{width:100%;padding:.5rem .5rem .5rem 2.1rem;border:1.5px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s}.table-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}thead th{background:var(--bg-table-head);padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-secondary);border-bottom:1.5px solid var(--border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}thead th:hover{color:var(--txt-primary)}tbody tr{border-bottom:1px solid var(--border);transition:background .13s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}tbody td{padding:.75rem 1rem;color:var(--txt-primary);vertical-align:middle}.td-muted{color:var(--txt-secondary);font-size:.8rem}.td-actions{display:flex;gap:.375rem}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:99px;font-size:.7rem;font-weight:600}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-top:1.5px solid var(--border);flex-wrap:wrap;gap:.75rem}.pagination-info{font-size:.8rem;color:var(--txt-secondary)}.pagination-btns{display:flex;gap:.375rem;flex-wrap:wrap}.page-btn{height:2rem;min-width:2rem;padding:0 .5rem;border-radius:.375rem;border:1.5px solid var(--border);background:var(--bg-page);color:var(--txt-secondary);font-size:.8rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.page-btn:hover:not(:disabled){background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:overlay-in .18s ease both}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:1rem;width:100%;max-width:520px;box-shadow:0 20px 60px #0000004d;animation:modal-in .22s cubic-bezier(.34,1.2,.64,1) both;overflow:hidden;max-height:90vh;display:flex;flex-direction:column}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{display:flex;align-items:center;gap:.75rem;padding:1.125rem 1.25rem;border-bottom:1px solid var(--border)}.modal-head-icon{width:2.25rem;height:2.25rem;border-radius:.6rem;background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.modal-head h3{margin:0;font-size:1rem;font-weight:700;color:var(--txt-primary)}.modal-head p{margin:.15rem 0 0;font-size:.78rem;color:var(--txt-muted)}.modal-close{margin-left:auto;width:1.875rem;height:1.875rem;border-radius:.5rem;border:1px solid var(--border);background:transparent;color:var(--txt-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;flex-shrink:0;transition:all .13s}.modal-close:hover{background:#ef44441a;color:#ef4444;border-color:#ef44444d}.modal-body{padding:1.25rem;overflow-y:auto;flex:1}.form-grid{display:grid;gap:1rem}.form-grid-2{grid-template-columns:1fr 1fr}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-label{font-size:.78rem;font-weight:600;color:var(--txt-secondary)}.form-input,.form-select,.form-textarea{padding:.5rem .75rem;background:var(--bg-page);border:1.5px solid var(--border-input);border-radius:.5rem;color:var(--txt-primary);font-size:.875rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61f}.form-input.error,.form-select.error,.form-textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.field-error{font-size:.75rem;color:#ef4444;margin:0}.modal-foot{display:flex;justify-content:flex-end;gap:.625rem;padding:.875rem 1.25rem;border-top:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:.5rem;padding:.5rem 1.1rem;font-size:.875rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:background .15s}.btn-danger:hover{background:var(--danger-hover)}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.btn-spinner{display:inline-block;width:.875rem;height:.875rem;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite}.btn-ghost{background:var(--bg-page);color:var(--txt-secondary);border:1.5px solid var(--border);border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:all .15s}.btn-ghost:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.view-grid{display:grid;gap:.875rem}.view-row{display:flex;flex-direction:column;gap:.2rem;padding:.75rem;background:var(--bg-page);border-radius:.5rem}.view-key{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-muted)}.view-val{font-size:.875rem;color:var(--txt-primary);word-break:break-word}.view-grid-2{grid-template-columns:1fr 1fr}.confirm-body{padding:1.5rem 1.25rem;text-align:center}.confirm-icon{font-size:2.5rem;margin-bottom:.75rem}.confirm-body h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--txt-primary)}.confirm-body p{margin:0;font-size:.875rem;color:var(--txt-secondary)}.skel-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);margin-bottom:1.25rem}.skel-table-head{display:grid;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-name,.skel-td-designation,.skel-td-organization,.skel-td-mobile,.skel-td-email,.skel-td-experience,.skel-td-payment{height:.8125rem;width:70%}@media (max-width: 1024px){.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 1fr 1fr 1fr 110px 88px}.skel-td-designation,.skel-td-organization,.skel-table-head>.shimmer:nth-child(2),.skel-table-head>.shimmer:nth-child(3){display:none}}@media (max-width: 768px){.data-table th:nth-child(2),.data-table td:nth-child(2),.data-table th:nth-child(3),.data-table td:nth-child(3),.data-table th:nth-child(5),.data-table td:nth-child(5){display:none}.stats-row{grid-template-columns:1fr 1fr}.toolbar{flex-direction:column;align-items:stretch}.search-wrap{max-width:none}.pagination{flex-direction:column;align-items:flex-start}.pagination-btns{flex-wrap:wrap}.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 1fr 110px 88px}.skel-td-mobile,.skel-td-email,.skel-td-experience,.skel-table-head>.shimmer:nth-child(4),.skel-table-head>.shimmer:nth-child(5),.skel-table-head>.shimmer:nth-child(6){display:none}}@media (max-width: 640px){.reg-header{flex-direction:column;align-items:flex-start}.reg-header button{width:100%;justify-content:center}.data-table th:nth-child(4),.data-table td:nth-child(4),.data-table th:nth-child(7),.data-table td:nth-child(7){display:none}.modal-card{max-width:95%}.modal-head{flex-wrap:wrap}.form-grid-2,.view-grid-2{grid-template-columns:1fr}.skel-table-head,.skel-table-row{grid-template-columns:1fr 1fr 88px}.skel-td-payment,.skel-table-head>.shimmer:nth-child(7){display:none}}@media (max-width: 480px){.stats-row{grid-template-columns:1fr}.data-table th,.data-table td{padding:.5rem;font-size:.75rem}.btn-icon{width:1.75rem;height:1.75rem;font-size:.75rem}}.gallery-page{padding:0}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;padding:.5rem 1.1rem;border-radius:.5rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;transition:opacity .2s}.gallery-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.gallery-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.gallery-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0,0,0,.1));transform:translateY(-2px)}.gallery-card-image{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.gallery-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-card:hover .gallery-card-image img{transform:scale(1.04)}.image-placeholder{font-size:2.5rem;opacity:.45}.gallery-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.gallery-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-card-desc{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.gallery-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.gallery-table{width:100%;border-collapse:collapse;font-size:.875rem}.gallery-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.gallery-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.gallery-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.gallery-table th.sortable:hover{color:var(--accent)}.gallery-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.gallery-table tbody tr:last-child td{border-bottom:none}.gallery-table tbody tr:hover{background:var(--bg-hover)}.col-title{min-width:150px}.table-thumb{width:56px;height:40px;object-fit:cover;border-radius:.375rem;border:1px solid var(--border)}.table-thumb-placeholder{width:56px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.375rem;background:var(--bg-hover);border-radius:.375rem;border:1px solid var(--border)}.modal-actions{display:flex;justify-content:flex-end;gap:.625rem;padding-top:1rem;border-top:1px solid var(--border);margin-top:.25rem}.skel-card-img{aspect-ratio:16/9;width:100%}.skel-table-head{display:grid;grid-template-columns:64px 1fr 2fr 100px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:64px 1fr 2fr 100px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-thumb{width:56px;height:40px;border-radius:.375rem}.skel-td-date{height:.75rem;width:80%}@media (max-width: 768px){.col-desc{display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.gallery-grid{grid-template-columns:1fr}.search-wrapper{max-width:100%}.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:48px 1fr 80px 72px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(3){display:none}}.training-page{padding:0}.batch-badge{display:inline-block;padding:.2rem .6rem;font-size:.7rem;font-weight:700;border-radius:9999px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent)}.training-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:1.25rem}.training-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.training-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.training-card-header{padding:1rem 1rem 0;display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;flex-wrap:wrap}.training-card-header h3{margin:0;font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;color:var(--txt-primary)}.training-card-body{padding:.5rem 1rem;flex:1}.training-description{margin:0 0 .5rem;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.training-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.training-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.training-table{width:100%;border-collapse:collapse;font-size:.875rem}.training-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.training-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.training-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.training-table th.sortable:hover{color:var(--accent)}.training-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.training-table tbody tr:last-child td{border-bottom:none}.training-table tbody tr:hover{background:var(--bg-hover)}.skel-card-header{padding:1rem 1rem 0;display:flex;justify-content:space-between;align-items:center}.skel-table-head{display:grid;grid-template-columns:100px 1fr 2fr 140px 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:100px 1fr 2fr 140px 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-batch{height:.75rem;width:60%}.skel-td-trainer,.skel-td-date{height:.75rem;width:70%}@media (max-width: 768px){.col-desc{display:none}.skel-table-head,.skel-table-row{grid-template-columns:100px 1fr 140px 110px 88px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(3){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.training-grid{grid-template-columns:1fr}.col-trainer{display:none}.skel-table-head,.skel-table-row{grid-template-columns:100px 1fr 110px 88px}.skel-td-trainer,.skel-table-head>.shimmer:nth-child(4){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.training-card-header h3{font-size:.875rem}.training-description{font-size:.75rem}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.upcoming-page{padding:0}.upcoming-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:1.25rem}.upcoming-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.upcoming-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.upcoming-card-header{padding:1rem 1rem 0}.upcoming-card-header h3{margin:0;font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt-primary)}.upcoming-card-body{padding:.5rem 1rem;flex:1}.upcoming-description{margin:0 0 .5rem;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.upcoming-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.meta-item{background:var(--bg-hover);padding:.2rem .5rem;border-radius:.375rem;font-size:.7rem;color:var(--txt-secondary)}.upcoming-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.upcoming-table{width:100%;border-collapse:collapse;font-size:.875rem}.upcoming-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.upcoming-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.upcoming-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.upcoming-table th.sortable:hover{color:var(--accent)}.upcoming-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.upcoming-table tbody tr:last-child td{border-bottom:none}.upcoming-table tbody tr:hover{background:var(--bg-hover)}.col-desc{min-width:200px}.col-trainer{width:140px}.col-fee{width:100px}.table-desc{margin:0;color:var(--txt-secondary);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:340px;font-size:.8125rem;line-height:1.5}.skel-meta{display:flex;gap:.5rem;margin-top:.5rem}.skel-meta-item{height:1.25rem;border-radius:.375rem}.skel-table-head{display:grid;grid-template-columns:1fr 2fr 140px 100px 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:1fr 2fr 140px 100px 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-trainer,.skel-td-fee,.skel-td-date{height:.75rem;width:70%}@media (max-width: 768px){.col-desc{display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 140px 100px 110px 88px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(2){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.upcoming-grid{grid-template-columns:1fr}.col-trainer,.col-fee{display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 110px 88px}.skel-td-trainer,.skel-td-fee,.skel-table-head>.shimmer:nth-child(3),.skel-table-head>.shimmer:nth-child(4){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.upcoming-card-header h3{font-size:.875rem}.upcoming-description{font-size:.75rem}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.course-page{padding:0}.course-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:1.25rem}.course-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.course-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.course-card-header{padding:1rem 1rem 0}.course-card-header h3{margin:0;font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt-primary)}.course-card-body{padding:.5rem 1rem;flex:1}.course-description{margin:0;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.course-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.course-table{width:100%;border-collapse:collapse;font-size:.875rem}.course-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.course-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.course-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.course-table th.sortable:hover{color:var(--accent)}.course-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.course-table tbody tr:last-child td{border-bottom:none}.course-table tbody tr:hover{background:var(--bg-hover)}.col-desc{min-width:250px}.table-title{font-weight:600;display:block;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-desc{margin:0;color:var(--txt-secondary);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:400px;font-size:.8125rem;line-height:1.5}.form-group input,.form-group textarea{padding:.5625rem .75rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}.skel-card-header{padding:1rem 1rem 0}.skel-table-head{display:grid;grid-template-columns:1fr 2fr 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:1fr 2fr 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-desc{height:.75rem;width:85%}.skel-td-date{height:.75rem;width:70%}@media (max-width: 768px){.col-desc{display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 110px 88px}.skel-td-desc,.skel-table-head>.shimmer:nth-child(2){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.course-grid{grid-template-columns:1fr}.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 88px}.skel-td-date,.skel-table-head>.shimmer:nth-child(3){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.course-card-header h3{font-size:.875rem}.course-description{font-size:.75rem}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.participant-page{padding:0}.badge-id,.badge-batch{display:inline-block;padding:.2rem .6rem;font-size:.7rem;font-weight:700;border-radius:9999px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent)}.badge-batch{background:var(--bg-hover);color:var(--txt-secondary);border-color:var(--border)}.participant-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.25rem}.participant-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.participant-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.participant-card-image{position:relative;aspect-ratio:1 / 1;background:linear-gradient(135deg,var(--accent-dim, #ede9fe),var(--bg-hover, #f3f4f6));display:flex;align-items:center;justify-content:center;overflow:hidden}.participant-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.participant-card:hover .participant-card-image img{transform:scale(1.04)}.image-placeholder{font-size:3rem;opacity:.45}.participant-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.participant-card-body h3{margin:0;font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.participant-meta{display:flex;flex-wrap:wrap;gap:.5rem}.meta-badge{background:var(--bg-hover);padding:.2rem .5rem;border-radius:.375rem;font-size:.7rem;color:var(--txt-secondary)}.participant-email{font-size:.75rem;color:var(--txt-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-actions{display:flex;justify-content:flex-end;gap:.375rem;padding-top:.625rem;border-top:1px solid var(--border);margin-top:auto}.participant-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.participant-table{width:100%;border-collapse:collapse;font-size:.875rem}.participant-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.participant-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.participant-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.participant-table th.sortable:hover{color:var(--accent)}.participant-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.participant-table tbody tr:last-child td{border-bottom:none}.participant-table tbody tr:hover{background:var(--bg-hover)}.col-thumb{width:72px}.col-participant-id{width:130px}.col-batch{width:100px}.col-email{min-width:180px}.table-thumb{width:48px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}.table-thumb-placeholder{width:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--bg-hover);border:1px solid var(--border)}.skel-card-img{aspect-ratio:1 / 1;width:100%}.skel-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.skel-line{height:.875rem}.skel-card-actions{display:flex;justify-content:flex-end;gap:.375rem;padding-top:.625rem;border-top:1px solid var(--border);margin-top:.125rem}.skel-table-head{display:grid;grid-template-columns:64px 1fr 130px 100px 1fr 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:64px 1fr 130px 100px 1fr 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-thumb{width:48px;border-radius:50%}.skel-td-id,.skel-td-batch,.skel-td-date{height:.75rem;width:60%}.skel-td-email{height:.75rem;width:70%}@media (max-width: 1024px){.col-email{min-width:140px}}@media (max-width: 768px){.col-email{display:none}.skel-table-head,.skel-table-row{grid-template-columns:64px 1fr 130px 100px 110px 88px}.skel-td-email,.skel-table-head>.shimmer:nth-child(6){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.participant-grid{grid-template-columns:1fr}.col-participant-id,.col-batch,.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:64px 1fr 88px}.skel-td-id,.skel-td-batch,.skel-td-date,.skel-table-head>.shimmer:nth-child(3),.skel-table-head>.shimmer:nth-child(4),.skel-table-head>.shimmer:nth-child(6){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.form-row{grid-template-columns:1fr;gap:.75rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.participant-card-body h3{font-size:.875rem}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}.jobs-page{padding:0}.jobs-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.jobs-table{width:100%;border-collapse:collapse;font-size:.875rem}.jobs-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.jobs-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.jobs-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.jobs-table th.sortable:hover{color:var(--accent)}.jobs-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.jobs-table tbody tr:last-child td{border-bottom:none}.jobs-table tbody tr:hover{background:var(--bg-hover)}.badge-green{background:#10b9811a;color:#10b981;border-color:#10b9814d}.badge-orange{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b4d}.badge-gray{background:var(--bg-hover);color:var(--txt-secondary);border-color:var(--border)}.modal{background:var(--bg-card);border-radius:.875rem;width:100%;max-width:560px;max-height:90dvh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;border:1px solid var(--border);animation:slideUp .18s ease;overflow:hidden}.skel-table-head{display:grid;grid-template-columns:50px 1fr 110px 110px 100px 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:50px 1fr 110px 110px 100px 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-date,.skel-td-status{height:.75rem;width:70%}@media (max-width: 768px){.skel-table-head,.skel-table-row{grid-template-columns:50px 1fr 110px 110px 88px}.skel-td-status,.skel-table-head>.shimmer:nth-child(5){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.search-wrapper{max-width:100%}.skel-table-head,.skel-table-row{grid-template-columns:50px 1fr 88px}.skel-td-date,.skel-table-head>.shimmer:nth-child(3),.skel-table-head>.shimmer:nth-child(4){display:none}}.circulars-page{padding:0}.circulars-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.circulars-table{width:100%;border-collapse:collapse;font-size:.875rem}.circulars-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.circulars-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.circulars-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.circulars-table th.sortable:hover{color:var(--accent)}.circulars-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.circulars-table tbody tr:last-child td{border-bottom:none}.circulars-table tbody tr:hover{background:var(--bg-hover)}.col-sn{width:50px}.col-title{min-width:180px}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--txt-secondary)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.72rem;font-weight:700;border:1px solid}.badge-blue{background:#6366f11a;color:#6366f1;border-color:#6366f14d}.modal{background:var(--bg-card);border-radius:.875rem;width:100%;max-width:680px;max-height:90dvh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;border:1px solid var(--border);animation:slideUp .18s ease;overflow:hidden}.form-group input,.form-group textarea,.form-group select{padding:.5625rem .75rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.skel-table-head{display:grid;grid-template-columns:50px 1fr 90px 100px 120px 110px 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-table-row{display:grid;grid-template-columns:50px 1fr 90px 100px 120px 110px 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-sn{width:30px;height:.75rem}.skel-td-title{height:.8125rem;width:70%}.skel-td-vacancy,.skel-td-salary,.skel-td-status,.skel-td-date{height:.75rem;width:70%}@media (max-width: 1024px){.skel-table-head,.skel-table-row{grid-template-columns:50px 1fr 100px 110px 110px 88px}.skel-td-salary,.skel-table-head>.shimmer:nth-child(4){display:none}}@media (max-width: 768px){.skel-table-head,.skel-table-row{grid-template-columns:50px 1fr 110px 110px 88px}.skel-td-vacancy,.skel-td-status,.skel-table-head>.shimmer:nth-child(3),.skel-table-head>.shimmer:nth-child(5){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.search-wrapper{max-width:100%}.skel-table-head,.skel-table-row{grid-template-columns:50px 1fr 88px}.skel-td-date,.skel-table-head>.shimmer:nth-child(6),.skel-table-head>.shimmer:nth-child(7){display:none}}.trainer-page{padding:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.page-header h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--txt-primary)}.text-muted{color:var(--txt-secondary);font-size:.875rem;margin:0}.page-header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.view-toggle{display:inline-flex;border:1px solid var(--border-input);border-radius:.5rem;overflow:hidden}.view-toggle-btn{background:transparent;border:none;padding:.4rem .875rem;font-size:.8125rem;font-weight:600;cursor:pointer;color:var(--txt-secondary);transition:all .15s}.view-toggle-btn+.view-toggle-btn{border-left:1px solid var(--border-input)}.view-toggle-btn:hover{background:var(--bg-hover);color:var(--txt-primary)}.view-toggle-btn.active{background:var(--accent);color:#fff}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;padding:.5rem 1.1rem;border-radius:.5rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;transition:opacity .2s;white-space:nowrap}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-outline{background:transparent;border:1px solid var(--border-input);color:var(--txt-primary);padding:.5rem 1rem;border-radius:.5rem;font-weight:600;cursor:pointer;font-size:.875rem;transition:background .15s}.btn-outline:hover{background:var(--bg-hover)}.btn-spinner{display:inline-block;width:.875rem;height:.875rem;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-bar{margin-bottom:1.25rem}.search-wrapper{position:relative;max-width:380px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:.875rem;pointer-events:none;color:var(--txt-muted)}.search-input{width:100%;padding:.5rem .75rem .5rem 2.25rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}.empty-state{text-align:center;padding:3rem 1.5rem;background:var(--bg-card);border-radius:.75rem;border:1px dashed var(--border);color:var(--txt-secondary);font-size:.9375rem;grid-column:1 / -1}.type-badge{display:inline-block;padding:.2rem .6rem;font-size:.7rem;font-weight:700;border-radius:9999px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent)}.trainer-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:1.25rem}.trainer-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.trainer-card:hover{box-shadow:var(--shadow-card, 0 4px 24px rgba(0, 0, 0, .1));transform:translateY(-2px)}.trainer-card-header{padding:1rem 1rem 0;display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;flex-wrap:wrap}.trainer-card-header h3{margin:0;font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;color:var(--txt-primary)}.trainer-card-body{padding:.5rem 1rem;flex:1}.trainer-qualification,.trainer-experience{margin:0 0 .5rem;font-size:.8125rem;color:var(--txt-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.trainer-qualification:empty,.trainer-experience:empty{display:none}.card-actions{display:flex;justify-content:flex-end;gap:.375rem;padding:.75rem 1rem;border-top:1px solid var(--border);margin-top:auto}.icon-btn{background:transparent;border:1px solid var(--border);border-radius:.375rem;width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9375rem;transition:all .15s;color:var(--txt-primary)}.icon-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.delete-btn:hover{background:#ef444414;border-color:#ef4444;color:#ef4444}.trainer-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card);overflow-x:auto;margin-bottom:1.25rem}.trainer-table{width:100%;border-collapse:collapse;font-size:.875rem}.trainer-table thead{background:var(--bg-hover);border-bottom:1.5px solid var(--border)}.trainer-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.trainer-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.trainer-table th.sortable:hover{color:var(--accent)}.sort-icon{display:inline-block;margin-left:.25rem;font-size:.7rem;opacity:.6}.trainer-table td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--txt-primary)}.trainer-table tbody tr:last-child td{border-bottom:none}.trainer-table tbody tr:hover{background:var(--bg-hover)}.col-name{min-width:160px}.col-type{width:130px}.col-qualification{min-width:200px}.col-experience{min-width:180px}.col-date{width:110px;white-space:nowrap}.col-actions{width:88px}.table-title{font-weight:600;display:block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-qualification,.table-experience{margin:0;color:var(--txt-secondary);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:280px;font-size:.8125rem;line-height:1.4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease}.modal{background:var(--bg-card);border-radius:.875rem;width:100%;max-width:640px;max-height:90dvh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;border:1px solid var(--border);animation:slideUp .18s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h3{margin:0;font-size:1.0625rem;font-weight:700}.modal-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--txt-secondary);width:2rem;height:2rem;border-radius:.375rem}.modal-close:hover{background:var(--bg-hover)}.modal-form{display:flex;flex-direction:column;gap:1.125rem;padding:1.5rem;overflow-y:auto;flex:1}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.8125rem;font-weight:600;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.04em}.required-star{color:var(--danger, #ef4444)}.form-group input,.form-group textarea,.form-group select{padding:.5625rem .75rem;border:1px solid var(--border-input);border-radius:.5rem;background:var(--bg-input);color:var(--txt-primary);font-size:.875rem;outline:none;transition:border-color .15s;font-family:inherit}.form-group select{cursor:pointer}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent)}.error{font-size:.78125rem;color:var(--danger, #ef4444)}.modal-actions{display:flex;justify-content:flex-end;gap:.625rem;padding-top:1rem;border-top:1px solid var(--border);margin-top:.25rem;flex-wrap:wrap}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.shimmer{background:linear-gradient(90deg,var(--bg-hover, #f3f4f6) 25%,color-mix(in srgb,var(--bg-hover) 60%,var(--border)) 50%,var(--bg-hover) 75%);background-size:1200px 100%;animation:shimmer 1.4s infinite linear;border-radius:.375rem}.skel-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden}.skel-card-header{padding:1rem 1rem 0;display:flex;justify-content:space-between}.skel-card-body{padding:.5rem 1rem}.skel-line{height:.875rem;margin-bottom:.5rem}.skel-title{width:65%}.skel-desc{width:90%;height:.75rem}.skel-desc-short{width:55%}.skel-card-actions{display:flex;justify-content:flex-end;gap:.375rem;padding:.75rem 1rem;border-top:1px solid var(--border)}.skel-btn{width:2rem;height:2rem;border-radius:.375rem}.skel-table-wrap{border:1.5px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--bg-card)}.skel-table-head{display:grid;grid-template-columns:1fr 130px 2fr 180px 110px 88px;gap:1rem;padding:.75rem 1rem;background:var(--bg-hover);border-bottom:1px solid var(--border)}.skel-th{height:.75rem}.skel-table-row{display:grid;grid-template-columns:1fr 130px 2fr 180px 110px 88px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);align-items:center}.skel-td-name{height:.8125rem;width:70%}.skel-td-type,.skel-td-date{height:.75rem;width:60%}.skel-td-qualification,.skel-td-experience{height:.75rem;width:85%}.skel-td-actions{display:flex;gap:.375rem}@media (max-width: 1024px){.col-qualification,.col-experience{min-width:160px}}@media (max-width: 768px){.col-qualification,.col-experience{display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 130px 110px 88px}.skel-td-qualification,.skel-td-experience,.skel-table-head>.shimmer:nth-child(3),.skel-table-head>.shimmer:nth-child(4){display:none}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:space-between}.search-wrapper{max-width:100%}.trainer-grid{grid-template-columns:1fr}.col-type,.col-date{display:none}.skel-table-head,.skel-table-row{grid-template-columns:1fr 88px}.skel-td-type,.skel-td-date,.skel-table-head>.shimmer:nth-child(2),.skel-table-head>.shimmer:nth-child(5){display:none}.modal{max-width:95%;max-height:95dvh}.modal-header{padding:1rem}.modal-form{padding:1rem;gap:1rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}.btn-primary,.btn-outline{white-space:normal;text-align:center}}@media (max-width: 480px){.page-header h2{font-size:1.25rem}.text-muted{font-size:.75rem}.view-toggle-btn{padding:.3rem .7rem;font-size:.75rem}.btn-primary,.btn-outline{padding:.4rem .8rem;font-size:.8125rem}.trainer-card-header h3{font-size:.875rem}.icon-btn{width:1.75rem;height:1.75rem;font-size:.875rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-page: #f1f5f9;--bg-header: #ffffff;--bg-sidebar: #1e293b;--bg-card: #ffffff;--bg-input: #ffffff;--bg-table-head: #f8fafc;--bg-hover: #f1f5f9;--txt-primary: #0f172a;--txt-secondary: #475569;--txt-muted: #94a3b8;--txt-sidebar: #94a3b8;--txt-sidebar-active: #ffffff;--border: #e2e8f0;--border-input: #cbd5e1;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-dim: #dbeafe;--danger: #dc2626;--danger-hover: #b91c1c;--success: #16a34a;--warning: #d97706;--logo-bg: linear-gradient(135deg,#2563eb,#7c3aed);--shadow: 0 1px 4px rgba(0,0,0,.08);--shadow-card: 0 1px 6px rgba(0,0,0,.08);--shadow-sidebar: 2px 0 16px rgba(0,0,0,.12);--shadow-header: 0 1px 6px rgba(0,0,0,.06);--sidebar-item-h: 44px;--sidebar-active-bg: #2563eb;--sidebar-hover-bg: rgba(255,255,255,.06);--toggle-bg: #e2e8f0;--toggle-knob: #ffffff;--btn-logout-bg: transparent;--btn-logout-c: #94a3b8;--btn-logout-b: rgba(148,163,184,.25);--badge-blue-bg: #dbeafe;--badge-blue-c: #1d4ed8;--badge-green-bg: #dcfce7;--badge-green-c: #15803d;--badge-gray-bg: #f1f5f9;--badge-gray-c: #475569;--badge-orange-bg: #ffedd5;--badge-orange-c: #c2410c;--breadcrumb-c: #94a3b8;--breadcrumb-sep: #cbd5e1;--radius: 6px;--radius-lg: 10px;--font: "DM Sans", system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace;--sw: 260px;--header-h: 60px;--transition: .2s ease}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-page);color:var(--txt-primary);font-size:14px;line-height:1.5;transition:background var(--transition),color var(--transition)}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:var(--font);font-size:14px}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--txt-muted)}input,select,textarea{font-family:var(--font);font-size:14px;border:1px solid var(--border-input);border-radius:var(--radius);padding:9px 12px;width:100%;outline:none;background:var(--bg-input);color:var(--txt-primary);transition:border-color var(--transition),background var(--transition)}input::placeholder,textarea::placeholder{color:var(--txt-muted)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius);border:none;font-weight:500;font-size:13.5px;transition:background var(--transition),opacity var(--transition),box-shadow var(--transition);white-space:nowrap;flex-shrink:0}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb40}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--txt-secondary)}.btn-outline:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-input)}.btn-ghost{background:transparent;border:none;color:var(--txt-secondary);padding:8px}.btn-ghost:hover{background:var(--bg-hover);color:var(--txt-primary)}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-xs{padding:4px 9px;font-size:12px}.btn-icon{padding:8px;border-radius:var(--radius)}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border);padding:24px;transition:background var(--transition),border-color var(--transition)}.card-sm{padding:16px}.card-flat{box-shadow:none}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--border);transition:background var(--transition)}th{background:var(--bg-table-head);font-weight:600;font-size:12.5px;color:var(--txt-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-blue{background:var(--badge-blue-bg);color:var(--badge-blue-c)}.badge-green{background:var(--badge-green-bg);color:var(--badge-green-c)}.badge-gray{background:var(--badge-gray-bg);color:var(--badge-gray-c)}.badge-orange{background:var(--badge-orange-bg);color:var(--badge-orange-c)}.badge-role{background:var(--accent-dim);color:var(--accent)}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:18px}.form-group label{font-weight:500;font-size:13px;color:var(--txt-secondary)}.form-error{color:var(--danger);font-size:12px}.form-hint{color:var(--txt-muted);font-size:12px}.page-wrapper{display:flex;flex-direction:column;gap:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;flex-wrap:wrap;gap:12px}.page-header h2{font-size:21px;font-weight:700;color:var(--txt-primary);letter-spacing:-.3px}.page-actions{display:flex;align-items:center;gap:8px}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--breadcrumb-c);margin-bottom:22px}.breadcrumb-sep{color:var(--breadcrumb-sep)}.breadcrumb-current{color:var(--txt-secondary);font-weight:500}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px;display:flex;flex-direction:column;gap:6px;transition:background var(--transition),border-color var(--transition),transform .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014}.stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--txt-muted)}.stat-value{font-size:28px;font-weight:700;color:var(--txt-primary);letter-spacing:-1px;font-family:var(--font-mono)}.stat-meta{font-size:12px;color:var(--txt-muted)}.stat-icon{font-size:22px;margin-bottom:4px}.stat-trend{font-size:12px;font-weight:600;display:flex;align-items:center;gap:3px}.stat-trend.up{color:var(--stat-up,#16a34a)}.stat-trend.down{color:var(--stat-down,#dc2626)}.placeholder-block{background:repeating-linear-gradient(90deg,var(--bg-hover) 0px,var(--bg-hover) 12px,transparent 12px,transparent 20px);border-radius:var(--radius);opacity:.45}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:12px;color:var(--txt-muted);text-align:center}.empty-state-icon{font-size:40px;opacity:.5}.empty-state-title{font-size:16px;font-weight:600;color:var(--txt-secondary)}.empty-state-desc{font-size:13px;max-width:320px;line-height:1.6}.search-row{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.search-row input{max-width:280px}.pagination{display:flex;gap:5px;align-items:center;margin-top:18px;justify-content:flex-end}.pagination button{min-width:34px;height:34px;padding:0 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--txt-secondary);font-size:13px;font-weight:500;transition:background var(--transition),border-color var(--transition)}.pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination button:disabled{opacity:.4;cursor:default}.pagination button:not(:disabled):not(.active):hover{background:var(--bg-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.modal{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;box-shadow:0 12px 40px #00000040;border:1px solid var(--border);animation:slideUp .18s ease}.modal-lg{max-width:720px}.modal-sm{max-width:380px}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:17px;font-weight:700;color:var(--txt-primary)}.modal-close{background:none;border:none;font-size:20px;color:var(--txt-muted);line-height:1;padding:2px;border-radius:4px;transition:color var(--transition),background var(--transition)}.modal-close:hover{color:var(--txt-primary);background:var(--bg-hover)}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.skeleton{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--border) 50%,var(--bg-hover) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-end{display:flex;align-items:center;justify-content:flex-end;gap:10px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-muted{color:var(--txt-muted)}.text-sm{font-size:12.5px}.text-xs{font-size:11.5px}.font-mono{font-family:var(--font-mono)}.font-semibold{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-cell,.empty-cell{text-align:center!important;color:var(--txt-muted);padding:40px!important;font-style:italic}@media (max-width: 768px){.stat-grid{grid-template-columns:1fr 1fr}.page-header{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.stat-grid{grid-template-columns:1fr}}.confirm-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:1100;display:flex;align-items:center;justify-content:center}
