@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--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-container-width: fit-content;--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-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--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;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.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%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.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%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;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{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.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-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.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;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.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:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-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)}}.session-expiry-overlay{position:fixed;inset:0;z-index:100000;background:#1118278c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;pointer-events:auto}.session-expiry-dialog{width:100%;max-width:420px;background:#fff;border-radius:16px;padding:28px 24px 22px;box-shadow:0 25px 50px #0003,0 0 0 1px #0000000d;text-align:center}.session-expiry-icon{font-size:2.5rem;line-height:1;margin-bottom:12px}.session-expiry-title{margin:0 0 10px;font-size:1.25rem;font-weight:700;color:#111827}.session-expiry-text{margin:0 0 18px;font-size:.875rem;line-height:1.5;color:#4b5563}.session-expiry-countdown{display:flex;flex-direction:column;align-items:center;gap:2px;margin-bottom:22px;padding:14px;background:linear-gradient(135deg,#f59e0b14,#4f46e514);border:1px solid rgba(245,158,11,.2);border-radius:12px}.session-expiry-countdown-value{font-size:2.25rem;font-weight:800;font-variant-numeric:tabular-nums;color:#b45309;line-height:1}.session-expiry-countdown-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6b7280}.session-expiry-actions{display:flex;flex-direction:column;gap:10px}.session-expiry-btn{width:100%;padding:12px 18px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:opacity .2s,transform .15s}.session-expiry-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.session-expiry-btn-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.session-expiry-btn-primary:hover:not(:disabled){box-shadow:0 4px 14px #4f46e566;transform:translateY(-1px)}.session-expiry-btn-secondary{background:#f3f4f6;color:#374151;border:1.5px solid #e5e7eb}.session-expiry-btn-secondary:hover:not(:disabled){background:#e5e7eb}.session-expiry-no-refresh{margin:0;font-size:.85rem;color:#b91c1c;font-weight:500}.imp-modal-overlay{position:fixed;inset:0;z-index:2000;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:4rem 1rem 2rem}.imp-modal{position:relative;width:min(440px,100%);max-height:min(72vh,560px);background:var(--surface-color, #fff);border-radius:14px;box-shadow:0 24px 48px #0f172a2e;border:1px solid var(--border-color, #e5e7eb);display:flex;flex-direction:column;overflow:hidden}.imp-modal-header{padding:1.25rem 1.25rem .75rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.imp-modal-header h2{margin:0 0 .5rem;font-size:1.1rem;font-weight:700;color:var(--text-primary, #111827);padding-right:2rem}.imp-modal-sub{margin:0;font-size:.8rem;line-height:1.45;color:var(--text-secondary, #6b7280)}.imp-modal-close{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;border:none;background:transparent;font-size:1.5rem;line-height:1;color:#9ca3af;cursor:pointer;border-radius:8px}.imp-modal-close:hover{background:#f3f4f6;color:#374151}.imp-modal-body{padding:.75rem 1rem 1rem;flex:1;min-height:0;display:flex;flex-direction:column;gap:.5rem}.imp-modal-search{width:100%;padding:.55rem .75rem;border:1px solid var(--border-color, #e5e7eb);border-radius:10px;font-size:.9rem;outline:none}.imp-modal-search:focus{border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.imp-modal-err{font-size:.85rem;color:#b91c1c}.imp-modal-loading{padding:1.5rem;text-align:center;color:var(--text-secondary, #6b7280);font-size:.9rem}.imp-modal-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1;max-height:42vh}.imp-modal-empty{padding:1.25rem;text-align:center;color:var(--text-secondary, #6b7280);font-size:.9rem}.imp-modal-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .75rem;border:none;background:#f9fafb;border-radius:10px;margin-bottom:6px;cursor:pointer;text-align:left;font:inherit}.imp-modal-row:hover:not(:disabled){background:#eef2ff}.imp-modal-row:disabled{opacity:.65;cursor:not-allowed}.imp-modal-row-name{font-weight:600;font-size:.9rem;color:var(--text-primary, #111827)}.imp-modal-row-meta{font-size:.75rem;color:#6b7280;flex-shrink:0}.imp-modal-footer{padding:.75rem 1rem 1rem;border-top:1px solid var(--border-color, #e5e7eb);display:flex;justify-content:flex-end}.imp-modal-cancel{padding:.45rem 1rem;border-radius:8px;border:1px solid var(--border-color, #e5e7eb);background:#fff;font-weight:600;font-size:.85rem;cursor:pointer;color:#374151}.imp-modal-cancel:hover{background:#f9fafb}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:260px;background-color:var(--surface-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:20}.sidebar-header{height:72px;padding:0 24px;display:flex;align-items:center;border-bottom:1px solid var(--border-color)}.logo-icon{width:32px;height:32px;background-color:var(--primary-color);color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;border-radius:8px;margin-right:12px}.logo-text h2{font-size:16px;font-weight:700;color:var(--text-primary);line-height:1.2}.logo-text span{font-size:11px;color:var(--text-secondary);font-weight:500}.sidebar-nav{flex:1;overflow-y:auto;padding:24px 16px}.nav-section{margin-bottom:24px}.nav-section>span{display:block;font-size:11px;font-weight:700;color:var(--text-secondary);margin-bottom:12px;padding-left:12px;letter-spacing:.5px}.nav-section ul{list-style:none}.nav-item{display:flex;align-items:center;padding:10px 12px;border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:4px;transition:all .2s ease}.nav-item span{margin-left:12px}.nav-item:hover:not(.disabled){background-color:#f0f2f5;color:var(--text-primary)}.nav-item.active{background-color:#4f46e51a;color:var(--primary-color)}.nav-item.disabled{opacity:.5;cursor:not-allowed}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color)}.logout-button{display:flex;align-items:center;width:100%;padding:10px 12px;border-radius:8px;color:var(--danger-color);font-size:14px;font-weight:600;transition:all .2s ease}.logout-button span{margin-left:12px}.logout-button:hover{background-color:#fef2f2}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-color)}.top-header{height:72px;background-color:var(--surface-color);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 32px}.breadcrumb{font-size:14px;font-weight:600;color:var(--text-primary)}.top-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.impersonation-start-btn,.impersonation-revert-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border-color);white-space:nowrap}.impersonation-start-btn{background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#3730a3;border-color:#c7d2fe}.impersonation-start-btn:hover{filter:brightness(.97)}.impersonation-revert-btn{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.impersonation-revert-btn:hover:not(:disabled){background:#ffedd5}.impersonation-revert-btn:disabled{opacity:.65;cursor:not-allowed}.user-profile{display:flex;align-items:center}.avatar{width:36px;height:36px;background-color:#f0f2f5;color:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;margin-right:12px}.user-info{display:flex;flex-direction:column}.user-info .name{font-size:13px;font-weight:600;color:var(--text-primary)}.user-info .role{font-size:11px;color:var(--text-secondary)}.page-content{flex:1;overflow-y:auto;padding:32px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#f8fafb,#e8ebf0);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,#4f46e51a,#4f46e500 70%);top:-200px;right:-200px;border-radius:50%}.login-box{background:#ffffffe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);border-radius:24px;padding:48px;width:100%;max-width:440px;box-shadow:0 20px 40px #1a21380d;z-index:10}.login-header{text-align:center;margin-bottom:32px}.logo-placeholder{font-size:48px;margin-bottom:16px;display:inline-block;background:#f0f2f5;width:80px;height:80px;line-height:80px;border-radius:24px}.login-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-header p{font-size:14px;color:var(--text-secondary)}.error-message{background-color:#fef2f2;color:var(--danger-color);padding:12px 16px;border-radius:12px;font-size:13px;font-weight:500;margin-bottom:24px;border:1px solid #FEE2E2}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.form-group input{width:100%;padding:14px 16px;background-color:#f8fafb;border:1px solid var(--border-color);border-radius:12px;font-size:14px;color:var(--text-primary);transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--primary-color);background-color:var(--surface-color);box-shadow:0 0 0 4px #4f46e51a}.login-button{width:100%;padding:16px;background-color:var(--primary-color);color:#fff;border-radius:12px;font-size:15px;font-weight:600;margin-top:12px;transition:all .2s ease;box-shadow:0 4px 12px #4f46e533}.login-button:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e540}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{position:absolute;bottom:32px;text-align:center;width:100%;font-size:12px;color:var(--text-secondary)}.login-kvkk-block{margin-bottom:16px;padding:14px;border-radius:12px;background:#f4f6f9;border:1px solid var(--border-color)}.login-kvkk-title{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px}.login-kvkk-scroll{max-height:120px;overflow-y:auto;padding:10px 12px;font-size:12px;line-height:1.5;color:var(--text-primary);background:#fff;border-radius:10px;border:1px solid var(--border-color);margin-bottom:10px;white-space:pre-wrap}.login-kvkk-check{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text-primary);cursor:pointer}.login-kvkk-check input{margin-top:3px;width:16px;height:16px;flex-shrink:0}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.dashboard-container{max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:32px}.dashboard-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.dashboard-header p{font-size:14px;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.stat-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:16px;padding:24px;display:flex;align-items:flex-start;box-shadow:0 4px 12px #1a213805;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #1a21380d}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-right:16px}.stat-icon.users{background-color:#4f46e51a}.stat-icon.leave{background-color:#d977061a}.stat-icon.rooms{background-color:#0596691a}.stat-icon.cash{background-color:#dc26261a}.stat-info h3{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.stat-trend{font-size:12px;font-weight:500}.stat-trend.positive{color:var(--success-color)}.stat-trend.negative{color:var(--danger-color)}.stat-trend.neutral{color:var(--text-secondary)}.charts-area{display:grid;grid-template-columns:2fr 1fr;gap:24px}.chart-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:16px;padding:24px}.chart-card h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.placeholder-chart{height:240px;background-color:#f8fafb;border:1px dashed var(--border-color);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:14px}.recent-list{list-style:none}.recent-list li{display:flex;align-items:flex-start;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--border-color)}.recent-list li:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.dot{width:10px;height:10px;border-radius:5px;margin-top:4px;margin-right:12px}.details{display:flex;flex-direction:column}.details .title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.details .meta{font-size:12px;color:var(--text-secondary)}@media(max-width:1024px){.charts-area{grid-template-columns:1fr}}.meeting-rooms-container{padding:24px;background-color:#f8fafb;min-height:100%}.mr-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px}.mr-header-titles h2{font-size:24px;font-weight:700;color:#1a2138;margin:0 0 6px}.mr-header-titles p{font-size:14px;color:#a0a7b5;margin:0}.mr-header-actions{display:flex;gap:12px}.mr-tabs{display:flex;gap:24px;border-bottom:1px solid #E5E7EB;margin-bottom:24px}.mr-tab{padding:12px 4px;background:transparent;border:none;font-size:15px;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.mr-tab:hover{color:#111827}.mr-tab.active{color:#4f46e5;border-bottom-color:#4f46e5}.mr-tab-badge{display:inline-block;margin-left:6px;font-size:11px;font-weight:600;color:#6366f1;background:#eef2ff;padding:2px 8px;border-radius:6px;vertical-align:middle}.mr-tab.active .mr-tab-badge{background:#e0e7ff;color:#4338ca}.mr-calendar-intro{font-size:13px;line-height:1.5;color:#475569;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border:1px solid #E2E8F0;border-radius:10px;padding:12px 16px;margin-bottom:16px}.mr-calendar-intro strong{color:#1e293b}.mr-res-callout{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:14px;line-height:1.5;color:#334155;background:#eff6ff;border:1px solid #BFDBFE;border-radius:10px;padding:12px 16px;margin-bottom:16px}.mr-res-callout-link{background:none;border:none;padding:0;font:inherit;font-weight:700;color:#2563eb;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.mr-res-callout-link:hover{color:#1d4ed8}.mr-table-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #00000008;overflow-x:auto}.mr-table{width:100%;border-collapse:collapse}.mr-table th{text-align:left;padding:14px 16px;font-size:13px;font-weight:600;color:#8f95a5;border-bottom:1px solid #E8ECF2;text-transform:uppercase}.mr-table td{padding:16px;font-size:14px;color:#1a2138;border-bottom:1px solid #F5F6F8;vertical-align:middle}.mr-color-box{width:20px;height:20px;border-radius:4px;display:inline-block;border:1px solid rgba(0,0,0,.1)}.mr-actions{display:flex;gap:8px}.schedule-filter-bar{display:flex;align-items:center;gap:16px;margin-bottom:20px;background:#fff;padding:16px;border-radius:12px;box-shadow:0 2px 8px #00000008}.schedule-filter-bar label{font-size:14px;font-weight:600;color:#374151}.date-input{padding:8px 12px;border:1px solid #D1D5DB;border-radius:6px;font-family:inherit;font-size:14px}.mr-modal-overlay{position:fixed;inset:0;background-color:#11182766;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.mr-modal-content{background:#fff;width:100%;max-width:500px;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column}.mr-modal-header{padding:20px 24px;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center}.mr-modal-header h3{margin:0;font-size:18px;color:#111827}.mr-modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;line-height:1}.mr-modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.mr-form-group{display:flex;flex-direction:column;gap:6px}.mr-form-group label{font-size:13px;font-weight:600;color:#374151}.mr-input{padding:10px 14px;border:1px solid #D1D5DB;border-radius:6px;font-family:inherit;font-size:14px}.mr-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.mr-color-picker{padding:2px 4px;height:40px;width:100%}.mr-modal-footer{padding:16px 24px;background:#f9fafb;border-top:1px solid #E5E7EB;border-bottom-left-radius:12px;border-bottom-right-radius:12px;display:flex;justify-content:flex-end;gap:12px}.btn-cancel{background:#fff;border:1px solid #D1D5DB;padding:10px 16px;border-radius:6px;font-weight:500;color:#374151;cursor:pointer}.btn-save{background:#4f46e5;border:none;padding:10px 20px;border-radius:6px;font-weight:600;color:#fff;cursor:pointer}.cal-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px;flex-wrap:wrap}.cal-toolbar-left{display:flex;align-items:center;gap:8px}.cal-toolbar-right{display:flex;align-items:center;gap:12px}.cal-nav-btn{width:36px;height:36px;border-radius:8px;border:1px solid #E5E7EB;background:#fff;font-size:20px;font-weight:600;color:#374151;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.cal-nav-btn:hover{background:#f3f4f6;border-color:#d1d5db}.cal-today-btn{padding:7px 16px;border-radius:8px;border:1px solid #E5E7EB;background:#fff;font-size:13px;font-weight:600;color:#374151;cursor:pointer;transition:all .15s}.cal-today-btn:hover{background:#eef2ff;color:#4f46e5;border-color:#c7d2fe}.cal-title{font-size:18px;font-weight:700;color:#1a2138;margin:0 0 0 8px}.cal-room-select{padding:7px 12px;border:1px solid #E5E7EB;border-radius:8px;font-size:13px;font-weight:500;color:#374151;background:#fff;cursor:pointer;min-width:140px}.cal-room-select:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.cal-view-switcher{display:flex;border:1px solid #E5E7EB;border-radius:8px;overflow:hidden}.cal-view-btn{padding:7px 16px;border:none;background:#fff;font-size:13px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .15s;border-right:1px solid #E5E7EB}.cal-view-btn:last-child{border-right:none}.cal-view-btn:hover{background:#f9fafb;color:#374151}.cal-view-btn.active{background:#4f46e5;color:#fff}.cal-legend{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.cal-legend-item{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;color:#6b7280;background:#fff;border:1px solid #E5E7EB;cursor:pointer;transition:all .15s}.cal-legend-item:hover{border-color:#d1d5db}.cal-legend-item.selected{border-color:#4f46e5;color:#4f46e5;background:#eef2ff}.cal-legend-color{width:10px;height:10px;border-radius:50%}.cal-container{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000000a;overflow:hidden}.cal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px}.cal-loading p{color:#9ca3af;font-size:14px}.cal-spinner{width:32px;height:32px;border:3px solid #E5E7EB;border-top-color:#4f46e5;border-radius:50%;animation:cal-spin .8s linear infinite}@keyframes cal-spin{to{transform:rotate(360deg)}}.cal-day-view{padding:0}.cal-time-grid{display:flex;flex-direction:column}.cal-time-row{display:flex;min-height:64px;border-bottom:1px solid #F3F4F6}.cal-time-row:last-child{border-bottom:none}.cal-time-label{width:72px;min-width:72px;padding:8px 12px;font-size:12px;font-weight:500;color:#9ca3af;text-align:right;border-right:1px solid #F3F4F6;flex-shrink:0}.cal-time-slot{flex:1;position:relative;padding:2px 8px}.cal-event{position:absolute;left:8px;right:8px;border-radius:8px;padding:6px 10px;cursor:pointer;transition:all .15s;z-index:1;overflow:hidden}.cal-event:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a;z-index:2}.cal-event-time{font-size:11px;font-weight:700;margin-bottom:2px}.cal-event-title{font-size:13px;font-weight:600;color:#1a2138;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event-room{font-size:11px;font-weight:500;opacity:.8}.cal-event-compact{padding:3px 6px;border-radius:6px}.cal-event-title-compact{font-size:11px;font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event-time-compact{font-size:10px;color:#9ca3af;font-weight:500}.cal-week-view{overflow-x:auto}.cal-week-header{display:grid;grid-template-columns:72px repeat(7,1fr);border-bottom:2px solid #E5E7EB;position:sticky;top:0;background:#fff;z-index:5}.cal-week-time-gutter{border-right:1px solid #F3F4F6}.cal-week-day-col-header{padding:12px 4px;text-align:center;border-right:1px solid #F3F4F6}.cal-week-day-col-header:last-child{border-right:none}.cal-week-day-col-header.is-today{background:#eef2ff}.cal-week-day-name{display:block;font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.cal-week-day-number{display:inline-flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#374151;margin-top:2px;width:32px;height:32px;border-radius:50%}.cal-week-day-number.today-badge{background:#4f46e5;color:#fff}.cal-week-body{max-height:600px;overflow-y:auto}.cal-week-time-row{display:grid;grid-template-columns:72px repeat(7,1fr);min-height:64px;border-bottom:1px solid #F3F4F6}.cal-week-cell{position:relative;border-right:1px solid #F3F4F6;min-height:64px;padding:2px}.cal-week-cell:last-child{border-right:none}.cal-month-view{padding:0}.cal-month-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:2px solid #E5E7EB}.cal-month-col-header{padding:12px 8px;text-align:center;font-size:12px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.cal-month-body{display:flex;flex-direction:column}.cal-month-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid #F3F4F6}.cal-month-row:last-child{border-bottom:none}.cal-month-cell{min-height:100px;padding:6px 8px;border-right:1px solid #F3F4F6;cursor:pointer;transition:background .1s}.cal-month-cell:last-child{border-right:none}.cal-month-cell:hover{background:#fafbff}.cal-month-cell.other-month{opacity:.4}.cal-month-cell.is-today{background:#eef2ff}.cal-month-day-number{font-size:14px;font-weight:600;color:#374151;margin-bottom:4px;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%}.cal-month-day-number.today-badge{background:#4f46e5;color:#fff}.cal-month-events{display:flex;flex-direction:column;gap:2px}.cal-month-event-dot{display:flex;align-items:center;gap:4px;padding:2px 6px;border-radius:4px;font-size:11px;cursor:pointer;transition:transform .1s;overflow:hidden}.cal-month-event-dot:hover{transform:scale(1.02)}.cal-month-event-time{font-weight:700;font-size:10px;flex-shrink:0}.cal-month-event-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-month-more{font-size:11px;font-weight:600;color:#6b7280;padding:2px 6px;cursor:pointer}.cal-month-more:hover{color:#4f46e5}.cal-detail-overlay{position:fixed;inset:0;background:#11182759;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:cal-fade-in .15s ease}@keyframes cal-fade-in{0%{opacity:0}to{opacity:1}}.cal-detail-card{background:#fff;border-radius:16px;width:100%;max-width:420px;box-shadow:0 24px 48px #0000001f;overflow:hidden;animation:cal-slide-up .2s ease}@keyframes cal-slide-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.cal-detail-header{padding:20px 24px;border-bottom:1px solid #F3F4F6;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.cal-detail-header h3{margin:0 0 6px;font-size:18px;font-weight:700;color:#111827}.cal-detail-room{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700}.cal-detail-close{width:32px;height:32px;border-radius:8px;border:none;background:#f3f4f6;color:#6b7280;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.cal-detail-close:hover{background:#e5e7eb;color:#374151}.cal-detail-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.cal-detail-row{display:flex;align-items:center;gap:10px;font-size:14px;color:#374151}.cal-detail-icon{font-size:16px;width:24px;text-align:center;flex-shrink:0}.cal-detail-footer{padding:16px 24px;border-top:1px solid #F3F4F6;display:flex;justify-content:flex-end}.cal-detail-cancel-btn{padding:8px 20px;border-radius:8px;border:1px solid #FCA5A5;background:#fef2f2;color:#ef4444;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.cal-detail-cancel-btn:hover{background:#fee2e2;border-color:#f87171}.mr-res-filter-card{margin-bottom:1rem}.mr-res-presets{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #F3F4F6}.mr-res-presets-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.mr-res-presets-btns{display:flex;flex-wrap:wrap;gap:8px}.mr-preset-btn{padding:6px 14px;font-size:13px;font-weight:600;color:#4f46e5;background:#eef2ff;border:1px solid #C7D2FE;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.mr-preset-btn:hover{background:#e0e7ff;border-color:#a5b4fc}.mr-res-filter-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.mr-res-search-group{grid-column:span 1;min-width:200px}@media(min-width:900px){.mr-res-search-group{grid-column:span 2}}.mr-res-summary{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding:12px 16px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #E2E8F0;border-radius:10px}.mr-res-summary-text{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;font-size:14px;color:#334155}.mr-res-summary-text strong{font-size:18px;color:#1e293b}.mr-res-summary-muted{font-size:13px;color:#94a3b8}.mr-res-range-hint{font-size:13px;color:#64748b;font-weight:500}.mr-res-table-wrap{padding:0;overflow:hidden}.mr-res-loading{padding:2.5rem;text-align:center;color:#64748b;font-size:14px}.mr-res-table-scroll{overflow-x:auto;max-height:min(70vh,720px);overflow-y:auto}.mr-res-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;box-shadow:0 1px #e8ecf2}.mr-res-row{cursor:pointer;transition:background .12s ease}.mr-res-row:hover{background:#f8faff!important}.mr-res-table tbody tr:nth-child(2n){background:#fcfcfd}.mr-res-cell-date{min-width:200px;max-width:280px;vertical-align:top}.mr-res-date-main{font-size:13px;color:#374151;line-height:1.35}.mr-res-cell-time{white-space:nowrap;vertical-align:middle}.mr-res-time-pill{display:inline-block;padding:4px 10px;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;color:#1e293b;background:#f1f5f9;border-radius:8px}.mr-res-room-badge{display:inline-block;padding:5px 10px;font-size:13px;font-weight:600;border-radius:8px;border:1px solid}.mr-res-cell-title{min-width:180px;max-width:360px;vertical-align:top}.mr-res-title-text{font-weight:600;color:#111827;font-size:14px;line-height:1.35}.mr-res-desc-text{margin-top:4px;font-size:12px;color:#6b7280;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mr-res-cell-user{color:#475569;font-size:14px;white-space:nowrap}.mr-res-col-actions{width:100px;text-align:right;white-space:nowrap}.mr-res-cancel-btn{padding:6px 12px;font-size:12px;font-weight:600;color:#dc2626;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.mr-res-cancel-btn:hover{background:#fee2e2;border-color:#f87171}.mr-res-empty{text-align:center;padding:2.5rem 1rem!important;color:#6b7280;font-size:14px}.header-actions{display:flex;gap:16px;align-items:center}.search-input{padding:10px 16px;width:280px;border-radius:12px;border:1px solid var(--border-color);background-color:var(--surface-color);font-size:14px;transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.user-name-cell{display:flex;align-items:center}.user-avatar{width:36px;height:36px;border-radius:50%;background-color:#f0f2f5;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:700;margin-right:12px}.user-details .fullname{font-size:14px;font-weight:600;color:var(--text-primary)}.user-details .email{font-size:12px;color:var(--text-secondary)}.tc-badge{background-color:#f8fafb;padding:4px 8px;border-radius:6px;border:1px solid var(--border-color);font-family:monospace;font-size:13px;color:var(--text-secondary)}.role-select{padding:6px 12px;border-radius:8px;border:1px solid var(--border-color);font-size:13px;font-weight:600;cursor:pointer;background-color:#fff}.role-select.role-1{color:#dc2626;border-color:#dc26264d}.role-select.role-3{color:#d97706;border-color:#d977064d}.role-select.role-2{color:#4f46e5;border-color:#4f46e54d}.toggle-status-btn{padding:6px 16px;border-radius:16px;font-size:12px;font-weight:600;border:1px solid transparent;transition:all .2s}.toggle-status-btn.active{background-color:#0596691a;color:var(--success-color)}.toggle-status-btn.inactive{background-color:#f0f2f5;color:var(--text-secondary)}.toggle-status-btn:hover{filter:brightness(.95)}.pass-reset-btn{background-color:#d977061a;color:var(--warning-color)}.pass-reset-btn:hover{background-color:#d9770633}.modal-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:24px;line-height:1.5}.primary-btn.warning{background-color:var(--warning-color)}.primary-btn.warning:hover{background-color:#b45309}.filter-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000000f}.filter-group label{font-size:.75rem;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:0}.worksites-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;padding:20px 24px;display:flex;align-items:center;gap:16px;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 16px #0000000f}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}.stat-icon.green{background:#0596691a}.stat-icon.amber{background:#d977061a}.stat-icon.red{background:#dc26261a}.stat-info h4{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.stat-info span{font-size:13px;color:var(--text-secondary);font-weight:500}.coord-badge{display:inline-flex;align-items:center;gap:4px;background:#f0f4ff;padding:4px 10px;border-radius:6px;font-family:SF Mono,Fira Code,monospace;font-size:12px;color:#4f46e5;font-weight:500}.coord-badge .coord-label{color:#8b8fe8;font-weight:400}.radius-badge{display:inline-flex;align-items:center;gap:4px;background:#05966914;padding:4px 10px;border-radius:6px;font-size:13px;color:#059669;font-weight:600}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:16px;font-size:12px;font-weight:600;border:1px solid transparent}.status-badge.active{background:#0596691a;color:#059669;border-color:#05966926}.status-badge.inactive{background:#f0f2f5;color:var(--text-secondary);border-color:var(--border-color)}.qr-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;background:#4f46e514;color:var(--primary-color);border:1px solid rgba(79,70,229,.15);cursor:pointer;transition:all .2s}.qr-btn:hover{background:#4f46e526;box-shadow:0 2px 8px #4f46e526}.action-btn-group{display:flex;gap:6px;justify-content:flex-end;align-items:center}.edit-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;background:#d9770614;color:var(--warning-color);border:1px solid rgba(217,119,6,.15);cursor:pointer;transition:all .2s}.edit-btn:hover{background:#d9770626}.delete-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;background:#dc262614;color:var(--danger-color);border:1px solid rgba(220,38,38,.15);cursor:pointer;transition:all .2s}.delete-btn:hover{background:#dc262626}.user-count-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:16px;font-size:13px;font-weight:600;background:#f8fafb;color:var(--text-primary);border:1px solid var(--border-color)}.ws-modal-overlay{position:fixed;inset:0;background:#11182780;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:wsOverlayIn .2s ease-out}@keyframes wsOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes wsModalIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ws-modal{background:#fff;width:100%;max-width:540px;border-radius:16px;box-shadow:0 25px 50px #00000026,0 0 0 1px #0000000d;display:flex;flex-direction:column;animation:wsModalIn .25s ease-out;overflow:hidden}.ws-modal-header{background:linear-gradient(135deg,#4f46e5,#7c3aed);padding:24px 28px;display:flex;align-items:center;gap:14px}.ws-modal-header-icon{width:44px;height:44px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.ws-modal-header-text h3{margin:0;font-size:18px;font-weight:700;color:#fff}.ws-modal-header-text p{margin:2px 0 0;font-size:13px;color:#ffffffb3}.ws-modal-close{margin-left:auto;width:32px;height:32px;background:#ffffff26;border:none;border-radius:8px;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.ws-modal-close:hover{background:#ffffff4d}.ws-modal-body{padding:28px;display:flex;flex-direction:column;gap:20px;max-height:60vh;overflow-y:auto}.ws-form-group{display:flex;flex-direction:column;gap:6px}.ws-form-group label{font-size:13px;font-weight:600;color:#374151;display:flex;align-items:center;gap:6px}.ws-form-group label .label-icon{font-size:14px}.ws-form-group label .required-star{color:#ef4444;font-weight:700}.ws-form-input{width:100%;padding:11px 14px;border:1.5px solid #E5E7EB;border-radius:10px;font-size:14px;font-family:inherit;background:#fafbfc;color:var(--text-primary);transition:all .2s}.ws-form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f;background:#fff}.ws-form-input::placeholder{color:#b0b6c3}textarea.ws-form-input{resize:vertical;min-height:70px}.ws-form-input[type=number]{-moz-appearance:textfield;appearance:textfield}.ws-form-input[type=number]::-webkit-outer-spin-button,.ws-form-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0}.ws-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ws-input-wrapper{position:relative}.ws-input-wrapper .ws-form-input{padding-left:38px}.ws-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:15px;pointer-events:none;color:#9ca3af}.ws-form-hint{font-size:12px;color:#9ca3af;margin-top:2px}.ws-modal-footer{padding:18px 28px;background:#f9fafb;border-top:1px solid #E5E7EB;display:flex;justify-content:flex-end;gap:10px}.ws-btn-cancel{padding:10px 20px;border-radius:10px;border:1.5px solid #E5E7EB;background:#fff;color:#374151;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.ws-btn-cancel:hover{background:#f3f4f6;border-color:#d1d5db}.ws-btn-submit{padding:10px 24px;border-radius:10px;border:none;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.ws-btn-submit:hover:not(:disabled){box-shadow:0 4px 16px #4f46e566;transform:translateY(-1px)}.ws-btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.ws-form-error{background:#fef2f2;border:1px solid #FECACA;border-radius:10px;padding:10px 14px;color:#dc2626;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px}.address-cell{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-secondary);font-size:13px}.address-cell.empty{color:#c4c9d4;font-style:italic}.site-name-cell{display:flex;align-items:center;gap:12px}.site-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.site-name-text{font-size:14px;font-weight:600;color:var(--text-primary)}.org-chart-wrapper{width:100%;overflow:hidden;background:#f1f5f9;border-radius:12px;height:70vh;min-height:500px;position:relative;box-shadow:inset 0 2px 10px #00000008}.chart-container-div{width:100%;height:100%}.ws-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ws-modal{background:#fff;padding:0;border-radius:12px;width:100%;max-width:400px;box-shadow:0 10px 25px #0000001a}.ws-form-group{margin-bottom:20px}.ws-form-label{display:block;margin-bottom:8px;font-weight:600;color:#334155;font-size:14px}.ws-form-input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;outline:none;transition:all .2s}.ws-form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.ws-modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:25px}.ws-btn-cancel{padding:8px 16px;background:#e2e8f0;color:#475569;border:none;border-radius:6px;cursor:pointer;font-weight:600}.ws-btn-submit{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.ws-btn-submit:disabled{opacity:.6;cursor:not-allowed}.ws-btn-danger{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;margin-right:auto}.announcement-container{padding:24px;background-color:#f8fafb;min-height:100%}.announcement-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px}.announcement-titles h2{font-size:24px;font-weight:700;color:#1a2138;margin:0 0 6px}.announcement-titles p{font-size:14px;color:#a0a7b5;margin:0}.add-announcement-btn{background-color:#4f46e5;color:#fff;border:none;border-radius:8px;padding:10px 18px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 6px #4f46e533}.add-announcement-btn:hover{background-color:#4338ca;transform:translateY(-1px)}.announcement-table-wrapper{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #00000008;overflow-x:auto}.announcement-table{width:100%;border-collapse:collapse}.announcement-table th{text-align:left;padding:14px 16px;font-size:13px;font-weight:600;color:#8f95a5;border-bottom:1px solid #E8ECF2;text-transform:uppercase;letter-spacing:.5px}.announcement-table td{padding:16px;font-size:14px;color:#1a2138;border-bottom:1px solid #F5F6F8;vertical-align:middle}.announcement-title-cell{display:flex;align-items:center;gap:12px}.announcement-img-thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;background-color:#f8fafb;border:1px solid #E8ECF2}.announcement-tag{display:inline-block;padding:4px 10px;background-color:#eef2ff;color:#4f46e5;border-radius:20px;font-size:12px;font-weight:600}.announcement-actions{display:flex;gap:10px}.btn-icon{background:none;border:none;font-size:16px;cursor:pointer;padding:6px;border-radius:6px;transition:background .2s}.btn-edit{color:#4f46e5;background-color:#f0f4ff}.btn-edit:hover{background-color:#e0ebff}.modal-overlay{position:fixed;inset:0;background-color:#0006;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 25px #0000001a}.modal-header{padding:20px 24px;border-bottom:1px solid #E8ECF2;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:18px;color:#1a2138}.close-btn{background:none;border:none;font-size:24px;color:#a0a7b5;cursor:pointer;line-height:1}.modal-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#374151}.form-input{padding:12px 14px;border:1px solid #D1D5DB;border-radius:8px;font-size:14px;transition:all .2s;font-family:inherit}.form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.form-textarea{resize:vertical;min-height:120px}.modal-footer{padding:20px 24px;border-top:1px solid #E8ECF2;display:flex;justify-content:flex-end;gap:12px}.btn-cancel{background:#fff;border:1px solid #D1D5DB;padding:10px 16px;border-radius:8px;font-weight:500;color:#374151;cursor:pointer}.btn-save{background:#4f46e5;border:none;padding:10px 20px;border-radius:8px;font-weight:600;color:#fff;cursor:pointer}.btn-save:disabled{opacity:.6;cursor:not-allowed}.integrations-container{padding:24px;background-color:#f8fafb;min-height:100%}.integrations-header{margin-bottom:32px}.integrations-header h2{font-size:24px;font-weight:700;color:#1a2138;margin:0 0 8px}.integrations-header p{font-size:14px;color:#6b7280;margin:0}.integrations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.integration-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000a;border:1px solid #E5E7EB;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}.integration-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.integration-card-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.integration-icon{width:48px;height:48px;background-color:#eef2ff;color:#4f46e5;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.integration-title{font-size:16px;font-weight:600;color:#111827;margin:0}.integration-subtitle{font-size:13px;color:#6b7280;margin-top:4px}.integration-card-body{flex-grow:1;margin-bottom:24px}.integration-description{font-size:14px;color:#4b5563;line-height:1.5;margin:0}.integration-card-footer{display:flex;justify-content:flex-end}.btn-sync{background-color:#4f46e5;color:#fff;border:none;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s}.btn-sync:hover:not(:disabled){background-color:#4338ca}.btn-sync:disabled{opacity:.6;cursor:not-allowed}.sync-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.surveys-container{padding:24px;background-color:#f8fafb;min-height:100%}.sv-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px}.sv-header-titles h2{font-size:24px;font-weight:700;color:#1a2138;margin:0 0 6px}.sv-header-titles p{font-size:14px;color:#a0a7b5;margin:0}.btn-primary{background-color:#4f46e5;color:#fff;border:none;border-radius:8px;padding:10px 18px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.btn-primary:hover{background-color:#4338ca;transform:translateY(-1px)}.sv-table-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #00000008;overflow-x:auto}.sv-table{width:100%;border-collapse:collapse}.sv-table th{text-align:left;padding:14px 16px;font-size:13px;font-weight:600;color:#8f95a5;border-bottom:1px solid #E8ECF2;text-transform:uppercase}.sv-table td{padding:16px;font-size:14px;color:#1a2138;border-bottom:1px solid #F5F6F8;vertical-align:middle;white-space:nowrap}.sv-actions{display:flex;gap:8px}.btn-icon{background:none;border:none;padding:6px;border-radius:6px;cursor:pointer;transition:background .2s;font-size:16px}.btn-view{color:#10b981;background-color:#d1fae5}.btn-view:hover{background-color:#a7f3d0}.btn-edit{color:#4f46e5;background-color:#eef2ff}.btn-edit:hover{background-color:#e0e7ff}.btn-delete{color:#ef4444;background-color:#fef2f2}.btn-delete:hover{background-color:#fee2e2}.sv-modal-overlay{position:fixed;inset:0;background-color:#11182766;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.sv-modal-content{background:#fff;width:100%;max-width:900px;height:90vh;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column}.sv-modal-header{padding:20px 24px;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center}.sv-modal-header h3{margin:0;font-size:18px;color:#111827}.sv-modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;line-height:1}.sv-modal-body{padding:24px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.sv-form-row{display:flex;gap:16px}.sv-form-group{display:flex;flex-direction:column;gap:6px;flex:1}.sv-form-group label{font-size:13px;font-weight:600;color:#374151}.sv-input{padding:10px 14px;border:1px solid #D1D5DB;border-radius:6px;font-family:inherit;font-size:14px}.sv-textarea{resize:vertical;min-height:80px}.sv-modal-footer{padding:16px 24px;background:#f9fafb;border-top:1px solid #E5E7EB;border-bottom-left-radius:12px;border-bottom-right-radius:12px;display:flex;justify-content:flex-end;gap:12px}.sv-questions-container{border-top:1px solid #E5E7EB;padding-top:24px}.sv-questions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sv-questions-header h4{margin:0;font-size:16px}.btn-add-question{background-color:#eef2ff;color:#4f46e5;border:1px solid #C7D2FE;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:.2s}.btn-add-question:hover{background-color:#e0e7ff}.sv-question-card{background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;padding:16px;margin-bottom:16px}.sv-question-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.sv-question-input{flex:1}.sv-question-type-select{width:160px}.btn-remove{background:none;border:none;color:#ef4444;cursor:pointer;font-size:18px}.sv-options-list{margin-left:20px;display:flex;flex-direction:column;gap:8px}.sv-option-item{display:flex;align-items:center;gap:10px}.btn-add-option{background:none;border:none;color:#10b981;font-size:13px;font-weight:600;cursor:pointer;margin-top:8px;margin-left:20px;text-align:left}.sv-results-container{display:flex;flex-direction:column;gap:20px}.sv-result-card{background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;padding:16px}.sv-result-card h5{margin:0 0 16px;font-size:15px;color:#111827}.sv-option-result{margin-bottom:12px}.sv-option-label{display:flex;justify-content:space-between;margin-bottom:4px;font-size:13px;color:#374151}.sv-progress-bg{background-color:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.sv-progress-fill{background-color:#4f46e5;height:100%;border-radius:4px;transition:width .5s ease}.sv-text-entries{max-height:150px;overflow-y:auto;border:1px solid #E5E7EB;border-radius:6px;background:#fff}.sv-text-entry-item{padding:8px 12px;border-bottom:1px solid #F3F4F6;font-size:13px;color:#4b5563}.sv-text-entry-item:last-child{border-bottom:none}.df-container{padding:28px 32px;max-width:1280px;margin:0 auto}.df-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:28px;flex-wrap:wrap}.df-header h2{font-size:22px;font-weight:700;color:#1e293b;margin:0 0 4px}.df-header p{font-size:14px;color:#64748b;margin:0}.df-table-card{background:#fff;border-radius:14px;border:1px solid #E2E8F0;overflow:hidden;box-shadow:0 2px 12px #0000000d}.df-table{width:100%;border-collapse:collapse;font-size:13.5px}.df-table th{background:#f8fafc;color:#475569;font-weight:600;text-align:left;padding:13px 16px;border-bottom:1px solid #E2E8F0}.df-table td{padding:13px 16px;border-bottom:1px solid #F1F5F9;vertical-align:middle}.df-table tr:last-child td{border-bottom:none}.df-table tr:hover td{background:#fafbff}.df-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px}.df-badge-success{background:#dcfce7;color:#15803d}.df-badge-danger{background:#fee2e2;color:#dc2626}.df-badge-info{background:#eff6ff;color:#2563eb}.df-badge-neutral{background:#f3f4f6;color:#6b7280}.df-actions{display:flex;gap:6px}.df-btn-icon{width:34px;height:34px;border:none;border-radius:8px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}.df-btn-report{background:#eff6ff}.df-btn-report:hover{background:#dbeafe}.df-btn-edit{background:#f0fdf4}.df-btn-edit:hover{background:#dcfce7}.df-btn-delete{background:#fff1f2}.df-btn-delete:hover{background:#ffe4e6}.df-empty{text-align:center;padding:40px;color:#94a3b8;font-style:italic}.df-loading{text-align:center;padding:40px;color:#94a3b8}.df-btn-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.df-btn-primary:hover{opacity:.9}.df-btn-primary:disabled{opacity:.5;cursor:not-allowed}.df-btn-cancel{background:#f1f5f9;color:#475569;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer}.df-btn-cancel:hover{background:#e2e8f0}.df-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.df-modal{background:#fff;border-radius:18px;width:100%;max-width:720px;margin:auto;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column}.df-modal-wide{max-width:980px}.df-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 28px 16px;border-bottom:1px solid #F1F5F9}.df-modal-header h3{margin:0 0 4px;font-size:18px;font-weight:700;color:#1e293b}.df-modal-header p{margin:0;font-size:13px;color:#64748b}.df-btn-close{background:#f1f5f9;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:15px;flex-shrink:0}.df-modal-body{padding:24px 28px;overflow-y:auto;max-height:70vh}.df-modal-footer{padding:16px 28px;border-top:1px solid #F1F5F9;display:flex;justify-content:flex-end;gap:12px}.df-form-group{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}.df-form-group label{font-size:13px;font-weight:600;color:#374151}.df-input{width:100%;box-sizing:border-box;border:1px solid #D1D5DB;border-radius:8px;padding:9px 12px;font-size:13.5px;background:#fafafa;color:#1e293b;transition:border-color .15s}.df-input:focus{outline:none;border-color:#4f46e5;background:#fff}.df-input-sm{padding:7px 10px;font-size:13px}.df-textarea{min-height:80px;resize:vertical}.df-checks-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:4px}.df-check-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13.5px;color:#374151}.df-section-title{font-size:14px;font-weight:700;color:#4f46e5;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:8px;border-bottom:2px solid #EEF2FF}.df-btn-add-field{background:#eef2ff;color:#4f46e5;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.df-btn-add-field:hover{background:#e0e7ff}.df-empty-fields{text-align:center;padding:28px;background:#f9fafb;border:1px dashed #D1D5DB;border-radius:10px;color:#9ca3af;font-size:13px;margin-bottom:16px}.df-field-card{background:#f9fafb;border:1px solid #E2E8F0;border-radius:10px;padding:14px;margin-bottom:10px;transition:box-shadow .15s}.df-field-card:hover{box-shadow:0 2px 10px #4f46e514}.df-field-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.df-field-number{font-size:12px;font-weight:700;color:#7c3aed;background:#ede9fe;border-radius:6px;padding:2px 7px;flex-shrink:0}.df-field-btns{display:flex;gap:4px}.df-btn-move{background:#e2e8f0;border:none;border-radius:6px;width:28px;height:28px;cursor:pointer;font-size:13px}.df-btn-move:hover{background:#cbd5e1}.df-btn-move:disabled{opacity:.3;cursor:default}.df-btn-rm{background:#fee2e2;color:#dc2626;border:none;border-radius:6px;width:28px;height:28px;cursor:pointer;font-size:14px}.df-btn-rm:hover{background:#fecaca}.df-options-hint{margin-top:10px;display:flex;flex-direction:column;gap:6px}.df-report-table-wrapper{overflow-x:auto}.df-file-link{color:#4f46e5;font-size:12px;text-decoration:none;font-weight:600}.df-file-link:hover{text-decoration:underline}.df-modal-full{max-width:98vw;width:1400px;display:flex;flex-direction:column;max-height:92vh}.df-report-toolbar{display:flex;align-items:center;gap:12px;padding:12px 28px;border-bottom:1px solid #F1F5F9;background:#fafbff}.df-search-input{flex:1;max-width:380px}.df-result-count{font-size:13px;color:#64748b;white-space:nowrap}.df-report-body{flex:1;overflow:hidden;display:flex;flex-direction:column;max-height:none}.df-report-table{min-width:800px;font-size:13px}.df-report-table th{font-size:12px;padding:10px 12px;white-space:nowrap}.df-report-table td{padding:10px 12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.df-report-table td:hover{white-space:normal;max-width:none}.df-btn-excel{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.df-btn-excel:hover{opacity:.9}.df-btn-excel:disabled{opacity:.5;cursor:not-allowed}.df-pagination{display:flex;align-items:center;justify-content:center;gap:4px;padding:14px;border-top:1px solid #F1F5F9;background:#fafbff;flex-shrink:0}.df-page-btn{min-width:34px;height:34px;border:1px solid #E2E8F0;border-radius:8px;background:#fff;color:#374151;font-size:13px;font-weight:600;cursor:pointer;padding:0 10px;transition:all .15s}.df-page-btn:hover:not(:disabled){background:#eef2ff;border-color:#c7d2fe;color:#4f46e5}.df-page-btn.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.df-page-btn:disabled{opacity:.4;cursor:not-allowed}.df-page-ellipsis{font-size:14px;color:#94a3b8;padding:0 4px}.worksites-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--card-bg, #fff);border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 4px #0000000f}.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.stat-icon.blue{background:#4f46e51a}.stat-icon.green{background:#10b9811a}.stat-icon.amber{background:#f59e0b1a}.stat-info h4{font-size:22px;font-weight:700;margin:0;color:var(--text-primary, #1a1a2e)}.stat-info span{font-size:12px;color:var(--text-secondary, #6b7280)}.assignment-toolbar{display:flex;justify-content:space-between;gap:16px;margin-bottom:16px}.assignment-toolbar .left-group{display:flex;gap:12px;flex:1}.search-input{padding:8px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:14px;flex:1;max-width:300px;background:var(--card-bg, #fff);color:var(--text-primary, #1a1a2e)}.search-input:focus{outline:none;border-color:#4f46e5}.worksite-filter-select{padding:8px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:14px;background:var(--card-bg, #fff);color:var(--text-primary, #1a1a2e);cursor:pointer}.table-card{background:var(--card-bg, #fff);border-radius:12px;overflow-x:auto;box-shadow:0 1px 4px #0000000f}.user-name-cell{display:flex;align-items:center;gap:10px}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:14px}.user-details{display:flex;flex-direction:column}.user-details .fullname{font-weight:600;font-size:14px;color:var(--text-primary, #1a1a2e)}.user-details .email{font-size:12px;color:var(--text-secondary, #6b7280)}.tc-badge{background:var(--bg-secondary, #f3f4f6);padding:3px 10px;border-radius:6px;font-size:13px;font-family:monospace;color:var(--text-secondary, #374151)}.multi-site-badges{display:flex;flex-wrap:wrap;gap:6px}.current-site-badge{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.current-site-badge.has-site{background:#4f46e514;color:#4f46e5;border:1px solid rgba(79,70,229,.15)}.current-site-badge.no-site{background:#f59e0b14;color:#d97706;border:1px solid rgba(245,158,11,.15)}.expand-btn{background:var(--bg-secondary, #f3f4f6);border:1px solid var(--border-color, #e5e7eb);border-radius:6px;cursor:pointer;padding:5px 12px;font-size:12px;color:var(--text-secondary, #374151);transition:all .15s}.expand-btn:hover,.expand-btn.active{background:#4f46e5;color:#fff;border-color:#4f46e5}.expanded-row{background:#4f46e505}.site-picker-row td{background:var(--bg-secondary, #f8f9fa);padding:0!important}.site-picker-panel{padding:16px 24px;border-top:1px solid var(--border-color, #e5e7eb);border-bottom:2px solid rgba(79,70,229,.15)}.site-picker-label{font-size:13px;font-weight:600;color:var(--text-primary, #374151);margin-bottom:12px}.site-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:16px}.site-checkbox-label{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;cursor:pointer;font-size:13px;background:var(--card-bg, #fff);transition:all .15s;color:var(--text-primary, #374151)}.site-checkbox-label:hover{border-color:#4f46e5;background:#4f46e508}.site-checkbox-label.checked{border-color:#4f46e5;background:#4f46e50f;color:#4f46e5;font-weight:600}.site-checkbox-label input[type=checkbox]{accent-color:#4F46E5;width:16px;height:16px}.site-checkbox-text{flex:1}.site-picker-actions{display:flex;gap:10px;align-items:center}.save-sites-btn{background:#4f46e5;color:#fff;border:none;padding:8px 20px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:opacity .15s}.save-sites-btn:hover:not(:disabled){opacity:.9}.save-sites-btn:disabled{opacity:.5;cursor:not-allowed}.cancel-sites-btn{background:var(--bg-secondary, #f3f4f6);color:var(--text-secondary, #374151);border:1px solid var(--border-color, #e5e7eb);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .15s}.cancel-sites-btn:hover{background:#e5e7eb}.unsaved-indicator{font-size:12px;color:#d97706;font-weight:500}.error-alert{background:#fef2f2;color:#dc2626;border:1px solid rgba(220,38,38,.2);border-radius:8px;padding:10px 16px;font-size:13px;margin-bottom:16px}.loading-state,.empty-state{padding:48px;text-align:center;color:var(--text-secondary, #6b7280);font-size:14px}@media(max-width:768px){.worksites-stats{grid-template-columns:repeat(2,1fr)}.site-checkboxes{grid-template-columns:1fr}.assignment-toolbar .left-group{flex-direction:column}}.perm-container{padding:24px}.perm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.perm-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1a1a2e);display:flex;align-items:center;gap:10px}.perm-save-btn{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;padding:10px 28px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.perm-save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6366f159}.perm-save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.perm-info{background:linear-gradient(135deg,#6366f114,#4f46e50a);border:1px solid rgba(99,102,241,.2);border-radius:12px;padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--text-secondary, #555);line-height:1.5}.perm-info-icon{font-size:1.4rem;flex-shrink:0}.perm-table-wrapper{background:#fff;border-radius:16px;border:1px solid var(--border-color, #e5e7eb);overflow:hidden;box-shadow:0 1px 8px #0000000a}.perm-table{width:100%;border-collapse:collapse}.perm-table thead th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:14px 16px;text-align:center;font-size:.82rem;font-weight:700;color:var(--text-primary, #1a1a2e);border-bottom:2px solid var(--border-color, #e5e7eb);text-transform:uppercase;letter-spacing:.5px}.perm-table thead th:first-child{text-align:left;padding-left:20px;min-width:220px}.perm-table tbody tr{transition:background .15s}.perm-table tbody tr:hover{background:#6366f108}.perm-table tbody tr:not(:last-child){border-bottom:1px solid #f1f3f5}.perm-table td{padding:12px 16px;text-align:center;vertical-align:middle}.perm-table td:first-child{text-align:left;padding-left:20px}.perm-section-header td{background:linear-gradient(135deg,#f0f4ff,#e8edff);padding:10px 20px!important;font-size:.85rem;font-weight:700;color:#4338ca;border-bottom:2px solid rgba(99,102,241,.15)!important;border-top:2px solid rgba(99,102,241,.1);text-align:left!important;letter-spacing:.3px}.perm-section-header td span{display:flex;align-items:center;gap:6px}.perm-section-header:hover{background:none!important}.perm-screen-cell{display:flex;align-items:center;gap:10px}.perm-screen-icon{font-size:1.2rem;width:32px;height:32px;border-radius:8px;background:#6366f114;display:flex;align-items:center;justify-content:center;flex-shrink:0}.perm-screen-name{font-weight:600;color:var(--text-primary, #1a1a2e);font-size:.88rem}.perm-screen-key{font-size:.72rem;color:#94a3b8;font-family:Courier New,monospace}.perm-toggle{position:relative;width:44px;height:24px;display:inline-block}.perm-toggle input{opacity:0;width:0;height:0}.perm-toggle-slider{position:absolute;cursor:pointer;inset:0;background:#cbd5e1;border-radius:12px;transition:all .25s ease}.perm-toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all .25s ease;box-shadow:0 1px 3px #00000026}.perm-toggle input:checked+.perm-toggle-slider{background:linear-gradient(135deg,#6366f1,#4f46e5)}.perm-toggle input:checked+.perm-toggle-slider:before{transform:translate(20px)}.perm-role-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;font-size:.78rem;font-weight:700}.perm-role-badge.admin{background:#ef44441a;color:#dc2626}.perm-role-badge.manager{background:#f59e0b1a;color:#d97706}.perm-role-badge.user{background:#3b82f61a;color:#2563eb}.perm-role-badge.superadmin{background:#4f46e524;color:#4338ca}.perm-status{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:10px;font-size:.85rem;font-weight:500;margin-bottom:16px;animation:fadeIn .3s ease}.perm-status.success{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.2)}.perm-status.error{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.perm-loading{text-align:center;padding:60px 0;color:var(--text-secondary, #555)}.perm-loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cash-report-container{padding:0;color:var(--text-primary, #1A2138);font-family:inherit}.cash-report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem}.cash-report-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1A2138);margin:0 0 4px}.cash-report-header p{color:#6b7280;font-size:.875rem;margin:0}.header-actions{display:flex;align-items:center;gap:.75rem}.alert-error{background:#fef2f2;border:1px solid #FECACA;border-radius:10px;padding:.85rem 1rem;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem;border-left:4px solid #EF4444}.cash-filter-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000000f}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-size:.75rem;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.filter-input{width:100%;padding:.55rem .85rem;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;color:#1a2138;font-size:.875rem;transition:border-color .2s,box-shadow .2s;height:38px}.filter-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;background:#fff}.filter-btn-group{justify-content:flex-end}.filter-btn{padding:0 1.5rem;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:background .2s,box-shadow .2s;height:38px;white-space:nowrap}.filter-btn:hover:not(:disabled){background:#4338ca;box-shadow:0 4px 12px #4f46e54d}.filter-btn:disabled{opacity:.5;cursor:not-allowed}.summary-cards-container{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1.5rem}.summary-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:6px;box-shadow:0 1px 3px #0000000f;border-left:4px solid transparent;transition:box-shadow .2s,transform .2s}.summary-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.summary-card.expense{border-left-color:#ef4444}.summary-card.income{border-left-color:#10b981}.summary-card.balance{border-left-color:#4f46e5}.summary-card.balance.negative{border-left-color:#ef4444}.summary-icon{font-size:1.25rem}.summary-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;font-weight:700}.summary-value{font-size:1.6rem;font-weight:800;color:#1a2138}.expense-value{color:#ef4444}.income-value{color:#10b981}.negative-value{color:#ef4444}.positive-value{color:#10b981}.data-table-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #0000000f}.table-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;border-bottom:1px solid #F3F4F6;background:#f9fafb}.select-all-label{display:flex;align-items:center;gap:8px;cursor:pointer;color:#4b5563;font-size:.875rem;font-weight:500;-webkit-user-select:none;user-select:none}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid #F3F4F6;vertical-align:middle;white-space:nowrap}.data-table thead tr{background:#1e293b!important}.data-table th{font-size:.75rem;font-weight:700;color:#fff!important;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;background:#1e293b!important}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#f5f5ff}.data-table tbody tr.row-selected{background:#eef2ff}.info-title{font-weight:600;color:#1a2138;font-size:.875rem}.info-subtitle{font-size:.78rem;color:#6b7280;margin-top:2px;display:block}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:9999px;font-size:.8rem;font-weight:600;white-space:nowrap}.badge.income{background:#d1fae5;color:#065f46}.badge.expense{background:#fee2e2;color:#991b1b}.badge.zero{background:#f3f4f6;color:#9ca3af}.btn-danger{padding:.5rem 1.1rem;background:#fef2f2;color:#dc2626;border:1px solid #FECACA;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:background .2s;display:inline-flex;align-items:center;gap:5px}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-danger-sm{padding:.4rem .9rem;background:#fef2f2;color:#dc2626;border:1px solid #FECACA;border-radius:7px;font-weight:600;font-size:.8rem;cursor:pointer;transition:background .2s}.btn-danger-sm:hover:not(:disabled){background:#fee2e2}.btn-icon-danger{background:#fef2f2;border:1px solid #FECACA;border-radius:7px;width:32px;height:32px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;transition:background .2s}.btn-icon-danger:hover{background:#fee2e2}.checkbox-input{width:16px;height:16px;cursor:pointer;accent-color:#4F46E5}.empty-state{text-align:center;padding:4rem 2rem!important;color:#9ca3af;font-size:.9rem}.loading-container{display:flex;justify-content:center;align-items:center;min-height:180px}.loading-spinner{width:40px;height:40px;border:3px solid #E5E7EB;border-radius:50%;border-top-color:#4f46e5;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.summary-cards-container{grid-template-columns:1fr}.filter-grid{grid-template-columns:1fr 1fr}}.cash-summary-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:1.5rem}.stat-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:6px;box-shadow:0 1px 3px #0000000f;border-left:4px solid transparent;transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.stat-card.stat-people{border-left-color:#6366f1}.stat-card.stat-expense{border-left-color:#ef4444}.stat-card.stat-income{border-left-color:#10b981}.stat-card.stat-balance{border-left-color:#f59e0b}.stat-icon{font-size:1.25rem}.stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;font-weight:700}.stat-value{font-size:1.6rem;font-weight:800;color:#1a2138}.stat-value.text-expense{color:#ef4444}.stat-value.text-income,.stat-value.text-balance-positive{color:#10b981}.stat-value.text-balance-negative{color:#ef4444}.balance-bar-wrapper{width:100%;height:8px;background:#f3f4f6;border-radius:9999px;overflow:hidden}.balance-bar-fill{height:100%;border-radius:9999px;transition:width .6s ease}.balance-bar-fill.bar-positive{background:linear-gradient(90deg,#10b981,#34d399)}.balance-bar-fill.bar-negative{background:linear-gradient(90deg,#ef4444,#f87171)}@media(max-width:1024px){.cash-summary-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.cash-summary-stats{grid-template-columns:1fr}}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.approval-wf-form-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.approval-wf-picker-card{display:block;width:100%;text-align:left;cursor:pointer;padding:22px 20px;background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;box-shadow:0 1px 3px #0000000a;font-family:inherit;transition:box-shadow .2s,border-color .2s,transform .15s}.approval-wf-picker-card:hover{border-color:#4f46e54d;box-shadow:0 4px 16px #4f46e51a;transform:translateY(-2px)}.approval-wf-picker-card strong{font-size:1.05rem;font-weight:700;color:var(--text-primary, #111827)}.approval-wf-picker-card .approval-wf-picker-desc{margin-top:8px;font-size:.85rem;line-height:1.45;color:var(--text-secondary, #64748b)}.approval-wf-toolbar{background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000d}.approval-wf-toolbar--in-table-card{background:transparent;border:none;box-shadow:none;padding:0;border-radius:0}.approval-wf-toolbar__node-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.approval-wf-tb-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.5rem .85rem;margin:.2rem .35rem;border-radius:10px;font-size:.8125rem;font-weight:600;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap}.approval-wf-tb-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.approval-wf-tb-btn:active{transform:translateY(0)}.approval-wf-tb-btn svg{flex-shrink:0}.approval-wf-tb-btn--start{background:linear-gradient(145deg,#e0f2fe,#bae6fd);color:#0369a1;border-color:#7dd3fc}.approval-wf-tb-btn--approver{background:linear-gradient(145deg,#eef2ff,#e0e7ff);color:#4338ca;border-color:#a5b4fc}.approval-wf-tb-btn--notify{background:linear-gradient(145deg,#fffbeb,#fef3c7);color:#b45309;border-color:#fcd34d}.approval-wf-tb-btn--mail{background:linear-gradient(145deg,#f5f3ff,#ede9fe);color:#5b21b6;border-color:#c4b5fd}.approval-wf-tb-btn--delete{background:linear-gradient(145deg,#f8fafc,#f1f5f9);color:#475569;border-color:#cbd5e1}.approval-wf-tb-btn--approved{background:linear-gradient(145deg,#f0fdf4,#dcfce7);color:#15803d;border-color:#86efac}.approval-wf-tb-btn--rejected{background:linear-gradient(145deg,#fef2f2,#fee2e2);color:#b91c1c;border-color:#fca5a5}.approval-wf-designer-header{flex-wrap:wrap;gap:1rem}.approval-wf-designer-header .primary-btn{align-self:flex-start}.approval-wf-canvas-card{border-radius:12px;overflow:hidden}.approval-wf-node-root{position:relative}.approval-wf-node-delete{position:absolute;top:4px;right:4px;z-index:5;width:22px;height:22px;padding:0;line-height:1;font-size:16px;font-weight:700;border:none;border-radius:6px;background:#0f172a14;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center}.approval-wf-node-delete:hover{background:#fecaca;color:#b91c1c}.approval-wf-edge-label-btn{border:1px solid rgba(15,23,42,.12);border-radius:8px;padding:2px 10px;font-size:11px;font-weight:700;cursor:pointer;background:#fff;box-shadow:0 1px 3px #00000014}.approval-wf-edge-label-btn.is-approve{color:#15803d;border-color:#86efac;background:#f0fdf4}.approval-wf-edge-label-btn.is-reject{color:#b91c1c;border-color:#fca5a5;background:#fef2f2}.approval-wf-edge-label-input{width:auto;min-width:72px;max-width:160px;font-size:11px;font-weight:600;padding:2px 6px}.approval-wf-node--email{padding:10px;border-radius:10px;min-width:248px;max-width:280px;background:linear-gradient(180deg,#faf5ff,#f3e8ff);border:2px solid #7c3aed;box-shadow:0 2px 8px #7c3aed1f}.approval-wf-node__title{font-weight:600;font-size:12px;margin-bottom:6px;color:#5b21b6;display:flex;align-items:center;gap:6px}.approval-wf-node__hint{font-size:10px;line-height:1.35;margin:0 0 8px;color:#6b21a8;opacity:.92}.approval-wf-node__footer{margin-top:8px;font-size:10px;color:#5b21b6}.mail-template-editor-shell{border:1.5px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fafbfc;transition:border-color .2s,box-shadow .2s}.mail-template-editor-shell:focus-within{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f;background:#fff}.mail-template-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 10px;background:#fff;border-bottom:1px solid #e5e7eb}.mail-template-toolbar button{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.mail-template-toolbar button:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db}.mail-template-toolbar button:disabled{opacity:.45;cursor:not-allowed}.mail-template-toolbar button.is-active{background:#4f46e51f;border-color:#4f46e559;color:#4f46e5}.mail-template-toolbar .toolbar-sep{width:1px;height:22px;background:#e5e7eb;margin:0 4px}.mail-template-tiptap.ProseMirror{min-height:260px;max-height:min(45vh,400px);overflow-y:auto;padding:12px 14px;outline:none;font-size:14px;line-height:1.55;color:var(--text-primary, #111827)}.mail-template-tiptap.ProseMirror p{margin:0 0 .5em}.mail-template-tiptap.ProseMirror p:last-child{margin-bottom:0}.mail-template-tiptap.ProseMirror ul,.mail-template-tiptap.ProseMirror ol{margin:.35em 0 .5em;padding-left:1.35rem}.mail-template-tiptap.ProseMirror a{color:#4f46e5;text-decoration:underline}.mail-template-editor-loading{min-height:260px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:13px}.page-container{padding:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.page-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.page-header p{font-size:.85rem;color:var(--text-secondary);margin:0}.primary-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,var(--primary-color),#7C3AED);color:#fff;border:none;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.primary-btn:hover:not(:disabled){box-shadow:0 4px 16px #4f46e559;transform:translateY(-1px)}.primary-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-alert{padding:.75rem 1rem;background-color:#fef2f2;color:#b91c1c;border:1px solid #FECACA;border-radius:10px;font-size:.85rem;font-weight:500;margin-bottom:1rem}.success-alert{padding:.75rem 1rem;background-color:#f0fdf4;color:#15803d;border:1px solid #86EFAC;border-radius:10px;font-size:.85rem;font-weight:500;margin-bottom:1rem}.table-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #0000000a}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{background-color:#f8fafb;border-bottom:2px solid var(--border-color)}.data-table thead th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.data-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .15s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background-color:#4f46e505}.data-table tbody td{padding:14px 16px;color:var(--text-primary);vertical-align:middle;white-space:nowrap}.loading-state{padding:3rem 1rem;text-align:center;color:var(--text-secondary);font-size:.9rem;font-weight:500}.approval-tabs{display:flex;gap:8px;margin-bottom:1.25rem}.tab-btn{padding:9px 20px;border-radius:10px;border:none;cursor:pointer;font-weight:600;font-size:.8rem;background:#f3f4f6;color:#374151;transition:all .2s;font-family:inherit}.tab-btn:hover{background:#e5e7eb}.tab-btn.active{background:var(--text-primary, #1A2138);color:#fff}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap}.status-badge.pending{background:#f59e0b1f;color:#d97706}.status-badge.approved{background:#10b9811f;color:#059669}.status-badge.rejected{background:#ef44441f;color:#dc2626}.status-badge.cancelled{background:#6b72801f;color:#6b7280}.empty-state{padding:3rem 1rem;text-align:center;color:var(--text-secondary)}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:.75rem;display:block}.empty-state p{font-weight:600;margin:0}.btn-approve{padding:7px 14px;border-radius:8px;border:none;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.btn-approve:hover{background:#10b98133}.btn-approve:disabled{opacity:.5;cursor:not-allowed}.btn-reject{padding:7px 14px;border-radius:8px;border:none;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.btn-reject:hover{background:#ef444433}.btn-reject:disabled{opacity:.5;cursor:not-allowed}.btn-pdf{padding:7px 14px;border-radius:8px;border:none;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;background:#4f46e51a;color:#4f46e5;border:1px solid rgba(79,70,229,.2)}.btn-pdf:hover{background:#4f46e533}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--surface-color, #fff);border-radius:16px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000026;animation:modal-enter .2s ease-out}@keyframes modal-enter{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:#f3f4f6;color:#6b7280;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit}.modal-close:hover{background:#e5e7eb;color:var(--text-primary)}.modal-body{padding:20px 24px}.modal-body .info-text{font-size:.875rem;color:var(--text-secondary);margin:0 0 1rem;line-height:1.5}.modal-body label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.modal-body textarea,.modal-body input[type=text],.modal-body input[type=number]{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--border-color);font-size:.875rem;font-family:inherit;color:var(--text-primary);background:var(--bg-color, #F8FAFB);outline:none;transition:border-color .15s;box-sizing:border-box;resize:vertical}.modal-body textarea:focus,.modal-body input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e514}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:0 24px 20px}.modal-footer .btn-cancel{padding:10px 20px;border-radius:10px;border:1px solid var(--border-color);background:var(--surface-color, #fff);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.modal-footer .btn-cancel:hover{background:#f3f4f6}.modal-footer .btn-confirm{padding:10px 20px;border-radius:10px;border:none;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.modal-footer .btn-confirm.approve{background:#10b981}.modal-footer .btn-confirm.approve:hover{background:#059669}.modal-footer .btn-confirm.reject{background:#ef4444}.modal-footer .btn-confirm.reject:hover{background:#dc2626}.truncate-text{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.currency{font-weight:700;font-variant-numeric:tabular-nums}:root{--primary-color: #4F46E5;--primary-hover: #4338CA;--bg-color: #F8FAFB;--surface-color: #FFFFFF;--text-primary: #1A2138;--text-secondary: #8F95A5;--border-color: #E8EBF0;--success-color: #059669;--danger-color: #DC2626;--warning-color: #D97706}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit}a{text-decoration:none;color:inherit}
