@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.isolate{isolation:isolate}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.flex-shrink,.shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.text-center{text-align:center}.text-right{text-align:right}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.delay-1{transition-delay:1ms}.delay-2{transition-delay:2ms}.delay-3{transition-delay:3ms}.delay-4{transition-delay:4ms}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}.login-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg-base);font-family:Segoe UI,system-ui,-apple-system,sans-serif}.login-brand{flex:1;position:relative;overflow:hidden;background:#0a0a1a}.spotlight-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;transition:opacity .8s ease-in-out}.login-brand.spotlight-visible .spotlight-bg{opacity:1}.spotlight-credit{position:absolute;bottom:16px;left:16px;display:flex;align-items:center;gap:7px;padding:6px 12px;background:#00000073;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;color:#ffffffbf;font-size:11px;z-index:2;opacity:0;transition:opacity .6s ease .4s}.login-brand.spotlight-visible .spotlight-credit{opacity:1}.spotlight-credit i{font-size:10px;opacity:.7}.spotlight-quote{position:absolute;bottom:24px;right:24px;max-width:380px;padding:20px 24px;background:#0006;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:16px;z-index:2;opacity:0;transform:translateY(10px);transition:opacity .6s ease .6s,transform .6s ease .6s}.login-brand.spotlight-visible .spotlight-quote{opacity:1;transform:translateY(0)}.spotlight-quote-icon{color:#6366f1b3;font-size:14px;margin-right:6px}.spotlight-quote-text{font-size:14px;font-weight:500;color:#ffffffeb;line-height:1.65;font-style:italic}.spotlight-quote-author{margin-top:10px;font-size:12px;color:#ffffff8c;font-weight:600;text-align:right}.login-panel{width:480px;min-width:480px;display:flex;align-items:center;justify-content:center;padding:40px 32px;background:var(--bg-sidebar);border-left:1px solid var(--border);overflow-y:auto}.login-card{width:100%;max-width:380px}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:52px;height:52px;background:var(--accent-dim);border:1px solid rgba(99,102,241,.35);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--accent);margin:0 auto 16px}.login-header h2{font-size:22px;font-weight:700;color:var(--text-1);margin-bottom:6px}.login-header p{font-size:13px;color:var(--text-2)}.btn-m365{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px 20px;background:var(--accent);color:#fff;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:background .15s,transform .1s,opacity .15s;margin-bottom:20px}.btn-m365:hover:not(:disabled){background:var(--accent-hov);transform:translateY(-1px)}.btn-m365:disabled{opacity:.65;cursor:not-allowed;transform:none}.btn-m365 i{font-size:16px}.login-divider{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--text-3);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.providers-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.btn-provider{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;color:var(--text-1);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,transform .1s,opacity .15s}.btn-provider:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent);transform:translateY(-1px)}.btn-provider:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-provider i{font-size:15px}.local-login-form{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.local-field{position:relative;display:flex;align-items:center}.local-field>i:first-child{position:absolute;left:13px;color:var(--text-3);font-size:13px;pointer-events:none}.local-field input{width:100%;padding:11px 40px 11px 36px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;color:var(--text-1);font-size:13.5px;outline:none;transition:border-color .15s,box-shadow .15s}.local-field input::placeholder{color:var(--text-3)}.local-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.local-field input:disabled{opacity:.55;cursor:not-allowed}.local-toggle-pw{position:absolute;right:10px;background:none;border:none;color:var(--text-3);font-size:13px;cursor:pointer;padding:4px;line-height:1;transition:color .15s}.local-toggle-pw:hover{color:var(--text-2)}.btn-local-signin{width:100%;display:flex;align-items:center;justify-content:center;gap:9px;padding:11px 20px;background:var(--bg-card);border:1px solid var(--accent);border-radius:9px;color:var(--accent);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,transform .1s,opacity .15s}.btn-local-signin:hover:not(:disabled){background:var(--accent);color:#fff;transform:translateY(-1px)}.btn-local-signin:disabled{opacity:.55;cursor:not-allowed;transform:none}.login-error{display:flex;align-items:flex-start;gap:9px;padding:11px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:8px;color:#f87171;font-size:12.5px;margin-bottom:16px;line-height:1.5}.login-error i{flex-shrink:0;margin-top:1px}.login-footer{text-align:center;font-size:11.5px;color:var(--text-3);line-height:1.6}.login-footer a{color:var(--text-2);text-decoration:underline;text-underline-offset:2px;transition:color .15s}.login-footer a:hover{color:var(--accent)}@media(max-width:860px){.login-brand{display:none}.login-panel{width:100%;min-width:unset;border-left:none}}@media(max-width:1100px)and (min-width:861px){.spotlight-quote{max-width:280px;padding:16px 18px}.spotlight-quote-text{font-size:13px}}@media(max-width:480px){.login-panel{padding:32px 20px}.providers-grid{grid-template-columns:1fr}}.emp-login-shell{display:flex;height:100vh;overflow:hidden;background:#0a0a1a;font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:#e2e8f0}.emp-login-left{flex:1;background:linear-gradient(135deg,#0f172a,#1e1b4b,#312e81);display:flex;align-items:center;justify-content:center;padding:60px 48px;position:relative;overflow:hidden}.emp-login-left:before{content:"";position:absolute;top:-50%;right:-30%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);pointer-events:none}.emp-login-left:after{content:"";position:absolute;bottom:-40%;left:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.1) 0%,transparent 70%);pointer-events:none}.emp-login-left-content{position:relative;z-index:1;max-width:420px}.emp-login-logo{width:72px;height:72px;background:#6366f126;border:2px solid rgba(99,102,241,.3);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:30px;color:#818cf8;margin-bottom:28px}.emp-login-brand{font-size:36px;font-weight:800;color:#fff;margin:0 0 14px;line-height:1.1}.emp-login-tagline{font-size:15px;color:#94a3b8;margin-bottom:40px;line-height:1.7}.emp-login-features{display:flex;flex-direction:column;gap:16px}.emp-feat{display:flex;align-items:center;gap:14px;font-size:14px;color:#cbd5e1}.emp-feat i{width:40px;height:40px;background:#6366f11f;border:1px solid rgba(99,102,241,.25);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;color:#818cf8;flex-shrink:0}.emp-login-right{width:500px;min-width:500px;display:flex;align-items:center;justify-content:center;padding:40px 36px;background:#0f0f23;border-left:1px solid rgba(99,102,241,.15);overflow-y:auto}.emp-login-card{width:100%;max-width:400px}.emp-login-header{text-align:center;margin-bottom:32px}.emp-login-icon{width:56px;height:56px;margin:0 auto 18px;background:#6366f11f;border:1px solid rgba(99,102,241,.3);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#818cf8}.emp-login-header h2{font-size:24px;font-weight:700;color:#f1f5f9;margin:0 0 6px}.emp-login-header p{font-size:13.5px;color:#64748b;margin:0}.emp-login-form{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.emp-field{position:relative;display:flex;align-items:center}.emp-field>i:first-child{position:absolute;left:14px;color:#475569;font-size:14px;pointer-events:none}.emp-field input{width:100%;padding:13px 42px 13px 40px;background:#1a1a2e;border:1px solid #2d2d4a;border-radius:10px;color:#e2e8f0;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.emp-field input::placeholder{color:#4a5568}.emp-field input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.emp-field input:disabled{opacity:.5;cursor:not-allowed}.emp-toggle-pw{position:absolute;right:12px;background:none;border:none;color:#475569;font-size:14px;cursor:pointer;padding:4px;transition:color .15s}.emp-toggle-pw:hover{color:#818cf8}.emp-btn-signin{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px 20px;background:#6366f1;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;margin-top:4px}.emp-btn-signin:hover:not(:disabled){background:#4f46e5;transform:translateY(-1px)}.emp-btn-signin:disabled{opacity:.6;cursor:not-allowed}.emp-login-error{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:10px;color:#f87171;font-size:13px;margin-bottom:16px;line-height:1.5}.emp-login-error i{flex-shrink:0;margin-top:2px}.emp-login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#475569;font-size:12px}.emp-login-divider:before,.emp-login-divider:after{content:"";flex:1;height:1px;background:#2d2d4a}.emp-btn-download{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:10px;color:#34d399;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,transform .1s}.emp-btn-download:hover{background:#10b9812e;border-color:#10b98180;transform:translateY(-1px)}.emp-btn-download i{font-size:17px}.emp-login-footer{text-align:center;margin-top:24px}.emp-login-footer a{font-size:12.5px;color:#475569;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:color .15s}.emp-login-footer a:hover{color:#818cf8}.emp-modal-overlay{position:fixed;inset:0;z-index:9999;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.emp-download-modal{background:#12122a;border:1px solid #2d2d4a;border-radius:16px;width:100%;max-width:780px;max-height:90vh;overflow-y:auto;padding:36px;position:relative}.emp-modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:#ffffff0d;border:1px solid #2d2d4a;border-radius:10px;color:#94a3b8;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.emp-modal-close:hover{background:#ef444426;color:#f87171}.emp-download-header{text-align:center;margin-bottom:32px}.emp-download-header>i{font-size:40px;color:#818cf8;margin-bottom:16px}.emp-download-header h2{font-size:24px;font-weight:700;color:#f1f5f9;margin:0 0 8px}.emp-download-header p{font-size:14px;color:#64748b;margin:0}.emp-download-options{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.emp-download-card{background:#1a1a2e;border:1px solid #2d2d4a;border-radius:14px;padding:24px;display:flex;flex-direction:column}.emp-download-card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px}.emp-download-card-icon.android{background:#10b9811f;border:1px solid rgba(16,185,129,.25);color:#34d399}.emp-download-card-icon.pwa{background:#6366f11f;border:1px solid rgba(99,102,241,.25);color:#818cf8}.emp-download-card h3{font-size:17px;font-weight:700;color:#f1f5f9;margin:0 0 8px}.emp-download-card>p{font-size:13px;color:#64748b;line-height:1.6;margin:0 0 16px}.emp-download-steps{font-size:12.5px;color:#94a3b8;line-height:1.8;padding-left:18px;margin:0 0 20px;flex:1}.emp-download-steps li{margin-bottom:4px}.emp-download-steps strong{color:#e2e8f0}.emp-btn-dl{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .2s,transform .1s;border:none;color:#fff;background:#10b981}.emp-btn-dl:hover{background:#059669;transform:translateY(-1px)}.emp-btn-dl.pwa{background:#6366f1}.emp-btn-dl.pwa:hover{background:#4f46e5}.emp-dl-meta{display:block;text-align:center;font-size:11px;color:#475569;margin-top:10px}.emp-download-footer{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:10px;font-size:12.5px;color:#94a3b8;line-height:1.6}.emp-download-footer>i{flex-shrink:0;margin-top:2px;color:#818cf8}@media(max-width:860px){.emp-login-left{display:none}.emp-login-right{width:100%;min-width:unset;border-left:none}.emp-download-options{grid-template-columns:1fr}}@media(max-width:500px){.emp-login-right,.emp-download-modal{padding:24px 16px}}.ep-wrap{padding:0;width:100%}.ep-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.ep-title{font-size:18px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.ep-sub{font-size:13px;color:var(--text-2)}.ep-subtitle{font-size:14px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:8px;margin-bottom:12px}.ep-emp-selector{display:flex;align-items:center;gap:10px}.ep-emp-selector select{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;color:var(--text-1);min-width:220px}.ep-emp-selector select:focus{border-color:var(--accent);outline:none}.ep-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s}.ep-btn-add:hover{background:var(--accent-hov)}.ep-btn-sm{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border-radius:6px;padding:7px 14px;font-size:12px;font-weight:600;transition:background .15s}.ep-btn-sm:hover{background:var(--accent-hov)}.ep-btn-cancel-sm{display:flex;align-items:center;gap:6px;background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border);border-radius:6px;padding:7px 14px;font-size:12px;font-weight:600;transition:background .15s}.ep-btn-cancel-sm:hover{background:var(--bg-hover)}.ep-toolbar-inline{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.ep-toolbar-inline input,.ep-toolbar-inline select{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--text-1)}.ep-toolbar-inline input:focus,.ep-toolbar-inline select:focus{border-color:var(--accent);outline:none}.ep-section{margin-bottom:28px}.ep-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.ep-card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);font-size:14px;font-weight:600;color:var(--text-1)}.ep-card-head i{color:var(--accent);margin-right:8px}.ep-card-body{padding:18px}.ep-table{width:100%;border-collapse:collapse}.ep-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:12px 16px;border-bottom:1px solid var(--border)}.ep-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-1);vertical-align:middle}.ep-table tbody tr:last-child td{border-bottom:none}.ep-table tbody tr:hover{background:var(--bg-hover)}.ep-table th:last-child,.ep-table td:last-child{text-align:right}.ep-loading{text-align:center;padding:24px 0!important;color:var(--text-3)!important}.ep-empty{text-align:center;padding:40px 0!important;color:var(--text-3)!important;display:flex;flex-direction:column;align-items:center;gap:8px}.ep-empty i{font-size:24px;opacity:.4}.ep-empty-block{text-align:center;padding:60px 20px;color:var(--text-3)}.ep-empty-block i{font-size:32px;opacity:.3;display:block;margin-bottom:12px}.ep-muted{color:var(--text-3)}.ep-total-row td{background:var(--bg-card2);border-top:2px solid var(--border);font-weight:700}.ep-amount{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-1)}.ep-ded{color:#ef4444;font-variant-numeric:tabular-nums}.ep-net{font-weight:700;color:#10b981;font-variant-numeric:tabular-nums}.ep-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;display:inline-flex;align-items:center;gap:5px;text-transform:capitalize}.ep-badge-pending{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.ep-badge-approved{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.2)}.ep-badge-rejected{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.ep-dept-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#6366f11f;color:var(--accent);border:1px solid rgba(99,102,241,.2)}.ep-leave-type{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#06b6d41f;color:#06b6d4;border:1px solid rgba(6,182,212,.2)}.ep-loan-type{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#8b5cf61f;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.ep-ot-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.ep-row-actions{display:flex;gap:4px;justify-content:flex-end}.ep-act-btn{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:background .15s,color .15s;font-size:13px}.ep-act-btn:hover{background:var(--bg-hover);color:var(--text-1)}.ep-act-del:hover{color:#ef4444}.ep-act-approve:hover{color:#10b981}.ep-profile-top{display:flex;align-items:center;gap:20px;margin-bottom:28px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px}.ep-avatar-lg{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700;flex-shrink:0}.ep-profile-name{font-size:20px;font-weight:700;color:var(--text-1)}.ep-profile-title{font-size:13px;color:var(--text-2);margin-top:2px}.ep-profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ep-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ep-info-row{display:flex;flex-direction:column;gap:2px;padding:8px 0;border-bottom:1px solid var(--border)}.ep-info-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.ep-info-row span:last-child{font-size:13px;color:var(--text-1);font-weight:500}.ep-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px}.ep-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;align-items:center;gap:14px}.ep-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.ep-stat-val{font-size:20px;font-weight:700;color:var(--text-1);line-height:1.2}.ep-stat-lbl{font-size:11px;color:var(--text-3)}.ep-benefits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.ep-benefit-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:14px}.ep-benefit-logo{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.ep-benefit-note{font-size:12px;color:var(--text-2);line-height:1.5;background:var(--bg-card2);border-radius:8px;padding:10px 12px}.ep-13th-highlight{background:var(--bg-card);border:2px solid var(--accent);border-radius:12px;padding:24px;display:flex;align-items:center;gap:20px;margin-bottom:20px}.ep-13th-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;background:#6366f11f;color:var(--accent);flex-shrink:0}.ep-13th-amount{font-size:28px;font-weight:800;color:var(--text-1);font-variant-numeric:tabular-nums}.ep-13th-label{font-size:13px;color:var(--text-2);margin-top:2px}.ep-13th-formula{font-size:12px;color:var(--text-3);margin-top:6px;font-style:italic;display:flex;align-items:center;gap:6px}.ep-memo-list{display:flex;flex-direction:column;gap:12px}.ep-memo-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;transition:border-color .2s}.ep-memo-important{border-left:3px solid #f59e0b}.ep-memo-urgent{border-left:3px solid #ef4444}.ep-memo-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.ep-memo-title{font-size:14px;font-weight:600;color:var(--text-1)}.ep-memo-meta{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:8px;flex-shrink:0}.ep-memo-content{font-size:13px;color:var(--text-2);line-height:1.6;white-space:pre-wrap}.ep-preview{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px;background:#6366f114;color:var(--accent);border:1px solid rgba(99,102,241,.15);display:flex;align-items:center;gap:8px}.ep-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ep-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:96%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.ep-modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-size:15px;font-weight:700;color:var(--text-1)}.ep-modal-close{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:background .15s,color .15s}.ep-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.ep-modal-body{padding:20px}.ep-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border)}.ep-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ep-form-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.ep-form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.ep-field{display:flex;flex-direction:column;gap:4px}.ep-field label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}.ep-field input,.ep-field select,.ep-field textarea{background:var(--bg-input, var(--bg-card2));border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;color:var(--text-1);width:100%;transition:border-color .15s}.ep-field input:focus,.ep-field select:focus,.ep-field textarea:focus{border-color:var(--accent);outline:none}.ep-field textarea{resize:vertical;font-family:inherit}.ep-field input:read-only{opacity:.6;cursor:default}.ep-msg{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:8px;background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.2)}@media(max-width:768px){.ep-header{flex-direction:column}.ep-form-grid,.ep-info-grid,.ep-profile-grid{grid-template-columns:1fr}.ep-profile-top{flex-direction:column;text-align:center}.ep-benefits-grid{grid-template-columns:1fr}.ep-13th-highlight{flex-direction:column;text-align:center}.ep-stat-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.ep-table th:nth-child(n+4),.ep-table td:nth-child(n+4){display:none}.ep-table th:last-child,.ep-table td:last-child{display:table-cell}.ep-emp-selector select{min-width:160px}}.emp-app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg-base, #0a0a1a);font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:var(--text-1, #e2e8f0)}.emp-sidebar{width:260px;min-width:260px;background:var(--bg-sidebar, #0f0f23);border-right:1px solid var(--border, #1e1e3a);display:flex;flex-direction:column;transition:width .2s,min-width .2s;overflow:hidden}.emp-sidebar.collapsed{width:64px;min-width:64px}.emp-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border, #1e1e3a)}.emp-sidebar-brand{display:flex;flex-direction:column}.emp-brand-main{font-size:15px;font-weight:700;color:var(--text-1, #f1f5f9)}.emp-brand-sub{font-size:11px;color:var(--text-3, #475569)}.emp-collapse-btn{width:30px;height:30px;border-radius:8px;background:#ffffff0a;border:1px solid var(--border, #1e1e3a);color:var(--text-2, #94a3b8);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.emp-collapse-btn:hover{background:#ffffff14}.emp-sidebar-nav{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:2px}.emp-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;font-size:13.5px;color:var(--text-2, #94a3b8);background:none;border:none;cursor:pointer;text-align:left;width:100%;transition:background .15s,color .15s;white-space:nowrap}.emp-nav-item i{width:18px;text-align:center;font-size:14px;flex-shrink:0}.emp-nav-item:hover{background:#6366f114;color:var(--text-1, #e2e8f0)}.emp-nav-item.active{background:#6366f126;color:#818cf8;font-weight:600}.emp-nav-item.download{margin-top:8px;color:#34d399}.emp-nav-item.download:hover{background:#10b9811a;color:#34d399}.emp-nav-item.logout{color:#ef4444;margin-top:4px}.emp-nav-item.logout:hover{background:#ef44441a}.emp-sidebar-footer{padding:12px;border-top:1px solid var(--border, #1e1e3a)}.emp-sidebar-user{display:flex;align-items:center;gap:10px;padding:6px 4px}.emp-avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.emp-sidebar-user-info{display:flex;flex-direction:column;min-width:0}.emp-sidebar-user-name{font-size:13px;font-weight:600;color:var(--text-1, #e2e8f0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emp-sidebar-user-role{font-size:11px;color:var(--text-3, #475569);display:flex;align-items:center;gap:4px}.emp-main-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}.emp-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border, #1e1e3a);background:var(--bg-sidebar, #0f0f23);min-height:56px}.emp-topbar-left h2{font-size:16px;font-weight:600;color:var(--text-1, #f1f5f9);margin:0}.emp-topbar-right{display:flex;align-items:center;gap:12px}.emp-icon-btn{width:36px;height:36px;border-radius:10px;background:#ffffff0a;border:1px solid var(--border, #1e1e3a);color:var(--text-2, #94a3b8);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.emp-icon-btn:hover{background:#ffffff14;color:var(--text-1, #e2e8f0)}.emp-avatar-sm{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.emp-content{flex:1;overflow-y:auto;padding:24px}.emp-dashboard{max-width:900px}.emp-welcome{margin-bottom:32px}.emp-welcome h1{font-size:24px;font-weight:700;color:var(--text-1, #f1f5f9);margin:0 0 8px}.emp-welcome p{font-size:14px;color:var(--text-2, #94a3b8);margin:0}.emp-quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.emp-quick-card{background:var(--bg-card, #12122a);border:1px solid var(--border, #1e1e3a);border-radius:14px;padding:24px 20px;text-align:left;cursor:pointer;transition:border-color .2s,transform .15s,box-shadow .2s}.emp-quick-card:hover{border-color:#6366f166;transform:translateY(-2px);box-shadow:0 8px 24px #0003}.emp-qc-icon{width:48px;height:48px;border-radius:14px;border:1px solid;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:16px}.emp-quick-card h3{font-size:15px;font-weight:700;color:var(--text-1, #f1f5f9);margin:0 0 6px}.emp-quick-card p{font-size:12.5px;color:var(--text-3, #64748b);margin:0;line-height:1.5}@media(max-width:900px){.emp-quick-actions{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.emp-sidebar{display:none}.emp-content{padding:16px}.emp-quick-actions{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.emp-topbar{padding:10px 16px}}.kb-shell{display:flex;flex-direction:column;min-height:100%}.kb-hero{background:linear-gradient(145deg,#12122a,#1a1040 55%,#0e1628);padding:56px 48px 48px;position:relative;overflow:hidden}.kb-hero:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.13) 0%,transparent 70%);top:-160px;right:-160px;pointer-events:none}.kb-hero:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.09) 0%,transparent 70%);bottom:-100px;left:-100px;pointer-events:none}.kb-hero-inner{position:relative;z-index:1;max-width:680px;margin:0 auto;text-align:center}.kb-hero-icon{width:64px;height:64px;background:#6366f12e;border:1px solid rgba(99,102,241,.35);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--accent);margin:0 auto 20px}.kb-hero-title{font-size:34px;font-weight:800;color:#fff;margin-bottom:10px;line-height:1.15}.kb-hero-sub{font-size:15px;color:#8888b0;margin-bottom:28px;line-height:1.65}.kb-search-wrap{position:relative;max-width:520px;margin:0 auto 20px}.kb-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#5555a0;font-size:14px;pointer-events:none}.kb-search-input{width:100%;padding:14px 44px;background:#ffffff12;border:1px solid rgba(99,102,241,.3);border-radius:12px;color:#fff;font-size:14.5px;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.kb-search-input::placeholder{color:#5555a0}.kb-search-input:focus{border-color:var(--accent);background:#ffffff1a;box-shadow:0 0 0 3px #6366f133}.kb-search-clear{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:#5555a0;font-size:13px;cursor:pointer;padding:4px;transition:color .12s}.kb-search-clear:hover{color:#fff}.kb-stats{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;font-size:12.5px;color:#6668a0}.kb-stats span{display:flex;align-items:center;gap:6px}.kb-stats i{color:var(--accent)}.kb-cats{display:flex;align-items:center;gap:8px;padding:20px 48px;background:var(--bg-sidebar);border-bottom:1px solid var(--border);overflow-x:auto;flex-wrap:nowrap}.kb-cat-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}.kb-cat-btn:hover{background:var(--bg-hover);color:var(--text-1)}.kb-cat-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.kb-cat-count{background:var(--bg-topbar);border-radius:20px;padding:1px 7px;font-size:11px;font-weight:700;color:var(--text-3)}.kb-cat-btn.active .kb-cat-count{background:var(--accent);color:#fff}.kb-main{flex:1;padding:36px 48px 48px;background:var(--bg-base)}.kb-section{margin-bottom:36px}.kb-section-label{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:16px}.kb-section-label i{color:var(--accent)}.kb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.kb-grid-featured{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.kb-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:22px;cursor:pointer;position:relative;display:flex;flex-direction:column;gap:10px;transition:border-color .15s,transform .15s,box-shadow .15s}.kb-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 24px #6366f126}.kb-card-featured{border-color:#6366f166;background:linear-gradient(135deg,var(--bg-card) 80%,rgba(99,102,241,.06))}.kb-featured-badge{position:absolute;top:14px;right:14px;display:flex;align-items:center;gap:5px;background:var(--accent);color:#fff;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px}.kb-featured-badge i{font-size:9px}.kb-card-cat{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.kb-card-cat i{font-size:12px}.kb-card-title{font-size:16px;font-weight:700;color:var(--text-1);line-height:1.3;margin:0}.kb-card:hover .kb-card-title{color:var(--accent)}.kb-card-excerpt{font-size:13px;color:var(--text-2);line-height:1.6;margin:0;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.kb-card-tags{display:flex;flex-wrap:wrap;gap:6px}.kb-tag{background:var(--bg-topbar);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:11px;color:var(--text-3);font-weight:500}.kb-card-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:11.5px;color:var(--text-3)}.kb-card-meta span{display:flex;align-items:center;gap:5px}.kb-read-btn{display:flex;align-items:center;gap:7px;color:var(--accent);background:none;border:none;font-size:13px;font-weight:600;cursor:pointer;padding:0;margin-top:2px;transition:gap .15s}.kb-card:hover .kb-read-btn{gap:10px}.kb-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center;color:var(--text-3)}.kb-empty i{font-size:40px;margin-bottom:16px;color:var(--text-3)}.kb-empty h3{font-size:17px;color:var(--text-2);margin-bottom:8px}.kb-empty p{font-size:13.5px;margin-bottom:20px}.kb-reset-btn{padding:9px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.kb-reset-btn:hover{background:var(--accent-hov)}.kb-results-count{font-size:12px;color:var(--text-3);text-align:right;margin-top:8px}.kb-viewer{display:flex;flex-direction:column;height:100%}.kb-viewer-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-sidebar);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:10px;flex-shrink:0}.kb-back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--accent);font-size:13.5px;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:8px;transition:background .15s}.kb-back-btn:hover{background:var(--accent-dim)}.kb-back-btn i{font-size:12px}.kb-viewer-meta{display:flex;align-items:center;gap:16px;font-size:12.5px;color:var(--text-3);flex-wrap:wrap}.kb-viewer-cat{display:flex;align-items:center;gap:6px;color:var(--accent);font-weight:600}.kb-open-btn{display:flex;align-items:center;gap:6px;color:var(--text-2);text-decoration:none;font-size:12.5px;padding:5px 11px;border:1px solid var(--border);border-radius:7px;transition:border-color .15s,color .15s}.kb-open-btn:hover{border-color:var(--accent);color:var(--accent)}.kb-viewer-content{flex:1;position:relative;overflow:hidden}.kb-iframe{width:100%;height:100%;border:none;background:#fff}.kb-viewer-loading,.kb-viewer-error{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px;font-size:14px}.kb-viewer-loading{color:var(--text-2)}.kb-viewer-error{color:#f87171}.kb-viewer-error a{color:var(--accent)}.kb-viewer-loading i{font-size:20px;color:var(--accent)}.kb-viewer-error i{font-size:20px}@media(max-width:900px){.kb-hero{padding:40px 24px 36px}.kb-cats{padding:14px 20px}.kb-main{padding:24px 20px 40px}.kb-grid{grid-template-columns:1fr}.kb-viewer-bar{flex-direction:column;align-items:flex-start}}[data-theme=dark] .dialer-panel{--d-bg: #1e2330;--d-bg2: #262d3a;--d-bg3: #2e3648;--d-border: #3d4758;--d-text: #eef0f6;--d-text2: #a0aabe;--d-text3: #6b7a92;--d-key-bg: #2a3244;--d-key-bdr: #404d62;--d-tab-bg: #222836;--d-hover: #343e52}[data-theme=light] .dialer-panel{--d-bg: #ffffff;--d-bg2: #f5f6fa;--d-bg3: #eef0f7;--d-border: #d0d5e2;--d-text: #1a1e2e;--d-text2: #4a5568;--d-text3: #7a849b;--d-key-bg: #f0f2f8;--d-key-bdr: #c8cdd8;--d-tab-bg: #f7f8fc;--d-hover: #e6e9f2}.dialer-fab{position:fixed;bottom:28px;right:28px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #6366f173;transition:transform .15s,box-shadow .15s;z-index:1000}.dialer-fab:hover{transform:scale(1.08)}.dialer-fab-reg{background:#22c55e;box-shadow:0 4px 16px #22c55e73}.dialer-fab-reg:hover{box-shadow:0 6px 20px #22c55e8c}.dialer-fab-unreg{background:#ef4444;box-shadow:0 4px 16px #ef444473}.dialer-fab-unreg:hover{box-shadow:0 6px 20px #ef44448c}.dialer-fab-ringing{background:#f59e0b!important;box-shadow:0 0 #f59e0bb3!important;animation:fab-ring-pulse 1s ease-in-out infinite,fab-shake .4s ease-in-out infinite}@keyframes fab-ring-pulse{0%{box-shadow:0 0 #f59e0bb3}50%{box-shadow:0 0 0 16px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}@keyframes fab-shake{0%,to{transform:rotate(0)}20%{transform:rotate(-8deg)}40%{transform:rotate(8deg)}60%{transform:rotate(-5deg)}80%{transform:rotate(5deg)}}.dialer-fab-active{background:#22c55e!important;animation:fab-active-pulse 2s ease-in-out infinite}@keyframes fab-active-pulse{0%,to{box-shadow:0 0 #22c55e80}50%{box-shadow:0 0 0 10px #22c55e00}}.dialer-fab-badge{position:absolute;top:-4px;right:-4px;width:22px;height:22px;border-radius:50%;background:#ef4444;color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;border:2px solid var(--d-bg);animation:badge-bounce .6s ease-in-out infinite}.dialer-fab-badge-active{background:#22c55e;animation:none}.dialer-fab-badge-active i{font-size:8px;animation:badge-blink 1s ease-in-out infinite}@keyframes badge-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@keyframes badge-blink{0%,to{opacity:1}50%{opacity:.3}}.dialer-panel{position:fixed;bottom:28px;right:28px;width:300px;background:var(--d-bg);border:1px solid var(--d-border);border-radius:16px;box-shadow:0 8px 32px #00000059;z-index:1000;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 60px)}.dialer-minimized{width:240px}.dialer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--d-bg2);border-bottom:1px solid var(--d-border);-webkit-user-select:none;user-select:none}.dialer-title{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--d-text)}.dialer-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-green{background:#22c55e;box-shadow:0 0 6px #22c55e80}.dot-yellow{background:#eab308;box-shadow:0 0 6px #eab30880}.dot-red{background:#ef4444;box-shadow:0 0 6px #ef444480}.dialer-header-btns{display:flex;gap:4px}.dialer-hbtn{width:24px;height:24px;background:none;border:none;color:var(--d-text3);font-size:11px;cursor:pointer;border-radius:5px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.dialer-hbtn:hover{background:var(--d-hover);color:var(--d-text)}.dialer-close:hover{color:#ef4444!important}.dialer-incoming{background:#22c55e1a;border-bottom:1px solid rgba(34,197,94,.2);padding:10px 14px;display:flex;align-items:center;gap:8px;font-size:12.5px;color:#22c55e}.dialer-incoming i{font-size:13px}.dialer-incoming span{flex:1}.dialer-incoming-btns{display:flex;gap:6px}.dialer-btn-answer,.dialer-btn-vm,.dialer-btn-decline{width:28px;height:28px;border-radius:50%;border:none;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s}.dialer-btn-answer{background:#22c55e;color:#fff}.dialer-btn-vm{background:#a855f7;color:#fff}.dialer-btn-decline{background:#ef4444;color:#fff}.dialer-btn-answer:hover,.dialer-btn-vm:hover,.dialer-btn-decline:hover{transform:scale(1.1)}.dialer-display{position:relative;padding:14px 14px 8px;min-height:48px;display:flex;flex-direction:column;align-items:center;gap:4px}.dialer-digits{font-size:20px;font-weight:700;color:var(--d-text);letter-spacing:2px;min-height:28px;word-break:break-all;text-align:center}.dialer-timer{font-size:11.5px;color:#22c55e;display:flex;align-items:center;gap:5px}.dialer-backspace{position:absolute;right:14px;top:14px;background:none;border:none;color:var(--d-text3);font-size:15px;cursor:pointer;padding:4px;transition:color .12s}.dialer-backspace:hover{color:var(--d-text)}.dialer-tabs{display:flex;border-top:1px solid var(--d-border);border-bottom:1px solid var(--d-border);background:var(--d-tab-bg)}.dialer-tab{flex:1;padding:9px 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--d-text3);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .12s,border-color .12s,background .12s}.dialer-tab:hover{color:var(--d-text);background:var(--d-hover)}.dialer-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--d-hover)}.dialer-log{max-height:200px;overflow-y:auto;font-size:11px}.dialer-empty{padding:20px 12px;text-align:center;color:var(--d-text3);font-size:12px}.dialer-log-entry{display:flex;gap:6px;padding:5px 12px;border-bottom:1px solid var(--d-border);line-height:1.4;align-items:flex-start}.log-time{color:var(--d-text3);flex-shrink:0}.log-success{color:#22c55e}.log-error{color:#ef4444}.log-warn{color:#eab308}.log-info{color:var(--d-text2)}.log-outgoing{color:var(--accent)}.log-incoming{color:#06b6d4}.dialer-history{max-height:220px;overflow-y:auto}.dialer-history-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--d-border);cursor:pointer;transition:background .1s}.dialer-history-row:hover{background:var(--d-hover)}.history-icon{font-size:11px;width:20px;text-align:center;flex-shrink:0}.history-outgoing{color:var(--accent)}.history-incoming{color:#22c55e}.history-missed{color:#ef4444}.history-info{flex:1;display:flex;flex-direction:column;min-width:0}.history-number{font-size:12.5px;font-weight:600;color:var(--d-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-meta{font-size:10.5px;color:var(--d-text3)}.history-call-btn{width:28px;height:28px;border-radius:50%;background:#22c55e1f;border:none;color:#22c55e;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,transform .1s}.history-call-btn:hover:not(:disabled){background:#22c55e40;transform:scale(1.08)}.history-call-btn:disabled{opacity:.3;cursor:not-allowed}.dialer-clear-history{display:flex;align-items:center;justify-content:center;gap:5px;width:100%;padding:8px;background:none;border:none;border-top:1px solid var(--d-border);color:var(--d-text3);font-size:11px;cursor:pointer;transition:color .12s}.dialer-clear-history:hover{color:#ef4444}.dialer-contacts{max-height:220px;overflow-y:auto}.contact-add-btn{display:flex;align-items:center;gap:5px;width:100%;padding:10px 12px;background:none;border:none;border-bottom:1px solid var(--d-border);color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;transition:background .1s}.contact-add-btn:hover{background:var(--d-hover)}.contact-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--d-border)}.contact-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.contact-info{flex:1;display:flex;flex-direction:column;cursor:pointer;min-width:0}.contact-name{font-size:12.5px;font-weight:600;color:var(--d-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-number{font-size:10.5px;color:var(--d-text3)}.contact-edit-btn,.contact-del-btn{width:24px;height:24px;border-radius:5px;background:none;border:none;color:var(--d-text3);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .12s,background .12s}.contact-edit-btn:hover{color:var(--accent);background:var(--d-hover)}.contact-del-btn:hover{color:#ef4444;background:#ef444414}.contact-form{padding:12px;display:flex;flex-direction:column;gap:8px}.contact-input{padding:8px 10px;border:1px solid var(--d-border);border-radius:8px;background:var(--d-bg3);color:var(--d-text);font-size:12.5px;outline:none;transition:border-color .12s}.contact-input:focus{border-color:var(--accent)}.contact-form-btns{display:flex;gap:6px}.contact-save-btn{flex:1;padding:7px 0;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:opacity .12s}.contact-save-btn:disabled{opacity:.4;cursor:not-allowed}.contact-cancel-btn{padding:7px 12px;background:var(--d-bg3);color:var(--d-text2);border:1px solid var(--d-border);border-radius:8px;font-size:12px;cursor:pointer;transition:background .12s}.contact-cancel-btn:hover{background:var(--d-hover)}.dialer-transfer{padding:12px;display:flex;flex-direction:column;gap:8px}.transfer-label{font-size:11.5px;font-weight:600;color:var(--d-text2)}.transfer-input{padding:8px 10px;border:1px solid var(--d-border);border-radius:8px;background:var(--d-bg3);color:var(--d-text);font-size:12.5px;outline:none;transition:border-color .12s}.transfer-input:focus{border-color:var(--accent)}.transfer-contacts{display:flex;flex-wrap:wrap;gap:4px}.transfer-quick{padding:4px 8px;background:var(--d-bg3);border:1px solid var(--d-border);border-radius:6px;color:var(--d-text2);font-size:10.5px;cursor:pointer;transition:border-color .12s,color .12s}.transfer-quick:hover{border-color:var(--accent);color:var(--accent)}.transfer-btns{display:flex;gap:6px}.transfer-blind-btn,.transfer-attended-btn{flex:1;padding:8px 0;border:none;border-radius:8px;font-size:11.5px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:opacity .12s}.transfer-blind-btn{background:var(--accent);color:#fff}.transfer-attended-btn{background:#06b6d4;color:#fff}.transfer-blind-btn:disabled,.transfer-attended-btn:disabled{opacity:.35;cursor:not-allowed}.dialer-keypad{padding:8px 14px 4px;display:flex;flex-direction:column;gap:6px}.dialer-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.dialer-key{height:44px;background:var(--d-key-bg);border:1px solid var(--d-key-bdr);border-radius:10px;color:var(--d-text);font-size:17px;font-weight:700;cursor:pointer;transition:background .1s,transform .08s,border-color .1s}.dialer-key:hover{background:var(--d-hover);border-color:var(--accent)}.dialer-key:active{transform:scale(.94)}.dialer-actions{padding:10px 14px 8px;display:flex;align-items:center;justify-content:center;gap:10px}.dialer-btn-call,.dialer-btn-hangup{width:52px;height:52px;border-radius:50%;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,box-shadow .15s}.dialer-btn-call{background:#22c55e;color:#fff;box-shadow:0 3px 10px #22c55e66}.dialer-btn-call:hover:not(:disabled){transform:scale(1.07);box-shadow:0 4px 14px #22c55e8c}.dialer-btn-call:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.dialer-btn-hangup{background:#ef4444;color:#fff;box-shadow:0 3px 10px #ef444466}.dialer-btn-hangup:hover{transform:scale(1.07);box-shadow:0 4px 14px #ef44448c}.dialer-act-btn{width:40px;height:40px;border-radius:50%;background:var(--d-key-bg);border:1px solid var(--d-key-bdr);color:var(--d-text2);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s,border-color .12s}.dialer-act-btn:hover{background:var(--d-hover);color:var(--d-text)}.active-red{background:#ef444426!important;border-color:#ef4444!important;color:#ef4444!important}.active-yellow{background:#eab30826!important;border-color:#eab308!important;color:#eab308!important}.dialer-volume{display:flex;align-items:center;gap:8px;padding:4px 14px 10px;font-size:11px;color:var(--d-text3)}.volume-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--d-border);border-radius:2px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.volume-val{min-width:28px;text-align:right;font-size:10.5px}.ringtone-toggle{background:none;border:none;color:#22c55e;font-size:13px;cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s,background .15s;margin-left:2px}.ringtone-toggle:hover{background:var(--d-hover, rgba(255,255,255,.08))}.ringtone-toggle.ringtone-off{color:var(--d-text3, #6b7a92);opacity:.6}.dialer-status-error{display:flex;align-items:flex-start;gap:7px;padding:8px 12px;margin:0 10px 10px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;font-size:11px;color:#f87171;line-height:1.5}.dialer-status-error i{flex-shrink:0;margin-top:1px}.dialer-confirm-overlay{position:absolute;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:20;border-radius:16px}.dialer-confirm{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px 20px;text-align:center;width:260px}.dialer-confirm-icon{font-size:28px;color:#f59e0b;margin-bottom:10px}.dialer-confirm-title{font-size:15px;font-weight:700;color:var(--text-1);margin-bottom:8px}.dialer-confirm-text{font-size:12px;color:var(--text-2);line-height:1.5;margin:0 0 16px}.dialer-confirm-btns{display:flex;flex-direction:column;gap:8px}.dialer-confirm-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:opacity .12s}.dialer-confirm-btn:hover{opacity:.85}.dialer-confirm-minimize{background:#22c55e;color:#fff}.dialer-confirm-close{background:#ef4444;color:#fff}.dialer-confirm-cancel{background:none;border:none;color:var(--text-3);font-size:12px;cursor:pointer;margin-top:10px;padding:4px 8px}.dialer-confirm-cancel:hover{color:var(--text-1)}.fusion-shell{display:flex;flex-direction:column;height:100%;position:relative}.fusion-iframe{flex:1;width:100%;height:100%;border:none;background:#fff}.fusion-hidden{display:none}.fusion-loading,.fusion-error{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px;font-size:14px;position:absolute;inset:0}.fusion-loading{color:var(--text-2)}.fusion-loading i{font-size:20px;color:var(--accent)}.fusion-error{color:#f87171}.fusion-error i{font-size:20px}.fusion-error a{color:var(--accent)}.um-page{padding:28px 28px 48px;max-width:1440px;width:100%}.um-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.um-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.um-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.um-sub{font-size:13px;color:var(--text-2)}.um-btn-import{display:flex;align-items:center;gap:7px;background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border);border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.um-btn-import:hover:not(:disabled){background:var(--bg-hover);color:var(--text-1);border-color:var(--accent)}.um-btn-import:disabled{opacity:.5;cursor:not-allowed}.um-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s}.um-btn-add:hover{background:var(--accent-hov)}.um-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.um-table{width:100%;border-collapse:collapse}.um-table thead th{padding:12px 16px;font-size:11.5px;font-weight:700;letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-card2)}.um-table tbody tr{border-bottom:1px solid var(--border);transition:background .12s}.um-table tbody tr:last-child{border-bottom:none}.um-table tbody tr:hover{background:var(--bg-hover)}.um-table td{padding:13px 16px;font-size:13px;color:var(--text-1);vertical-align:middle}.um-empty{text-align:center;padding:48px 16px!important;color:var(--text-3);display:flex;flex-direction:column;align-items:center;gap:10px}.um-empty i{font-size:28px;color:var(--text-3)}.um-empty b{color:var(--text-2)}.um-user-cell{display:flex;align-items:center;gap:10px}.um-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;-webkit-user-select:none;user-select:none}.um-name{font-weight:500;color:var(--text-1)}.um-cell-muted{color:var(--text-2)}.um-dash{color:var(--text-3)}.um-role-badge{display:inline-block;font-size:11.5px;font-weight:600;border-radius:20px;border:1px solid transparent;padding:3px 10px;white-space:nowrap}.um-icon-yes{color:#22c55e;font-size:14px}.um-badge{display:inline-block;font-size:11.5px;font-weight:600;border-radius:20px;padding:3px 10px}.um-badge-active{color:#22c55e;background:#22c55e1a;border:1px solid rgba(34,197,94,.25)}.um-badge-off{color:var(--text-3);background:var(--bg-card2);border:1px solid var(--border)}.um-row-actions{display:flex;align-items:center;gap:4px;justify-content:flex-end}.um-act-btn{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:12px;transition:background .12s,color .12s}.um-act-btn:hover{background:var(--bg-hover);color:var(--text-1)}.um-act-del:hover{background:#ef44441f;color:#ef4444}.um-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:500;padding:16px}.um-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:580px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #0006;overflow:hidden}.um-modal-sm{max-width:420px}.um-modal-lg{max-width:860px}.um-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 16px;border-bottom:1px solid var(--border);font-size:15px;font-weight:600;color:var(--text-1);flex-shrink:0}.um-modal-close{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:14px;transition:background .12s}.um-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.um-modal-body{padding:22px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}.um-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border);flex-shrink:0}.um-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.um-field{display:flex;flex-direction:column;gap:6px}.um-field label{font-size:12.5px;font-weight:600;color:var(--text-2)}.um-req{color:#ef4444}.um-hint{font-weight:400;color:var(--text-3);font-size:11px}.um-field input,.um-field select,.um-field textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:13px;color:var(--text-1);outline:none;transition:border-color .15s;width:100%;font-family:inherit}.um-field input::placeholder,.um-field textarea::placeholder{color:var(--text-3)}.um-field input:focus,.um-field select:focus,.um-field textarea:focus{border-color:var(--accent)}.um-input-err{border-color:#ef4444!important}.um-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}.um-field-err{font-size:11.5px;color:#ef4444}.um-pwd-row{display:flex;gap:8px}.um-pwd-input-wrap{position:relative;flex:1}.um-pwd-input-wrap input{padding-right:38px}.um-pwd-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px;transition:color .12s;background:none;border:none;cursor:pointer;padding:2px}.um-pwd-eye:hover{color:var(--text-1)}.um-pwd-gen{display:flex;align-items:center;gap:6px;background:var(--bg-card2);border:1px solid var(--border);border-radius:8px;padding:0 14px;font-size:12.5px;font-weight:600;color:var(--text-2);white-space:nowrap;transition:background .12s,color .12s,border-color .12s;cursor:pointer;flex-shrink:0}.um-pwd-gen:hover{background:var(--bg-hover);color:var(--text-1);border-color:var(--accent)}.um-toggles{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden}.um-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none}.um-toggle-row:last-child{border-bottom:none}.um-toggle-row:hover{background:var(--bg-hover)}.um-toggle-label{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-1)}.um-toggle-label i{color:var(--accent);font-size:13px;width:16px;text-align:center}.um-toggle{width:40px;height:22px;border-radius:20px;background:var(--border);position:relative;flex-shrink:0;transition:background .2s;border:none;cursor:pointer}.um-toggle-on{background:var(--accent)}.um-toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .18s;pointer-events:none}.um-toggle-on .um-toggle-thumb{left:21px}.um-fusion-legend{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px;padding:10px 14px;background:var(--bg-card2);border:1px solid var(--border);border-radius:8px}.um-fleg{display:flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600}.um-fleg i{font-size:11px}.um-fleg-synced{color:#22c55e}.um-fleg-mismatch{color:#f59e0b}.um-fleg-orphan{color:#ef4444}.um-fleg-protected{color:var(--text-3)}.um-frow-mismatch td{background:#f59e0b0a!important}.um-frow-orphan td{background:#ef44440a!important}.um-fsync{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;border-radius:20px;padding:3px 10px;border:1px solid transparent;white-space:nowrap}.um-fsync-synced{color:#22c55e;background:#22c55e1a;border-color:#22c55e40}.um-fsync-mismatch{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b4d}.um-fsync-orphan{color:#ef4444;background:#ef44441a;border-color:#ef444440}.um-fsync-protected{color:var(--text-3);background:var(--bg-card2);border-color:var(--border)}.um-act-fix:hover{background:#f59e0b1f;color:#f59e0b}.um-act-pull:hover{background:#6366f11f;color:#6366f1}.um-act-pull-ok{color:#22c55e!important}.um-act-pull-err{color:#ef4444!important}.um-act-provision:hover{background:#14b8a61f;color:#14b8a6}.um-act-reset-pwd:hover{background:#f59e0b1f;color:#f59e0b}.um-act-kick:hover{background:#f973161f;color:#f97316}.um-btn-reset-pwd{background:#f59e0b}.um-btn-warn{display:flex;align-items:center;gap:7px;padding:8px 18px;border:none;border-radius:8px;background:#f97316;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s}.um-btn-warn:hover{background:#ea580c}.um-btn-warn:disabled{opacity:.45;cursor:not-allowed}.um-btn-provision{background:#14b8a6!important}.um-btn-provision:hover{background:#0d9488!important}.um-sync-msg{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500}.um-sync-ok{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.25)}.um-sync-err{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.um-sync-warn{background:#f973161a;color:#f97316;border:1px solid rgba(249,115,22,.25)}.um-btn-cancel{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text-2);background:var(--bg-card2);border:1px solid var(--border);transition:background .12s,color .12s}.um-btn-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.um-btn-save{display:flex;align-items:center;gap:7px;padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;background:var(--accent);color:#fff;transition:background .12s,opacity .12s}.um-btn-save:hover:not(:disabled){background:var(--accent-hov)}.um-btn-save:disabled{opacity:.45;cursor:not-allowed}.um-btn-danger{display:flex;align-items:center;gap:7px;padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;background:#ef4444;color:#fff;transition:background .12s}.um-btn-danger:hover{background:#dc2626}.um-btn-sm{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;background:var(--accent);color:#fff;cursor:pointer;border:none;text-decoration:none;transition:opacity .12s}.um-btn-sm:hover{opacity:.85}.um-btn-sm.um-btn-danger{background:#ef4444;padding:4px 10px;font-size:12px}.um-btn-sm.um-btn-danger:hover{background:#dc2626}.um-btn-sm.um-btn-playing{background:#22c55e}.um-ext-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#6366f1;background:#6366f115;border:1px solid #6366f130;border-radius:6px;padding:2px 8px;cursor:pointer;transition:background .15s,box-shadow .15s,color .15s,border-color .15s}.um-ext-badge:hover{background:#6366f125;border-color:#6366f170;color:#818cf8;box-shadow:0 0 8px #6366f155,0 0 2px #6366f1aa}.um-sip-section{margin-top:16px;padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--bg-2, rgba(255,255,255,.03))}.um-sip-section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:12px;display:flex;align-items:center;gap:7px}.um-sip-hint{margin-top:10px;font-size:11.5px;color:var(--text-3);display:flex;align-items:flex-start;gap:6px;line-height:1.5}.um-sip-hint i{margin-top:2px;flex-shrink:0}@media(max-width:640px){.um-grid-2{grid-template-columns:1fr}.um-page{padding:16px 16px 40px}.um-pwd-row{flex-direction:column}}.um-reg-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.um-reg-online{background:#22c55e;box-shadow:0 0 5px #22c55e99}.um-reg-offline{background:#ef4444;box-shadow:0 0 5px #ef444499}.um-reg-busy{background:#fb923c;box-shadow:0 0 5px #fb923c99}.um-reg-break{background:#f59e0b;box-shadow:0 0 5px #f59e0b99}.um-reg-dnd{background:#a855f7;box-shadow:0 0 5px #a855f799}.um-tip-wrap{position:relative;cursor:default}.um-tip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#1e293b;color:#e2e8f0;font-size:11px;font-weight:500;padding:4px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:20}.um-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#1e293b}.um-tip-wrap:hover .um-tip{opacity:1}.um-fd-section{margin-bottom:20px}.um-fd-section:last-child{margin-bottom:0}.um-fd-section-title{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:#6366f1;margin-bottom:10px;display:flex;align-items:center;gap:6px}.um-fd-grid{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden}.um-fd-row{display:grid;grid-template-columns:200px 1fr;align-items:center;padding:8px 14px;border-bottom:1px solid var(--border);font-size:13px}.um-fd-row:last-child{border-bottom:none}.um-fd-row:nth-child(odd){background:var(--bg-card2)}.um-fd-label{color:var(--text-3);font-size:12px}.um-fd-value{color:var(--text-1);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.um-fd-yes{color:#22c55e}.um-fd-no{color:#ef4444}.um-fd-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;background:#6366f11f;color:#818cf8;border:1px solid rgba(99,102,241,.25)}.um-fd-empty{padding:16px;border-radius:8px;background:var(--bg-card2);border:1px solid var(--border);color:var(--text-3);font-size:13px;display:flex;align-items:center;gap:8px}.um-fd-pwd-row{display:flex;align-items:center;gap:8px}.um-fd-eye{background:none;border:none;cursor:pointer;color:var(--text-3);padding:2px 4px;font-size:12px;line-height:1}.um-fd-eye:hover{color:var(--text-1)}.um-trunk-section{margin-top:12px}.um-trunk-tabs{display:flex;border-bottom:2px solid var(--border);padding:0 22px;gap:0;flex-shrink:0}.um-trunk-tab{padding:12px 20px;font-size:13px;font-weight:600;color:var(--text-2);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s}.um-trunk-tab:hover{color:var(--text-1)}.um-trunk-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.um-trunk-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;color:var(--text-1);outline:none;width:100%;font-family:SF Mono,Fira Code,monospace;resize:vertical;transition:border-color .15s;line-height:1.6}.um-trunk-textarea::placeholder{color:var(--text-3)}.um-trunk-textarea:focus{border-color:var(--accent)}.um-member-table{border:1px solid var(--border);border-radius:8px;overflow:hidden}.um-member-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#6366f114;font-size:11px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border)}.um-member-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);transition:background .12s}.um-member-row:hover{background:var(--bg-hover)}.um-member-row:last-of-type{border-bottom:none}.um-member-row input[type=number]{padding:4px 6px;font-size:12px;border:1px solid var(--border);border-radius:5px;background:var(--bg-card);color:var(--text-1)}.um-member-row input[type=number]:focus{border-color:var(--accent);outline:none}.um-member-actions{width:120px;display:flex;justify-content:center;gap:4px}.um-mbtn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-3);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}.um-mbtn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-1);border-color:var(--accent)}.um-mbtn:disabled{opacity:.3;cursor:default}.um-mbtn-del:hover:not(:disabled){background:#ef44441a;color:#ef4444;border-color:#ef4444}.um-mbtn-add{background:var(--accent);color:#fff;border-color:var(--accent)}.um-mbtn-add:hover:not(:disabled){background:var(--accent-hov);color:#fff;border-color:var(--accent-hov)}.um-member-add{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card2);border-top:1px solid var(--border)}.um-member-add input[type=text]{padding:7px 12px;font-size:12.5px;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-1)}.um-member-add input[type=text]::placeholder{color:var(--text-3)}.um-member-add input[type=text]:focus{border-color:var(--accent);outline:none}.um-search-results{position:absolute;left:0;right:0;bottom:100%;margin-bottom:4px;background:var(--bg-sidebar);border:1px solid var(--border);border-radius:8px;max-height:180px;overflow-y:auto;box-shadow:0 -8px 24px #00000040;z-index:20}.um-search-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.um-search-item:last-child{border-bottom:none}.um-search-item:hover{background:#6366f11f}.um-search-ext{font-size:13px;font-weight:700;color:var(--accent);min-width:45px}.um-search-name{font-size:12.5px;color:var(--text-1)}.ch-page{padding:28px 28px 48px;max-width:1440px;width:100%}.ch-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ch-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.ch-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.ch-sub{font-size:13px;color:var(--text-2)}.ch-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:20px}.ch-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 18px;display:flex;align-items:center;gap:14px}.ch-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.ch-stat-icon.total{background:#6366f126;color:#6366f1}.ch-stat-icon.answered{background:#22c55e26;color:#22c55e}.ch-stat-icon.missed{background:#ef444426;color:#ef4444}.ch-stat-icon.avg{background:#f9731626;color:#f97316}.ch-stat-icon.inbound{background:#06b6d426;color:#06b6d4}.ch-stat-icon.outbound{background:#8b5cf626;color:#8b5cf6}.ch-stat-info{display:flex;flex-direction:column}.ch-stat-value{font-size:20px;font-weight:700;color:var(--text-1)}.ch-stat-label{font-size:12px;color:var(--text-2);font-weight:500}.ch-filters{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 20px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.ch-filter-group{display:flex;flex-direction:column;gap:4px}.ch-filter-group label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}.ch-filter-group input,.ch-filter-group select{background:var(--bg-card2);border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--text-1);min-width:140px}.ch-filter-group input:focus,.ch-filter-group select:focus{outline:none;border-color:var(--accent)}.ch-filter-group input[type=date]{min-width:130px}.ch-btn-search{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border-radius:6px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;border:none;height:34px}.ch-btn-search:hover{background:var(--accent-hov)}.ch-btn-clear{display:flex;align-items:center;gap:6px;background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border);border-radius:6px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;height:34px}.ch-btn-clear:hover{color:var(--text-1);border-color:var(--text-2)}.ch-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.ch-table{width:100%;border-collapse:collapse}.ch-table thead th{padding:12px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-2);background:var(--bg-card2);border-bottom:1px solid var(--border);white-space:nowrap}.ch-table tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.ch-table tbody tr:hover{background:var(--bg-hover)}.ch-table tbody tr:last-child{border-bottom:none}.ch-table td{padding:10px 14px;font-size:13px;color:var(--text-1);white-space:nowrap}.ch-dir{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px}.ch-dir.inbound{background:#06b6d41f;color:#06b6d4}.ch-dir.local{background:#6366f11f;color:#6366f1}.ch-dir.outbound{background:#8b5cf61f;color:#8b5cf6}.ch-status{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px}.ch-status.answered{background:#22c55e1f;color:#22c55e}.ch-status.missed,.ch-status.failed{background:#ef44441f;color:#ef4444}.ch-status.no_answer{background:#f973161f;color:#f97316}.ch-status.cancelled{background:#9ca3af1f;color:#9ca3af}.ch-status.voicemail{background:#8b5cf61f;color:#8b5cf6}.ch-caller{display:flex;flex-direction:column;gap:1px}.ch-caller-name{font-weight:600;color:var(--text-1);font-size:13px}.ch-caller-num{font-size:11px;color:var(--text-2)}.ch-duration{display:flex;align-items:center;gap:5px;color:var(--text-1)}.ch-duration i{font-size:11px;color:var(--text-2)}.ch-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:60px 20px;color:var(--text-2)}.ch-empty i{font-size:32px;opacity:.4}.ch-empty span{font-size:14px}.ch-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border);font-size:13px;color:var(--text-2)}.ch-page-info{display:flex;align-items:center;gap:6px}.ch-page-btns{display:flex;align-items:center;gap:4px}.ch-page-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;font-size:13px;color:var(--text-2);background:transparent;border:1px solid var(--border);cursor:pointer;transition:all .12s}.ch-page-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-1);border-color:var(--accent)}.ch-page-btn:disabled{opacity:.3;cursor:not-allowed}.ch-page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.ch-overlay{position:fixed;inset:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;animation:ch-fade-in .15s ease}@keyframes ch-fade-in{0%{opacity:0}to{opacity:1}}.ch-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:680px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px #00000059}.ch-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.ch-modal-title{font-size:17px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px}.ch-modal-close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-2);cursor:pointer;font-size:14px;background:transparent;border:none}.ch-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.ch-modal-body{padding:20px 22px}.ch-detail-section{margin-bottom:20px}.ch-detail-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:10px;display:flex;align-items:center;gap:6px}.ch-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px}.ch-detail-item{display:flex;flex-direction:column;gap:2px}.ch-detail-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.3px}.ch-detail-value{font-size:13px;color:var(--text-1);font-weight:500}.ch-detail-value.mono{font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:12px}.ch-loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-2);gap:10px;font-size:14px}.ch-loading i{animation:ch-spin 1s linear infinite}@keyframes ch-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ch-per-page{display:flex;align-items:center;gap:6px}.ch-per-page select{background:var(--bg-card2);border:1px solid var(--border);border-radius:5px;padding:4px 8px;font-size:12px;color:var(--text-1)}.ch-play-btn{display:inline-flex;align-items:center;gap:5px;background:#22c55e1f;color:#22c55e;border:none;border-radius:5px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer}.ch-play-btn:hover{background:#22c55e33}@media(max-width:900px){.ch-filters{flex-direction:column}.ch-filter-group input,.ch-filter-group select{min-width:auto;width:100%}.ch-stats{grid-template-columns:repeat(2,1fr)}.ch-detail-grid{grid-template-columns:1fr}}.or-page{padding:28px 28px 48px;max-width:1440px;width:100%}.or-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.or-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.or-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.or-sub{font-size:13px;color:var(--text-2)}.or-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.or-actions .or-search-wrap{position:relative;display:flex;align-items:center}.or-actions .or-search-wrap i{position:absolute;left:10px;font-size:13px;color:var(--text-2);pointer-events:none}.or-actions .or-search-input{background:var(--bg-card2);border:1px solid var(--border);border-radius:6px;padding:7px 10px 7px 32px;font-size:13px;color:var(--text-1);min-width:200px}.or-actions .or-search-input:focus{outline:none;border-color:var(--accent)}.or-btn{display:flex;align-items:center;gap:6px;border-radius:6px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg-card2);color:var(--text-2);height:34px;transition:all .12s}.or-btn:hover:not(:disabled){color:var(--text-1);border-color:var(--text-2)}.or-btn:disabled{opacity:.35;cursor:not-allowed}.or-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.or-btn-primary:hover:not(:disabled){background:var(--accent-hov);color:#fff;border-color:var(--accent-hov)}.or-btn-danger{color:#ef4444}.or-btn-danger:hover:not(:disabled){background:#ef44441a;border-color:#ef4444;color:#ef4444}.or-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.or-table{width:100%;border-collapse:collapse}.or-table thead th{padding:12px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-2);background:var(--bg-card2);border-bottom:1px solid var(--border);white-space:nowrap}.or-table tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.or-table tbody tr:hover{background:var(--bg-hover)}.or-table tbody tr:last-child{border-bottom:none}.or-table tbody tr.selected{background:var(--accent-dim)}.or-table td{padding:10px 14px;font-size:13px;color:var(--text-1);white-space:nowrap}.or-table td.or-name{font-weight:600}.or-table td.or-expression{font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:12px;color:var(--text-2)}.or-gw-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;margin-right:4px}.or-gw-badge.gw-active{background:#22c55e1f;color:#22c55e}.or-gw-badge.gw-blocked{background:#ef44441f;color:#ef4444}.or-gw-badge.gw-empty{background:#9ca3af14;color:var(--text-2);opacity:.5}.or-enabled{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.or-enabled.yes{background:#22c55e1f;color:#22c55e}.or-enabled.no{background:#ef44441f;color:#ef4444}.or-order{display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-2);background:var(--bg-card2);border-radius:6px;padding:2px 8px;min-width:32px}.or-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:60px 20px;color:var(--text-2)}.or-empty i{font-size:32px;opacity:.4}.or-empty span{font-size:14px}.or-loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-2);gap:10px;font-size:14px}.or-loading i{animation:or-spin 1s linear infinite}@keyframes or-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.or-overlay{position:fixed;inset:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;animation:or-fade-in .15s ease}@keyframes or-fade-in{0%{opacity:0}to{opacity:1}}.or-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:720px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px #00000059}.or-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.or-modal-title{font-size:17px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px}.or-modal-close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-2);cursor:pointer;font-size:14px;background:transparent;border:none}.or-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.or-modal-body{padding:20px 22px}.or-form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.or-form-group label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}.or-form-group input,.or-form-group select,.or-form-group textarea{background:var(--bg-card2);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;color:var(--text-1)}.or-form-group input:focus,.or-form-group select:focus,.or-form-group textarea:focus{outline:none;border-color:var(--accent)}.or-form-group textarea{resize:vertical;min-height:60px}.or-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.or-form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.or-gw-section{margin-top:8px;padding:14px;background:var(--bg-card2);border:1px solid var(--border);border-radius:8px}.or-gw-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:10px;display:flex;align-items:center;gap:6px}.or-gw-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.or-gw-row label{font-size:12px;font-weight:600;color:var(--text-2);min-width:60px}.or-gw-row select{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;color:var(--text-1)}.or-gw-row select:focus{outline:none;border-color:var(--accent)}.or-toggle-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}.or-toggle{position:relative;width:40px;height:22px;background:var(--border);border-radius:11px;cursor:pointer;transition:background .2s;border:none;padding:0}.or-toggle.on{background:#22c55e}.or-toggle:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.or-toggle.on:after{transform:translate(18px)}.or-toggle-label{font-size:13px;font-weight:600;color:var(--text-1)}.or-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 22px;border-top:1px solid var(--border)}.or-confirm-body{padding:24px 22px;text-align:center}.or-confirm-icon{font-size:36px;color:#ef4444;margin-bottom:14px}.or-confirm-text{font-size:15px;color:var(--text-1);margin-bottom:6px;font-weight:600}.or-confirm-sub{font-size:13px;color:var(--text-2);margin-bottom:20px}.or-confirm-btns{display:flex;align-items:center;justify-content:center;gap:10px}.or-preset-row{display:flex;align-items:flex-end;gap:10px}.or-preset-row .or-form-group:first-child{flex:1}.or-preset-row .or-form-group:last-child{min-width:180px}.or-form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.or-ext-chips{display:flex;flex-wrap:wrap;gap:3px}.or-ext-chip{font-size:11px;font-weight:600;background:#6366f11f;color:#818cf8;padding:2px 7px;border-radius:4px;white-space:nowrap}.or-all-ext{font-size:12px;color:var(--text-2);font-style:italic}.or-ext-section{margin-top:8px;padding:14px;background:var(--bg-card2);border-radius:8px;border:1px solid var(--border)}.or-ext-section-title{font-size:13px;font-weight:700;color:var(--text-1);margin-bottom:10px;display:flex;align-items:center;gap:8px}.or-ext-hint{font-size:11px;font-weight:500;color:var(--text-2)}.or-ext-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:4px}.or-ext-tag{display:inline-flex;align-items:center;gap:5px;background:#6366f126;border:1px solid rgba(99,102,241,.25);border-radius:6px;padding:4px 6px 4px 10px;font-size:12px;color:var(--text-1)}.or-ext-tag-num{font-weight:700;color:#818cf8}.or-ext-tag-name{font-weight:500;color:var(--text-2);font-size:11px}.or-ext-tag button{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:none;background:transparent;color:var(--text-2);cursor:pointer;font-size:10px;padding:0}.or-ext-tag button:hover{background:#ef444433;color:#ef4444}.or-ext-search-wrap{position:relative}.or-ext-search-wrap input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--text-1)}.or-ext-search-wrap input:focus{outline:none;border-color:var(--accent)}.or-ext-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0000004d;z-index:20;max-height:200px;overflow-y:auto;margin-top:4px}.or-ext-dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s}.or-ext-dropdown-item:hover{background:var(--bg-hover)}.or-ext-dropdown-num{font-weight:700;font-size:13px;color:#818cf8;min-width:40px}.or-ext-dropdown-name{font-size:13px;color:var(--text-2)}.or-length-wrap{position:relative;cursor:help}.or-length-tip{display:none;position:absolute;top:calc(100% + 6px);left:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px 14px;box-shadow:0 8px 24px #00000059;z-index:30;white-space:nowrap;font-size:12px;color:var(--text-1);min-width:240px}.or-length-wrap:hover .or-length-tip{display:block}.or-length-tip-row{display:flex;justify-content:space-between;gap:16px;padding:2px 0}.or-length-tip-label{color:var(--text-2);font-weight:500}.or-length-tip-value{font-weight:600;color:var(--text-1)}@media(max-width:900px){.or-actions{flex-direction:column;align-items:stretch}.or-actions .or-search-input{min-width:auto;width:100%}.or-form-row,.or-form-row-2,.or-form-row-3{grid-template-columns:1fr}}.fr-shell{display:flex;flex-direction:column;min-height:100%}.fr-header{display:flex;align-items:center;justify-content:space-between;padding:28px 48px 20px;gap:20px;flex-wrap:wrap}.fr-header-left{display:flex;align-items:center;gap:16px}.fr-header-icon{width:48px;height:48px;background:#6366f126;border:1px solid rgba(99,102,241,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--accent)}.fr-title{font-size:24px;font-weight:800;color:var(--text-1);margin:0}.fr-subtitle{font-size:13.5px;color:var(--text-2);margin:2px 0 0}.fr-submit-btn{display:flex;align-items:center;gap:7px;padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.fr-submit-btn:hover{background:var(--accent-hov);transform:translateY(-1px)}.fr-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.fr-toolbar{display:flex;align-items:center;gap:16px;padding:0 48px 16px;flex-wrap:wrap}.fr-search-wrap{position:relative;flex:1;min-width:200px;max-width:400px}.fr-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px;pointer-events:none}.fr-search-input{width:100%;padding:10px 36px 10px 38px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;color:var(--text-1);font-size:13.5px;outline:none;transition:border-color .15s,box-shadow .15s}.fr-search-input::placeholder{color:var(--text-3)}.fr-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.fr-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;font-size:12px;padding:4px}.fr-search-clear:hover{color:var(--text-1)}.fr-sort-wrap{display:flex;align-items:center;gap:8px}.fr-sort-label{font-size:12.5px;color:var(--text-3);font-weight:500}.fr-sort-select{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;cursor:pointer;outline:none}.fr-sort-select:focus{border-color:var(--accent)}.fr-status-tabs{display:flex;align-items:center;gap:6px;padding:0 48px 20px;overflow-x:auto;flex-wrap:nowrap}.fr-status-tab{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-2);font-size:12.5px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}.fr-status-tab:hover{background:var(--bg-hover);color:var(--text-1)}.fr-status-tab.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.fr-tab-count{background:var(--bg-topbar);border-radius:20px;padding:1px 7px;font-size:10.5px;font-weight:700;color:var(--text-3)}.fr-status-tab.active .fr-tab-count{background:var(--accent);color:#fff}.fr-list{flex:1;padding:0 48px 48px;display:flex;flex-direction:column;gap:12px}.fr-card{display:flex;gap:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;transition:border-color .15s,box-shadow .15s}.fr-card:hover{border-color:#6366f166;box-shadow:0 4px 16px #0000001a}.fr-card-vote{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:44px}.fr-vote-btn{width:40px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-base);border:1px solid var(--border);border-radius:8px;color:var(--text-3);font-size:18px;cursor:pointer;transition:all .15s}.fr-vote-btn:hover,.fr-vote-btn.voted{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.fr-vote-count{font-size:14px;font-weight:700;color:var(--text-1)}.fr-card-body{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.fr-card-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fr-card-cat{display:flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.3px}.fr-card-cat i{font-size:11px}.fr-card-priority{font-size:11px;font-weight:600;padding:2px 8px;border:1px solid;border-radius:4px}.fr-card-status{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px}.fr-card-status i{font-size:10px}.fr-card-title{font-size:16px;font-weight:700;color:var(--text-1);margin:0;line-height:1.3}.fr-card:hover .fr-card-title{color:var(--accent)}.fr-card-desc{font-size:13px;color:var(--text-2);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fr-card-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--text-3);margin-top:4px}.fr-card-meta span{display:flex;align-items:center;gap:5px}.fr-card-actions{margin-top:4px}.fr-status-select{padding:5px 10px;background:var(--bg-base);border:1px solid var(--border);border-radius:6px;color:var(--text-1);font-size:12px;cursor:pointer;outline:none}.fr-status-select:focus{border-color:var(--accent)}.fr-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center;color:var(--text-3)}.fr-empty i{font-size:40px;margin-bottom:16px;color:var(--accent);opacity:.5}.fr-empty h3{font-size:17px;color:var(--text-2);margin:0 0 8px}.fr-empty p{font-size:13.5px;margin:0 0 20px}.fr-results-count{font-size:12px;color:var(--text-3);text-align:right;margin-top:4px}.fr-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fr-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006}.fr-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.fr-modal-header h2{font-size:18px;font-weight:700;color:var(--text-1);margin:0;display:flex;align-items:center;gap:10px}.fr-modal-header h2 i{color:var(--accent);font-size:16px}.fr-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-3);font-size:16px;cursor:pointer;border-radius:8px;transition:background .15s,color .15s}.fr-modal-close:hover{background:var(--bg-base);color:var(--text-1)}.fr-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:18px}.fr-field{display:flex;flex-direction:column;gap:6px;position:relative}.fr-field label{font-size:12.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}.fr-required{color:#ef4444}.fr-field input,.fr-field textarea,.fr-field select{padding:10px 14px;background:var(--bg-base);border:1px solid var(--border);border-radius:9px;color:var(--text-1);font-size:14px;font-family:inherit;outline:none;resize:vertical;transition:border-color .15s,box-shadow .15s}.fr-field input:focus,.fr-field textarea:focus,.fr-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11f}.fr-field input::placeholder,.fr-field textarea::placeholder{color:var(--text-3)}.fr-char-count{position:absolute;right:0;top:0;font-size:11px;color:var(--text-3)}.fr-field-row{display:flex;gap:16px}.fr-field-row .fr-field{flex:1}.fr-form-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.fr-cancel-btn{padding:10px 20px;background:var(--bg-base);border:1px solid var(--border);border-radius:9px;color:var(--text-2);font-size:13.5px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.fr-cancel-btn:hover{background:var(--bg-hover);color:var(--text-1)}@media(max-width:900px){.fr-header{padding:20px 20px 16px}.fr-toolbar{padding:0 20px 12px}.fr-status-tabs{padding:0 20px 16px}.fr-list{padding:0 20px 40px}.fr-card{flex-direction:column}.fr-card-vote{flex-direction:row;gap:8px}.fr-field-row{flex-direction:column;gap:14px}}.hr-wrap{padding:0;width:100%}.hr-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.hr-title{font-size:18px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.hr-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.hr-sub{font-size:13px;color:var(--text-2)}.hr-subtitle{font-size:14px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:8px;margin-bottom:12px}.hr-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s}.hr-btn-add:hover{background:var(--accent-hov)}.hr-btn-sm{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border-radius:6px;padding:7px 14px;font-size:12px;font-weight:600;transition:background .15s}.hr-btn-sm:hover{background:var(--accent-hov)}.hr-btn-save{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.hr-btn-save:hover:not(:disabled){background:var(--accent-hov)}.hr-btn-save:disabled{opacity:.5;cursor:not-allowed}.hr-btn-cancel{background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border);border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.hr-btn-cancel:hover{background:var(--bg-hover)}.hr-btn-danger{display:flex;align-items:center;gap:6px;background:#ef4444;color:#fff;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.hr-btn-danger:hover{background:#dc2626}.hr-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.hr-search-box{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:8px 14px;flex:1;max-width:360px}.hr-search-box i{color:var(--text-3);font-size:13px}.hr-search-box input{background:transparent;border:none;outline:none;color:var(--text-1);font-size:13px;width:100%}.hr-search-box input::placeholder{color:var(--text-3)}.hr-date-range{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hr-date-range label{font-size:12px;font-weight:600;color:var(--text-2)}.hr-date-range input,.hr-date-range select{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--text-1)}.hr-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.hr-table{width:100%;border-collapse:collapse}.hr-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:12px 16px;border-bottom:1px solid var(--border)}.hr-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-1);vertical-align:middle}.hr-table tbody tr:last-child td{border-bottom:none}.hr-table tbody tr:hover{background:var(--bg-hover)}.hr-loading{text-align:center;padding:24px 0!important;color:var(--text-3)!important}.hr-empty{text-align:center;padding:40px 0!important;color:var(--text-3)!important;display:flex;flex-direction:column;align-items:center;gap:8px}.hr-empty i{font-size:24px;opacity:.4}.hr-muted{color:var(--text-3)}.hr-emp-cell{display:flex;align-items:center;gap:10px}.hr-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.hr-avatar-sm{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:700;flex-shrink:0}.hr-avatar-xs{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:8px;font-weight:700;flex-shrink:0}.hr-emp-name{font-weight:600;color:var(--text-1)}.hr-emp-nick{font-size:11px;color:var(--text-3);font-style:italic}.hr-emp-title{font-size:13px;color:var(--text-1)}.hr-emp-role{font-size:11px;color:var(--text-3)}.hr-dept-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#6366f11f;color:var(--accent);border:1px solid rgba(99,102,241,.2)}.hr-pay-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px}.hr-pay-hourly{background:#06b6d41f;color:#06b6d4;border:1px solid rgba(6,182,212,.2)}.hr-pay-monthly{background:#8b5cf61f;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.hr-pay-amount{font-weight:600;font-variant-numeric:tabular-nums}.hr-total-row td{background:var(--bg-card2);border-top:2px solid var(--border)}.hr-leave-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.hr-leave-vacation{background:#06b6d41f;color:#06b6d4;border-color:#06b6d433}.hr-leave-sickleave{background:#ef44441f;color:#ef4444;border-color:#ef444433}.hr-leave-personal{background:#8b5cf61f;color:#8b5cf6;border-color:#8b5cf633}.hr-leave-maternitypaternity{background:#ec48991f;color:#ec4899;border-color:#ec489933}.hr-status-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;display:inline-flex;align-items:center;gap:5px;text-transform:capitalize}.hr-status-pending{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.hr-status-approved{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.2)}.hr-status-rejected{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.hr-row-actions{display:flex;gap:4px;justify-content:flex-end}.hr-act-btn{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:background .15s,color .15s;font-size:13px}.hr-act-btn:hover{background:var(--bg-hover);color:var(--text-1)}.hr-act-del:hover{color:#ef4444}.hr-act-approve:hover{color:#10b981}.hr-clock-section{margin-bottom:8px}.hr-clock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.hr-clock-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color .2s}.hr-clock-card.hr-clocked-in{border-color:#10b98166}.hr-clock-name{font-size:13px;font-weight:600;color:var(--text-1);text-align:center}.hr-clock-status{font-size:11px}.hr-status-in{color:#10b981}.hr-status-in i{font-size:8px}.hr-status-out{color:var(--text-3)}.hr-status-out i{font-size:8px}.hr-clock-btns{display:flex;gap:6px;width:100%}.hr-btn-clock-in,.hr-btn-clock-out{flex:1;padding:6px 0;border-radius:6px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:4px;transition:background .15s}.hr-btn-clock-in{background:#10b98126;color:#10b981}.hr-btn-clock-in:hover:not(:disabled){background:#10b98140}.hr-btn-clock-out{background:#ef444426;color:#ef4444}.hr-btn-clock-out:hover:not(:disabled){background:#ef444440}.hr-btn-clock-in:disabled,.hr-btn-clock-out:disabled{opacity:.35;cursor:not-allowed}.hr-dept-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.hr-dept-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:12px}.hr-dept-head{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--text-1)}.hr-dept-head i{color:var(--accent)}.hr-dept-name{flex:1}.hr-dept-roles{display:flex;flex-direction:column;gap:6px}.hr-dept-role{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);padding:6px 10px;background:var(--bg-card2);border-radius:6px}.hr-dept-role i{color:var(--accent);font-size:12px}.hr-dept-role-count{margin-left:auto;font-size:11px;font-weight:600;background:var(--accent-dim);color:var(--accent);padding:1px 8px;border-radius:10px}.hr-dept-members{border-top:1px solid var(--border);padding-top:10px}.hr-dept-members-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;margin-bottom:8px}.hr-dept-member-list{display:flex;flex-direction:column;gap:6px}.hr-dept-member{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-1)}.hr-empty-block{text-align:center;padding:60px 20px;color:var(--text-3)}.hr-empty-block i{font-size:32px;opacity:.3;display:block;margin-bottom:12px}.hr-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.hr-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:96%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.hr-modal-sm{max-width:440px}.hr-modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-size:15px;font-weight:700;color:var(--text-1)}.hr-modal-close{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:background .15s,color .15s}.hr-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.hr-modal-body{padding:20px}.hr-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border)}.hr-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.hr-field{display:flex;flex-direction:column;gap:4px}.hr-field label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}.hr-field input,.hr-field select,.hr-field textarea{background:var(--bg-input, var(--bg-card2));border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;color:var(--text-1);width:100%;transition:border-color .15s}.hr-field input:focus,.hr-field select:focus,.hr-field textarea:focus{border-color:var(--accent);outline:none}.hr-field textarea{resize:vertical;font-family:inherit}.hr-msg{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:8px}.hr-msg-ok{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.2)}.hr-msg-err{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.hr-adv-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:20px}.hr-adv-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;align-items:center;gap:14px}.hr-adv-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.hr-adv-stat-val{font-size:20px;font-weight:700;color:var(--text-1);line-height:1.2}.hr-adv-stat-label{font-size:11px;color:var(--text-3)}.hr-adv-progress{width:60px;height:6px;border-radius:3px;background:var(--bg-card2);overflow:hidden}.hr-adv-progress-bar{height:100%;border-radius:3px;background:#10b981;transition:width .3s}.hr-adv-preview{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px;background:#6366f114;color:var(--accent);border:1px solid rgba(99,102,241,.15);display:flex;align-items:center;gap:8px}.hr-status-paid{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.2)}@media(max-width:768px){.hr-header{flex-direction:column}.hr-form-grid{grid-template-columns:1fr}.hr-table th:nth-child(n+4),.hr-table td:nth-child(n+4){display:none}.hr-table th:last-child,.hr-table td:last-child{display:table-cell}.hr-clock-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.hr-dept-grid{grid-template-columns:1fr}}.geoip-loading{display:flex;align-items:center;justify-content:center;gap:10px;height:300px;color:var(--text-secondary, #94a3b8);font-size:15px}.geoip-page{padding:0;max-width:1400px}.geoip-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.geoip-header-left{flex:1}.geoip-title{font-size:22px;font-weight:700;margin:0 0 4px;color:var(--text-primary, #f1f5f9)}.geoip-title i{margin-right:8px;color:#818cf8}.geoip-subtitle{font-size:13px;color:var(--text-secondary, #94a3b8);margin:0;display:flex;align-items:center;gap:6px}.geoip-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.geoip-dot.active{background:#22c55e;box-shadow:0 0 6px #22c55e80}.geoip-dot.inactive{background:#ef4444;box-shadow:0 0 6px #ef444466}.geoip-header-right{display:flex;gap:8px;align-items:center}.geoip-toggle-master{padding:8px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#94a3b8;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.geoip-toggle-master.on{background:#22c55e1f;color:#22c55e;border-color:#22c55e4d}.geoip-toggle-master:hover{filter:brightness(1.15)}.geoip-btn-apply{padding:8px 20px;border-radius:8px;border:none;background:#818cf8;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.geoip-btn-apply:hover:not(:disabled){background:#6366f1}.geoip-btn-apply:disabled{opacity:.45;cursor:not-allowed}.geoip-msg{padding:8px 16px;border-radius:8px;margin-bottom:16px;font-size:13px;display:flex;align-items:center;gap:6px}.geoip-msg.ok{background:#22c55e1a;color:#22c55e}.geoip-msg.err{background:#ef44441a;color:#ef4444}.geoip-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.geoip-grid{grid-template-columns:1fr}}.geoip-continent-card{background:var(--card-bg, rgba(255,255,255,.03));border:1px solid var(--border-color, rgba(255,255,255,.06));border-radius:12px;overflow:hidden}.geoip-continent-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border:none;background:transparent;cursor:pointer;color:var(--text-primary, #f1f5f9);border-bottom:1px solid var(--border-color, rgba(255,255,255,.06));transition:background .15s}.geoip-continent-header:hover{background:#ffffff08}.geoip-continent-title{display:flex;align-items:center;gap:10px}.geoip-continent-title strong{font-size:15px}.geoip-continent-count{font-size:12px;color:var(--text-secondary, #64748b);font-weight:400}.geoip-continent-header i{font-size:11px;color:#64748b}.geoip-country-list{padding:0}.geoip-country-row{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--border-color, rgba(255,255,255,.04));transition:background .12s}.geoip-country-row:last-child{border-bottom:none}.geoip-country-row:hover{background:#ffffff06}.geoip-country-row.allowed{background:#818cf80a}.geoip-country-info{display:flex;align-items:center;gap:10px}.geoip-code-badge{display:inline-flex;align-items:center;justify-content:center;min-width:30px;padding:2px 6px;border-radius:4px;background:#818cf826;color:#818cf8;font-size:11px;font-weight:700;letter-spacing:.5px}.geoip-country-row.allowed .geoip-code-badge{background:#22c55e26;color:#22c55e}.geoip-country-name{font-size:13.5px;font-weight:500;color:var(--text-primary, #e2e8f0)}.geoip-country-iso{font-size:11px;color:var(--text-secondary, #64748b);font-weight:400}.geoip-switch{position:relative;width:40px;height:22px;border-radius:12px;background:#ffffff1a;border:none;cursor:pointer;transition:background .2s;flex-shrink:0;padding:0}.geoip-switch.on{background:#818cf8}.geoip-switch-knob{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.geoip-switch.on .geoip-switch-knob{transform:translate(18px)}.geoip-pager{display:flex;align-items:center;justify-content:space-between;padding:8px 18px;border-top:1px solid var(--border-color, rgba(255,255,255,.06))}.geoip-pager-info{font-size:12px;color:var(--text-secondary, #64748b)}.geoip-pager-nav{display:flex;align-items:center;gap:8px}.geoip-pager-nav span{font-size:12px;color:var(--text-secondary, #94a3b8)}.geoip-pager-nav button{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .15s}.geoip-pager-nav button:hover:not(:disabled){background:#ffffff14;color:#e2e8f0}.geoip-pager-nav button:disabled{opacity:.3;cursor:not-allowed}[data-theme=light] .geoip-title{color:#1e293b}[data-theme=light] .geoip-title i{color:#6366f1}[data-theme=light] .geoip-subtitle{color:#64748b}[data-theme=light] .geoip-continent-card{background:#fff;border-color:#e2e8f0}[data-theme=light] .geoip-continent-header{color:#1e293b;border-color:#e2e8f0}[data-theme=light] .geoip-continent-header:hover{background:#f8fafc}[data-theme=light] .geoip-country-row{border-color:#f1f5f9}[data-theme=light] .geoip-country-row:hover{background:#f8fafc}[data-theme=light] .geoip-country-row.allowed{background:#6366f10a}[data-theme=light] .geoip-country-name{color:#334155}[data-theme=light] .geoip-country-iso{color:#94a3b8}[data-theme=light] .geoip-code-badge{background:#6366f11a;color:#6366f1}[data-theme=light] .geoip-country-row.allowed .geoip-code-badge{background:#16a34a1a;color:#16a34a}[data-theme=light] .geoip-switch{background:#cbd5e1}[data-theme=light] .geoip-toggle-master{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}[data-theme=light] .geoip-toggle-master.on{background:#16a34a1a;color:#16a34a;border-color:#16a34a40}[data-theme=light] .geoip-pager{border-color:#e2e8f0}[data-theme=light] .geoip-pager-nav button{background:#f1f5f9;border-color:#e2e8f0;color:#64748b}.cr-page{padding:28px 28px 48px;max-width:1440px;width:100%}.cr-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.cr-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.cr-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.cr-sub{font-size:13px;color:var(--text-2)}.cr-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s;border:none;cursor:pointer}.cr-btn-add:hover{background:var(--accent-hov)}.cr-filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.cr-search-wrap{position:relative;flex:1;min-width:200px}.cr-search-wrap>i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px}.cr-search{width:100%;padding:9px 12px 9px 34px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px}.cr-search:focus{border-color:var(--accent);outline:none}.cr-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px}.cr-filter-select{padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;min-width:130px}.cr-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.cr-table{width:100%;border-collapse:collapse}.cr-table thead th{padding:12px 16px;font-size:11.5px;font-weight:700;letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-card2)}.cr-table tbody td{padding:11px 16px;font-size:13px;color:var(--text-1);border-bottom:1px solid var(--border);vertical-align:middle}.cr-table tbody tr:last-child td{border-bottom:none}.cr-row-click{cursor:pointer;transition:background .12s}.cr-row-click:hover{background:var(--bg-hover)}.cr-acct-num{font-size:12px;background:var(--bg-card2);padding:2px 8px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;color:var(--accent)}.cr-name-cell{font-weight:600}.cr-muted{color:var(--text-3)}.cr-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.cr-type-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:6px;background:var(--bg-card2);color:var(--text-2)}.cr-type-badge[data-type=FTTH]{background:#dbeafe;color:#1d4ed8}.cr-type-badge[data-type=SMB]{background:#fef3c7;color:#92400e}.cr-type-badge[data-type=Enterprise]{background:#ede9fe;color:#5b21b6}[data-theme=dark] .cr-type-badge[data-type=FTTH]{background:#1e3a5f;color:#93c5fd}[data-theme=dark] .cr-type-badge[data-type=SMB]{background:#422006;color:#fcd34d}[data-theme=dark] .cr-type-badge[data-type=Enterprise]{background:#2e1065;color:#c4b5fd}.cr-row-btn{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:14px;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s}.cr-row-btn:hover{color:var(--accent);background:var(--accent-dim)}.cr-loading,.cr-empty{padding:60px 20px;text-align:center;color:var(--text-3);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:12px}.cr-loading i,.cr-empty i{font-size:28px}.cr-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.cr-overlay-top{z-index:1010}.cr-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:820px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.cr-modal-site{max-width:900px}.cr-modal-sm{max-width:640px}.cr-modal-confirm{max-width:400px;padding:32px;text-align:center}.cr-confirm-icon{font-size:40px;color:#ef4444;margin-bottom:12px}.cr-confirm-icon i{font-size:40px}.cr-modal-confirm h3{margin:0 0 8px;font-size:18px;color:var(--text-1)}.cr-modal-confirm p{color:var(--text-2);font-size:13px;margin:0 0 20px}.cr-confirm-btns{display:flex;gap:10px;justify-content:center}.cr-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.cr-modal-header h2{font-size:18px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin:0}.cr-acct-tag{font-size:12px;background:var(--accent-dim);color:var(--accent);padding:2px 8px;border-radius:4px;font-weight:600}.cr-modal-close{background:none;border:none;color:var(--text-3);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.cr-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.cr-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-card2);padding:0 16px}.cr-tab{padding:12px 16px;font-size:13px;font-weight:600;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .15s,border-color .15s}.cr-tab:hover{color:var(--text-1)}.cr-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.cr-tab:disabled{opacity:.4;cursor:not-allowed}.cr-tab-count{font-size:11px;background:var(--accent-dim);color:var(--accent);border-radius:10px;padding:1px 7px;font-weight:700}.cr-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.cr-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.cr-span-2{grid-column:span 2}.cr-span-full{grid-column:1 / -1}.cr-field{display:flex;flex-direction:column;gap:4px}.cr-field label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.3px}.cr-field input,.cr-field select,.cr-field textarea{padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card2);color:var(--text-1);font-size:13px;transition:border-color .15s}.cr-field input:focus,.cr-field select:focus,.cr-field textarea:focus{border-color:var(--accent);outline:none}.cr-field textarea{resize:vertical}.cr-req{color:#ef4444}.cr-section-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--accent);margin-top:8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.cr-type-selector{display:flex;gap:10px}.cr-type-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;border-radius:10px;border:2px solid var(--border);background:var(--bg-card2);cursor:pointer;transition:border-color .15s,background .15s}.cr-type-opt i{font-size:22px;color:var(--text-3);transition:color .15s}.cr-type-opt span{font-size:13px;font-weight:700;color:var(--text-1)}.cr-type-opt small{font-size:11px;color:var(--text-3)}.cr-type-opt:hover{border-color:var(--accent)}.cr-type-opt.active{border-color:var(--accent);background:var(--accent-dim)}.cr-type-opt.active i{color:var(--accent)}.cr-type-opt[data-type=FTTH].active{border-color:#3b82f6;background:#dbeafe20}.cr-type-opt[data-type=FTTH].active i{color:#3b82f6}.cr-type-opt[data-type=SMB].active{border-color:#f59e0b;background:#fef3c720}.cr-type-opt[data-type=SMB].active i{color:#f59e0b}.cr-type-opt[data-type=Enterprise].active{border-color:#8b5cf6;background:#ede9fe20}.cr-type-opt[data-type=Enterprise].active i{color:#8b5cf6}.cr-modal-footer{display:flex;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid var(--border);background:var(--bg-card2);border-radius:0 0 14px 14px}.cr-msg{font-size:12px;color:var(--accent);font-weight:600}.cr-btn-save{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.cr-btn-save:hover{background:var(--accent-hov)}.cr-btn-save:disabled{opacity:.6;cursor:not-allowed}.cr-btn-cancel{background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.cr-btn-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.cr-btn-danger{display:flex;align-items:center;gap:6px;background:#ef4444;color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer}.cr-btn-danger:hover{background:#dc2626}.cr-btn-sm{display:flex;align-items:center;gap:5px;background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer}.cr-btn-sm:hover{background:var(--accent-hov)}.cr-btn-gps{display:inline-flex;align-items:center;gap:5px;background:var(--bg-card);color:var(--accent);border:1px solid var(--accent);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;cursor:pointer;margin-left:auto}.cr-btn-gps:hover{background:var(--accent-dim)}.cr-btn-gps:disabled{opacity:.5;cursor:not-allowed}.cr-sub-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cr-sub-header>span{font-size:14px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:8px}.cr-empty-sub{text-align:center;padding:40px 20px;color:var(--text-3);font-size:13px;display:flex;flex-direction:column;align-items:center;gap:10px}.cr-empty-sub i{font-size:28px}.cr-site-list{display:flex;flex-direction:column;gap:10px}.cr-site-card{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg-card2)}.cr-site-card-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg-card)}.cr-site-card-head strong{font-size:14px;color:var(--text-1);margin-right:8px}.cr-site-type-badge{font-size:11px;font-weight:600;background:var(--accent-dim);color:var(--accent);padding:2px 7px;border-radius:4px;margin-right:6px}.cr-site-status-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:4px;background:#dcfce7;color:#166534}.cr-site-status-badge[data-status=Inactive]{background:#fee2e2;color:#991b1b}.cr-site-status-badge[data-status="Pending Installation"]{background:#fef3c7;color:#92400e}[data-theme=dark] .cr-site-status-badge{background:#14532d;color:#86efac}[data-theme=dark] .cr-site-status-badge[data-status=Inactive]{background:#450a0a;color:#fca5a5}[data-theme=dark] .cr-site-status-badge[data-status="Pending Installation"]{background:#422006;color:#fcd34d}.cr-site-actions{display:flex;gap:6px}.cr-site-actions button{background:none;border:none;color:var(--text-3);cursor:pointer;padding:4px 6px;border-radius:4px;font-size:13px}.cr-site-actions button:hover{color:var(--accent);background:var(--accent-dim)}.cr-site-actions button:last-child:hover{color:#ef4444;background:#fee2e2}.cr-site-card-body{padding:10px 14px;display:flex;flex-direction:column;gap:6px}.cr-site-address,.cr-site-gis,.cr-site-fiber{font-size:12px;color:var(--text-2);display:flex;align-items:flex-start;gap:8px}.cr-site-address i,.cr-site-gis i,.cr-site-fiber i{color:var(--text-3);margin-top:2px;min-width:14px;text-align:center}.cr-geo-tag{font-size:10px;background:var(--bg-card);color:var(--text-3);padding:1px 6px;border-radius:3px;margin-left:4px}.cr-contact-list{display:flex;flex-direction:column;gap:8px}.cr-contact-card{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg-card2)}.cr-contact-name{font-size:14px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:8px;margin-bottom:2px}.cr-contact-type-badge{font-size:10px;font-weight:600;background:var(--accent-dim);color:var(--accent);padding:1px 6px;border-radius:3px}.cr-contact-desg{font-size:12px;color:var(--text-2);margin-bottom:4px}.cr-contact-details{display:flex;gap:14px;flex-wrap:wrap}.cr-contact-details span{font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:4px}.cr-contact-details i{font-size:11px;color:var(--text-3)}.cr-contact-actions{display:flex;gap:6px}.cr-contact-actions button{background:none;border:none;color:var(--text-3);cursor:pointer;padding:4px 6px;border-radius:4px;font-size:13px}.cr-contact-actions button:hover{color:var(--accent);background:var(--accent-dim)}.cr-contact-actions button:last-child:hover{color:#ef4444;background:#fee2e2}.cr-map-preview{border:1px solid var(--border);border-radius:10px;overflow:hidden}.cr-geo-stats{font-size:10px;font-weight:500;color:var(--text-3);margin-left:auto;letter-spacing:0}.cr-field-spin{font-size:10px;color:var(--accent);margin-left:4px}.cr-brgy-wrap{position:relative}.cr-brgy-dropdown{position:absolute;top:100%;left:0;right:0;max-height:220px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--accent);border-radius:0 0 8px 8px;box-shadow:0 8px 24px #00000026;z-index:20}.cr-brgy-option{padding:8px 12px;font-size:13px;color:var(--text-1);cursor:pointer;transition:background .1s}.cr-brgy-option:hover{background:var(--accent-dim);color:var(--accent)}.cr-brgy-more{padding:6px 12px;font-size:11px;color:var(--text-3);font-style:italic;border-top:1px solid var(--border)}@media(max-width:640px){.cr-page{padding:16px}.cr-form-grid{grid-template-columns:1fr}.cr-span-2{grid-column:1}.cr-type-selector{flex-direction:column}.cr-modal{max-width:100%;max-height:95vh}.cr-filters{flex-direction:column}}.sp-page{padding:28px 28px 48px;max-width:1440px;width:100%}.sp-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.sp-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.sp-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.sp-sub{font-size:13px;color:var(--text-2)}.sp-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s;border:none;cursor:pointer}.sp-btn-add:hover{background:var(--accent-hov)}.sp-filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.sp-search-wrap{position:relative;flex:1;min-width:200px}.sp-search-wrap>i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px}.sp-search{width:100%;padding:9px 12px 9px 34px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px}.sp-search:focus{border-color:var(--accent);outline:none}.sp-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px}.sp-filter-select{padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;min-width:130px}.sp-loading,.sp-empty{padding:60px 20px;text-align:center;color:var(--text-3);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:12px}.sp-loading i,.sp-empty i{font-size:28px}.sp-category-group{margin-bottom:28px}.sp-category-label{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700;color:var(--text-1);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.sp-category-label i{font-size:16px}.sp-category-label .sp-cat-count{font-size:12px;font-weight:600;background:var(--bg-card2);color:var(--text-2);border-radius:20px;padding:2px 8px}.sp-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.sp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.sp-card:hover{border-color:var(--accent);box-shadow:0 4px 20px #0000001f;transform:translateY(-1px)}.sp-card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px}.sp-card-name{font-size:15px;font-weight:700;color:var(--text-1);flex:1;margin-right:8px}.sp-card-body{padding:0 16px 14px;display:flex;flex-direction:column;gap:8px}.sp-speed-row{display:flex;align-items:center;gap:14px}.sp-speed-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-2)}.sp-speed-item i{font-size:12px;color:var(--text-3)}.sp-speed-val{font-weight:700;color:var(--text-1);font-size:16px}.sp-speed-unit{font-size:11px;color:var(--text-3)}.sp-price{font-size:22px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.sp-price-label{font-size:12px;font-weight:500;color:var(--text-3);margin-left:4px}.sp-detail-row{display:flex;flex-wrap:wrap;gap:6px}.sp-detail-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--text-2);background:var(--bg-card2);border-radius:6px;padding:3px 8px}.sp-detail-pill i{font-size:10px;color:var(--text-3)}.sp-card-foot{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border);background:var(--bg-card2)}.sp-subscriber-count{font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:5px}.sp-subscriber-count i{font-size:11px;color:var(--text-3)}.sp-card-actions{display:flex;gap:4px}.sp-card-actions button{background:none;border:none;color:var(--text-3);cursor:pointer;padding:4px 7px;border-radius:4px;font-size:13px;transition:color .15s,background .15s}.sp-card-actions button:hover{color:var(--accent);background:var(--accent-dim)}.sp-card-actions button.sp-btn-del:hover{color:#ef4444;background:#fee2e2}.sp-cat-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px}.sp-cat-badge[data-cat=FTTH]{background:#dcfce7;color:#166534}.sp-cat-badge[data-cat=SMB]{background:#dbeafe;color:#1d4ed8}.sp-cat-badge[data-cat=Enterprise]{background:#ede9fe;color:#5b21b6}[data-theme=dark] .sp-cat-badge[data-cat=FTTH]{background:#14532d;color:#86efac}[data-theme=dark] .sp-cat-badge[data-cat=SMB]{background:#1e3a5f;color:#93c5fd}[data-theme=dark] .sp-cat-badge[data-cat=Enterprise]{background:#2e1065;color:#c4b5fd}.sp-status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}.sp-status-badge[data-status=Active]{background:#dcfce7;color:#166534}.sp-status-badge[data-status=Discontinued]{background:#f3f4f6;color:#374151}.sp-status-badge[data-status=Draft]{background:#fef3c7;color:#92400e}[data-theme=dark] .sp-status-badge[data-status=Active]{background:#14532d;color:#86efac}[data-theme=dark] .sp-status-badge[data-status=Discontinued]{background:#374151;color:#9ca3af}[data-theme=dark] .sp-status-badge[data-status=Draft]{background:#422006;color:#fcd34d}.sp-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.sp-overlay-top{z-index:1010}.sp-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:720px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.sp-modal-confirm{max-width:400px;padding:32px;text-align:center}.sp-confirm-icon{font-size:40px;color:#ef4444;margin-bottom:12px}.sp-confirm-icon i{font-size:40px}.sp-modal-confirm h3{margin:0 0 8px;font-size:18px;color:var(--text-1)}.sp-modal-confirm p{color:var(--text-2);font-size:13px;margin:0 0 20px}.sp-confirm-btns{display:flex;gap:10px;justify-content:center}.sp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.sp-modal-header h2{font-size:18px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin:0}.sp-modal-close{background:none;border:none;color:var(--text-3);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.sp-modal-close:hover{background:var(--bg-card2);color:var(--text-1)}.sp-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.sp-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.sp-span-2{grid-column:span 2}.sp-span-full{grid-column:1 / -1}.sp-field{display:flex;flex-direction:column;gap:4px}.sp-field label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.3px}.sp-field input,.sp-field select,.sp-field textarea{padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-1);font-size:13px;transition:border-color .15s}.sp-field input:focus,.sp-field select:focus,.sp-field textarea:focus{border-color:var(--accent);outline:none}.sp-field textarea{resize:vertical;min-height:60px}.sp-section-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--accent);margin-top:8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.sp-modal-footer{display:flex;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid var(--border);background:var(--bg-card2);border-radius:0 0 14px 14px}.sp-msg{font-size:12px;color:var(--accent);font-weight:600}.sp-msg-error{color:#ef4444}.sp-btn-save{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.sp-btn-save:hover{background:var(--accent-hov)}.sp-btn-save:disabled{opacity:.6;cursor:not-allowed}.sp-btn-cancel{background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.sp-btn-cancel:hover{background:var(--bg-card2);color:var(--text-1)}.sp-btn-danger{display:flex;align-items:center;gap:6px;background:#ef4444;color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer}.sp-btn-danger:hover{background:#dc2626}.sp-btn-delete-sm{margin-left:auto;background:none;border:1px solid #ef4444;color:#ef4444;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s}.sp-btn-delete-sm:hover{background:#fee2e2}[data-theme=dark] .sp-btn-delete-sm:hover{background:#450a0a}@media(max-width:640px){.sp-page{padding:16px}.sp-form-grid{grid-template-columns:1fr}.sp-span-2{grid-column:1}.sp-modal{max-width:100%;max-height:95vh}.sp-filters{flex-direction:column}.sp-card-grid{grid-template-columns:1fr}}.sub-page{padding:28px 28px 48px;max-width:1440px;width:100%}.sub-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.sub-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.sub-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.sub-subtitle{font-size:13px;color:var(--text-2)}.sub-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s;border:none;cursor:pointer}.sub-btn-add:hover{background:var(--accent-hov)}.sub-filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.sub-search-wrap{position:relative;flex:1;min-width:200px}.sub-search-wrap>i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px}.sub-search{width:100%;padding:9px 12px 9px 34px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px}.sub-search:focus{border-color:var(--accent);outline:none}.sub-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px}.sub-filter-select{padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;min-width:150px}.sub-flash{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;margin-bottom:16px}.sub-flash-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.sub-flash-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}[data-theme=dark] .sub-flash-success{background:#14532d;color:#86efac;border-color:#166534}[data-theme=dark] .sub-flash-error{background:#450a0a;color:#fca5a5;border-color:#991b1b}.sub-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.sub-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.sub-table{width:100%;border-collapse:collapse;min-width:1000px}.sub-table thead th{padding:12px 16px;font-size:11.5px;font-weight:700;letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-card2);position:sticky;top:0;z-index:2}.sub-table tbody td{padding:11px 16px;font-size:13px;color:var(--text-1);border-bottom:1px solid var(--border);vertical-align:middle}.sub-table tbody tr:nth-child(2n){background:var(--bg-card)}.sub-table tbody tr:last-child td{border-bottom:none}.sub-row-click{cursor:pointer;transition:background .12s}.sub-row-click:hover{background:var(--bg-hover)}.sub-acct-num{font-size:12px;background:var(--bg-card2);padding:2px 8px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;color:var(--accent)}.sub-name-cell{font-weight:600}.sub-muted{font-size:11px;color:var(--text-3)}.sub-price{font-weight:600;font-family:SF Mono,Fira Code,monospace}.sub-status-badge{display:inline-block;font-size:11px;font-weight:700;color:#fff;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.3px}.sub-row-actions{display:flex;gap:4px}.sub-row-btn{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:14px;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s}.sub-row-btn:hover{color:var(--accent);background:var(--accent-dim)}.sub-row-btn-del:hover{color:#ef4444;background:#fee2e2}[data-theme=dark] .sub-row-btn-del:hover{background:#450a0a}.sub-loading,.sub-empty{padding:60px 20px;text-align:center;color:var(--text-3);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:12px}.sub-loading i,.sub-empty i{font-size:28px}.sub-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.sub-overlay-top{z-index:1010}.sub-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.sub-modal-confirm{max-width:420px;padding:32px;text-align:center}.sub-confirm-icon{font-size:40px;color:#ef4444;margin-bottom:12px}.sub-confirm-icon i{font-size:40px}.sub-modal-confirm h3{margin:0 0 8px;font-size:18px;color:var(--text-1)}.sub-modal-confirm p{color:var(--text-2);font-size:13px;margin:0 0 20px}.sub-confirm-btns{display:flex;gap:10px;justify-content:center}.sub-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.sub-modal-header h2{font-size:18px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin:0}.sub-modal-close{background:none;border:none;color:var(--text-3);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.sub-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.sub-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.sub-section-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--accent);margin-top:18px;margin-bottom:10px;padding-bottom:4px;border-bottom:1px solid var(--border)}.sub-section-label:first-child{margin-top:0}.sub-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:6px}.sub-span-2{grid-column:span 2}.sub-span-full{grid-column:1 / -1}.sub-field{display:flex;flex-direction:column;gap:4px}.sub-field label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.3px}.sub-field input,.sub-field select,.sub-field textarea{padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card2);color:var(--text-1);font-size:13px;transition:border-color .15s}.sub-field input:focus,.sub-field select:focus,.sub-field textarea:focus{border-color:var(--accent);outline:none}.sub-field textarea{resize:vertical}.sub-field select:disabled{opacity:.5;cursor:not-allowed}.sub-req{color:#ef4444}.sub-field-spin{font-size:12px;color:var(--accent);padding:8px 0}.sub-cust-search-wrap{position:relative}.sub-cust-search-wrap input{width:100%;padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card2);color:var(--text-1);font-size:13px}.sub-cust-search-wrap input:focus{border-color:var(--accent);outline:none}.sub-cust-selected{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card2);font-size:13px;color:var(--text-1)}.sub-cust-tag{font-size:11px;background:var(--accent-dim);color:var(--accent);padding:1px 7px;border-radius:4px;font-weight:700;font-family:SF Mono,Fira Code,monospace}.sub-cust-clear{margin-left:auto;background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px;padding:2px 6px;border-radius:4px}.sub-cust-clear:hover{color:#ef4444}.sub-cust-dropdown{position:absolute;top:100%;left:0;right:0;max-height:240px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--accent);border-radius:0 0 8px 8px;box-shadow:0 8px 24px #0003;z-index:20}.sub-cust-option{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--text-1);cursor:pointer;transition:background .1s}.sub-cust-option:hover{background:var(--accent-dim);color:var(--accent)}.sub-cust-opt-num{font-size:11px;font-weight:700;font-family:SF Mono,Fira Code,monospace;color:var(--accent);min-width:80px}.sub-cust-opt-type{margin-left:auto;font-size:10px;font-weight:600;background:var(--bg-card2);color:var(--text-3);padding:1px 6px;border-radius:3px}.sub-cust-no-match{padding:12px;text-align:center;color:var(--text-3);font-size:13px}.sub-cust-more{padding:6px 12px;font-size:11px;color:var(--text-3);font-style:italic;border-top:1px solid var(--border)}.sub-modal-footer{display:flex;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid var(--border);background:var(--bg-card2);border-radius:0 0 14px 14px}.sub-msg{font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px}.sub-msg-success{color:#22c55e}.sub-msg-error{color:#ef4444}.sub-btn-save{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.sub-btn-save:hover{background:var(--accent-hov)}.sub-btn-save:disabled{opacity:.6;cursor:not-allowed}.sub-btn-cancel{background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.sub-btn-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.sub-btn-danger{display:flex;align-items:center;gap:6px;background:#ef4444;color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer}.sub-btn-danger:hover{background:#dc2626}@media(max-width:768px){.sub-page{padding:16px}.sub-header{flex-direction:column}.sub-form-grid{grid-template-columns:1fr}.sub-span-2{grid-column:1}.sub-modal{max-width:100%;max-height:95vh}.sub-filters{flex-direction:column}}.mdu-page{padding:28px 28px 48px;max-width:1440px;width:100%}.mdu-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.mdu-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin-bottom:4px}.mdu-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.mdu-sub{font-size:13px;color:var(--text-2)}.mdu-btn-add{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;transition:background .15s;border:none;cursor:pointer}.mdu-btn-add:hover{background:var(--accent-hov)}.mdu-filters{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.mdu-search-wrap{position:relative;flex:1;min-width:200px}.mdu-search-wrap>i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px}.mdu-search{width:100%;padding:9px 12px 9px 34px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px}.mdu-search:focus{border-color:var(--accent);outline:none}.mdu-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px}.mdu-filter-select{padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;min-width:150px}.mdu-loading,.mdu-empty{padding:60px 20px;text-align:center;color:var(--text-3);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:12px}.mdu-loading i,.mdu-empty i{font-size:28px}.mdu-empty-sm{padding:20px;text-align:center;color:var(--text-3);font-size:13px}.mdu-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.mdu-bldg-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:18px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .12s}.mdu-bldg-card:hover{border-color:var(--accent);box-shadow:0 4px 20px #00000014;transform:translateY(-2px)}.mdu-bldg-card-top{margin-bottom:10px}.mdu-bldg-name{font-size:16px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px;margin-bottom:8px}.mdu-bldg-name i{font-size:18px}.mdu-bldg-badges{display:flex;flex-wrap:wrap;gap:6px}.mdu-badge-type,.mdu-badge-status,.mdu-badge-agree{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:6px}.mdu-status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.mdu-bldg-location{font-size:12.5px;color:var(--text-2);display:flex;align-items:center;gap:5px;margin-bottom:12px}.mdu-bldg-location i{font-size:11px;color:var(--text-3)}.mdu-bldg-stats{display:flex;gap:14px;margin-bottom:10px;flex-wrap:wrap}.mdu-stat{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-2)}.mdu-stat i{font-size:11px}.mdu-stat-val{font-weight:700;color:var(--text-1)}.mdu-stat-lbl{color:var(--text-3)}.mdu-occ-bar-wrap{display:flex;align-items:center;gap:10px;margin-bottom:10px}.mdu-occ-bar{flex:1;height:6px;background:var(--bg-card2);border-radius:3px;overflow:hidden}.mdu-occ-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:3px;transition:width .3s ease}.mdu-occ-pct{font-size:11.5px;font-weight:600;color:var(--text-2);white-space:nowrap}.mdu-bldg-dev{font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:5px;margin-bottom:6px}.mdu-bldg-dev i{font-size:11px;color:var(--text-3)}.mdu-badge-agree{margin-top:4px}.mdu-back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;padding:6px 0;margin-bottom:16px;transition:color .15s}.mdu-back-btn:hover{color:var(--accent-hov)}.mdu-detail-header{margin-bottom:20px}.mdu-detail-title{display:flex;align-items:center;gap:14px}.mdu-detail-title h1{font-size:24px;font-weight:700;color:var(--text-1);margin:0}.mdu-detail-meta{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}.mdu-detail-loc{font-size:12.5px;color:var(--text-2);display:inline-flex;align-items:center;gap:4px}.mdu-detail-loc i{font-size:11px}.mdu-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:0;gap:0}.mdu-tab{display:flex;align-items:center;gap:6px;padding:12px 20px;font-size:13px;font-weight:600;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.mdu-tab:hover{color:var(--text-1)}.mdu-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.mdu-tab-content{padding:20px 0}.mdu-msg{padding:10px 14px;background:var(--accent-dim);color:var(--accent);border-radius:8px;font-size:13px;font-weight:600;margin-bottom:16px}.mdu-section{margin-bottom:24px}.mdu-section-title{font-size:14px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.mdu-section-title i{color:var(--accent);font-size:13px}.mdu-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.mdu-field{display:flex;flex-direction:column;gap:4px;position:relative}.mdu-field-brgy{position:relative}.mdu-label{font-size:11.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.3px}.mdu-input{padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;transition:border-color .15s}.mdu-input:focus{border-color:var(--accent);outline:none}.mdu-input:disabled{opacity:.5;cursor:not-allowed}.mdu-textarea{padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;resize:vertical;font-family:inherit;width:100%}.mdu-textarea:focus{border-color:var(--accent);outline:none}.mdu-field-checkbox .mdu-checkbox-wrap{display:flex;align-items:center;gap:8px;padding:8px 0;font-size:13px;color:var(--text-1)}.mdu-field-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.mdu-brgy-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000026;z-index:100;margin-top:2px}.mdu-brgy-option{padding:8px 12px;font-size:13px;color:var(--text-1);cursor:pointer;transition:background .1s}.mdu-brgy-option:hover{background:var(--accent-dim)}.mdu-form-actions{display:flex;gap:10px;padding-top:16px;border-top:1px solid var(--border)}.mdu-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.mdu-btn-primary{background:var(--accent);color:#fff}.mdu-btn-primary:hover{background:var(--accent-hov)}.mdu-btn-primary:disabled{opacity:.6;cursor:not-allowed}.mdu-btn-outline{background:transparent;color:var(--accent);border:1px solid var(--accent)}.mdu-btn-outline:hover{background:var(--accent-dim)}.mdu-btn-outline:disabled{opacity:.6;cursor:not-allowed}.mdu-btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.mdu-btn-ghost:hover{background:var(--bg-card2);color:var(--text-1)}.mdu-btn-danger{background:#ef4444;color:#fff}.mdu-btn-danger:hover{background:#dc2626}.mdu-btn-sm{padding:6px 12px;font-size:12px}.mdu-row-btn{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s}.mdu-row-btn:hover{color:var(--accent);background:var(--accent-dim)}.mdu-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.mdu-overlay-top{z-index:1010}.mdu-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:720px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.mdu-modal-sm{max-width:640px}.mdu-modal-xs{max-width:480px}.mdu-modal-confirm{max-width:400px;padding:32px;text-align:center}.mdu-confirm-icon{font-size:40px;color:#ef4444;margin-bottom:12px}.mdu-confirm-icon i{font-size:40px}.mdu-modal-confirm h3{margin:0 0 8px;font-size:18px;color:var(--text-1)}.mdu-modal-confirm p{color:var(--text-2);font-size:13px;margin:0 0 20px}.mdu-confirm-btns{display:flex;gap:10px;justify-content:center}.mdu-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.mdu-modal-header h2{font-size:18px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin:0}.mdu-modal-close{background:none;border:none;color:var(--text-3);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.mdu-modal-close:hover{background:var(--bg-card2);color:var(--text-1)}.mdu-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.mdu-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0}.mdu-floor-actions{display:flex;gap:10px;margin-bottom:16px}.mdu-accordion{display:flex;flex-direction:column;gap:4px}.mdu-acc-item{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}.mdu-acc-item.expanded{border-color:var(--accent)}.mdu-acc-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .12s;-webkit-user-select:none;user-select:none}.mdu-acc-header:hover{background:var(--bg-card2)}.mdu-acc-left{display:flex;align-items:center;gap:10px}.mdu-acc-chevron{font-size:11px;color:var(--text-3);width:14px;text-align:center;transition:transform .2s}.mdu-acc-floor-num{font-size:14px;font-weight:700;color:var(--text-1)}.mdu-acc-floor-label{font-size:12px;color:var(--text-2);background:var(--bg-card2);padding:2px 8px;border-radius:4px}.mdu-acc-right{display:flex;align-items:center;gap:10px}.mdu-acc-info{font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:4px}.mdu-acc-info i{font-size:11px;color:var(--text-3)}.mdu-acc-body{border-top:1px solid var(--border);padding:12px 16px;animation:mdu-slide-down .2s ease}@keyframes mdu-slide-down{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.mdu-acc-unit-actions{display:flex;justify-content:flex-end;margin-bottom:10px}.mdu-unit-table{width:100%;border-collapse:collapse;font-size:13px}.mdu-unit-table thead th{padding:8px 12px;font-size:11px;font-weight:700;letter-spacing:.4px;color:var(--text-3);text-transform:uppercase;text-align:left;border-bottom:1px solid var(--border)}.mdu-unit-table tbody td{padding:8px 12px;color:var(--text-1);border-bottom:1px solid var(--border);vertical-align:middle}.mdu-unit-table tbody tr:last-child td{border-bottom:none}.mdu-unit-num{font-weight:600}.mdu-unit-status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:2px 8px;border-radius:5px}.mdu-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.mdu-muted{color:var(--text-3)}.mdu-map-legend{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.mdu-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2);font-weight:600}.mdu-legend-dot{display:inline-block;width:10px;height:10px;border-radius:3px}.mdu-unit-map{display:flex;flex-direction:column;gap:6px}.mdu-map-floor{display:flex;align-items:flex-start;gap:12px}.mdu-map-floor-label{width:60px;flex-shrink:0;text-align:right;padding-top:12px}.mdu-map-floor-label span:first-child{font-size:13px;font-weight:700;color:var(--text-1)}.mdu-map-floor-sub{display:block;font-size:10px;color:var(--text-3);font-weight:400}.mdu-map-tiles{display:flex;flex-wrap:wrap;gap:4px;flex:1;min-height:48px;align-items:flex-start}.mdu-map-empty-floor{font-size:11px;color:var(--text-3);padding:14px 8px}.mdu-map-tile{width:48px;height:48px;border-radius:6px;border:2px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:transform .12s,box-shadow .12s;position:relative}.mdu-map-tile:hover{transform:scale(1.12);box-shadow:0 4px 12px #00000026;z-index:5}.mdu-tile-num{font-size:11px;font-weight:700;color:var(--text-1);line-height:1}.mdu-tile-dot{width:6px;height:6px;border-radius:50%}.mdu-tooltip{position:fixed;transform:translate(-50%,-100%);background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:10px 14px;box-shadow:0 8px 24px #0003;z-index:1100;pointer-events:none;min-width:160px}.mdu-tooltip-title{font-size:13px;font-weight:700;color:var(--text-1);margin-bottom:6px;border-bottom:1px solid var(--border);padding-bottom:4px}.mdu-tooltip-row{display:flex;justify-content:space-between;gap:12px;font-size:11.5px;color:var(--text-2);padding:1px 0}.mdu-tooltip-row span:first-child{color:var(--text-3)}.mdu-tooltip-row span:last-child{font-weight:600}@media(max-width:768px){.mdu-page{padding:16px 12px 40px}.mdu-header{flex-direction:column}.mdu-card-grid,.mdu-form-grid{grid-template-columns:1fr}.mdu-bldg-stats{gap:8px}.mdu-map-floor{flex-direction:column;gap:4px}.mdu-map-floor-label{width:auto;text-align:left;padding-top:0}.mdu-acc-header{flex-direction:column;align-items:flex-start;gap:8px}.mdu-acc-right{flex-wrap:wrap}.mdu-detail-title{flex-direction:column;align-items:flex-start;gap:8px}.mdu-tabs{overflow-x:auto}.mdu-form-actions{flex-direction:column}}.pm-page{padding:28px 28px 48px;max-width:1540px;width:100%}.pm-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}.pm-tab{padding:10px 24px;font-size:14px;font-weight:600;color:var(--text-2);border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:8px;background:none;border-top:none;border-left:none;border-right:none}.pm-tab:hover{color:var(--text-1)}.pm-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.pm-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.pm-header-left{display:flex;flex-direction:column;gap:4px}.pm-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px}.pm-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.pm-sub{font-size:13px;color:var(--text-2)}.pm-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pm-btn{display:flex;align-items:center;gap:7px;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;transition:background .15s,color .15s,border-color .15s;border:none}.pm-btn-primary{background:var(--accent);color:#fff}.pm-btn-primary:hover{background:var(--accent-hov)}.pm-btn-secondary{background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border)}.pm-btn-secondary:hover{background:var(--bg-card);color:var(--text-1);border-color:var(--accent)}.pm-btn-danger{background:#ef4444;color:#fff}.pm-btn-danger:hover{background:#dc2626}.pm-btn-sm{padding:6px 12px;font-size:12px}.pm-btn:disabled{opacity:.5;cursor:not-allowed}.pm-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center}.pm-search{flex:1;min-width:200px;max-width:320px;padding:9px 14px 9px 36px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s}.pm-search:focus{border-color:var(--accent)}.pm-search-wrap{position:relative;flex:1;min-width:200px;max-width:320px}.pm-search-wrap i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px;pointer-events:none}.pm-filter-select{padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;outline:none;cursor:pointer;min-width:140px}.pm-filter-select:focus{border-color:var(--accent)}.pm-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.pm-table-wrap{overflow-x:auto}.pm-table{width:100%;border-collapse:collapse;font-size:13px}.pm-table th{background:var(--bg-card);color:var(--text-2);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:12px 14px;text-align:left;white-space:nowrap;position:sticky;top:0;z-index:1;border-bottom:1px solid var(--border)}.pm-table td{padding:11px 14px;color:var(--text-1);border-bottom:1px solid var(--border);vertical-align:middle}.pm-table tbody tr{cursor:pointer;transition:background .1s}.pm-table tbody tr:hover{background:var(--bg-card)}.pm-table tbody tr:nth-child(2n){background:var(--bg-1)}.pm-table tbody tr:nth-child(2n):hover{background:var(--bg-card)}.pm-sku{font-family:Courier New,monospace;font-weight:600;font-size:12px;color:var(--accent)}.pm-product-name{font-weight:600;color:var(--text-1)}.pm-brand-model{font-size:12px;color:var(--text-2)}.pm-price{font-weight:600;font-family:Courier New,monospace;white-space:nowrap}.pm-stock-ok{color:#22c55e;font-weight:600}.pm-stock-low{color:#ef4444;font-weight:600}.pm-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}.pm-badge-active{background:#22c55e1f;color:#22c55e}.pm-badge-inactive,.pm-badge-discontinued{background:#ef44441f;color:#ef4444}.pm-badge-topsku{background:#eab3081f;color:#eab308}.pm-badge-preorder{background:#3b82f61f;color:#3b82f6}.pm-badge-incoming{background:#a855f71f;color:#a855f7}.pm-badge-regular{background:var(--accent-dim);color:var(--accent)}.pm-row-actions{display:flex;gap:6px;align-items:center}.pm-row-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--bg-card2);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all .15s}.pm-row-btn:hover{background:var(--bg-card);color:var(--text-1);border-color:var(--accent)}.pm-row-btn.danger:hover{border-color:#ef4444;color:#ef4444}.pm-empty{text-align:center;padding:60px 20px;color:var(--text-3)}.pm-empty i{font-size:40px;margin-bottom:12px;display:block}.pm-empty p{font-size:14px}.pm-loading{text-align:center;padding:60px 20px;color:var(--text-3);font-size:14px}.pm-loading i{margin-right:8px}.pm-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:pm-fadeIn .15s ease}@keyframes pm-fadeIn{0%{opacity:0}to{opacity:1}}.pm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:920px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:pm-slideUp .2s ease}.pm-modal-wide{width:780px}.pm-modal-sm{width:440px}@keyframes pm-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pm-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.pm-modal-title{font-size:17px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px}.pm-modal-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--bg-card2);color:var(--text-2);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.pm-modal-close:hover{background:var(--bg-card);color:var(--text-1)}.pm-modal-body{padding:20px 24px}.pm-modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}.pm-section-label{font-size:13px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;margin:18px 0 10px;display:flex;align-items:center;gap:8px}.pm-section-label:first-child{margin-top:0}.pm-form-grid,.pm-form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px 16px}.pm-form-full{grid-column:1 / -1}.pm-field{display:flex;flex-direction:column;gap:4px}.pm-field label{font-size:12px;font-weight:600;color:var(--text-2)}.pm-field input,.pm-field select,.pm-field textarea{padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s;font-family:inherit}.pm-field input:focus,.pm-field select:focus,.pm-field textarea:focus{border-color:var(--accent)}.pm-field input:read-only{opacity:.6;cursor:not-allowed}.pm-field textarea{resize:vertical;min-height:60px}.pm-confirm-text{font-size:14px;color:var(--text-1);line-height:1.6;margin-bottom:8px}.pm-confirm-name{font-weight:700;color:var(--accent)}.pm-confirm-warn{font-size:12px;color:var(--text-3);margin-top:4px}.pm-cat-list{list-style:none;padding:0;margin:0 0 16px;max-height:240px;overflow-y:auto}.pm-cat-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;font-size:13px;color:var(--text-1);transition:background .1s}.pm-cat-item:hover{background:var(--bg-card)}.pm-cat-add{display:flex;gap:8px;align-items:center}.pm-cat-add input{flex:1;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:13px;outline:none}.pm-cat-add input:focus{border-color:var(--accent)}.pm-toast{position:fixed;bottom:28px;right:28px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px 20px;font-size:13px;font-weight:600;color:var(--text-1);box-shadow:0 8px 30px #0003;z-index:2000;display:flex;align-items:center;gap:10px;animation:pm-slideUp .2s ease}.pm-toast-ok i{color:#22c55e}.pm-toast-err i{color:#ef4444}.pm-searchable-select{position:relative}.pm-ss-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:7px;color:var(--text-1);font-size:13px;cursor:pointer;text-align:left;transition:border-color .15s}.pm-ss-trigger:focus,.pm-ss-trigger:hover{border-color:var(--accent)}.pm-ss-trigger i{font-size:10px;color:var(--text-3);flex-shrink:0;margin-left:8px}.pm-ss-value{color:var(--text-1)}.pm-ss-placeholder{color:var(--text-3)}.pm-ss-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000040;z-index:100;overflow:hidden}.pm-ss-search-wrap{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border)}.pm-ss-search-wrap i{font-size:12px;color:var(--text-3);flex-shrink:0}.pm-ss-search{flex:1;border:none;background:transparent;color:var(--text-1);font-size:13px;outline:none}.pm-ss-search::placeholder{color:var(--text-3)}.pm-ss-options{max-height:200px;overflow-y:auto}.pm-ss-option{padding:8px 12px;font-size:13px;color:var(--text-1);cursor:pointer;transition:background .1s}.pm-ss-option:hover{background:var(--bg-hover)}.pm-ss-option.selected{background:var(--accent-dim);color:var(--accent);font-weight:600}.pm-ss-clear{color:var(--text-3);font-size:12px;display:flex;align-items:center;gap:6px}.pm-ss-clear:hover{color:#ef4444;background:#ef444411}.pm-ss-empty{padding:16px 12px;text-align:center;color:var(--text-3);font-size:13px}.pm-contacts-table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto;margin-bottom:8px}.pm-contacts-table{width:100%;border-collapse:collapse;font-size:12px}.pm-contacts-table th{padding:8px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-2);background:var(--bg-card2);border-bottom:1px solid var(--border);white-space:nowrap}.pm-contacts-table td{padding:4px;border-bottom:1px solid var(--border);vertical-align:middle}.pm-contacts-table tbody tr:last-child td{border-bottom:none}.pm-contacts-table td input[type=text],.pm-contacts-table td input[type=email],.pm-contacts-table td input:not([type]){width:100%;padding:6px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:5px;color:var(--text-1);font-size:12px;outline:none;transition:border-color .15s}.pm-contacts-table td input:focus{border-color:var(--accent)}.pm-contacts-table td input[type=radio]{accent-color:var(--accent);cursor:pointer}.pm-contact-count{font-size:10px;font-weight:600;color:var(--accent);background:var(--accent-dim);padding:1px 6px;border-radius:10px;margin-left:6px}.pm-icon-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:none;background:transparent;color:var(--text-3);cursor:pointer;font-size:12px;transition:background .12s,color .12s}.pm-icon-btn:hover{background:var(--bg-hover);color:var(--text-1)}.pm-icon-danger:hover{background:#ef444422;color:#ef4444}@media(max-width:768px){.pm-page{padding:16px 12px 40px}.pm-header,.pm-filters{flex-direction:column}.pm-search-wrap{max-width:100%}.pm-form-grid,.pm-form-grid-3{grid-template-columns:1fr}.pm-modal{width:100%;border-radius:14px 14px 0 0}}.proc-page{padding:28px 28px 48px;max-width:1520px;width:100%}.proc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.proc-title{font-size:22px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin:0 0 4px}.proc-title i{color:var(--accent)}.proc-count{font-size:13px;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:2px 10px}.proc-sub{font-size:13px;color:var(--text-2);margin:0}.proc-stats{display:flex;gap:12px;margin-bottom:20px;overflow-x:auto;padding-bottom:4px}.proc-stat-card{flex:1;min-width:140px;background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:12px;transition:box-shadow .15s}.proc-stat-card:hover{box-shadow:0 2px 12px #00000014}.proc-stat-total{border-top-color:var(--accent)}.proc-stat-icon{font-size:20px;color:var(--accent);width:36px;text-align:center;flex-shrink:0}.proc-stat-info{display:flex;flex-direction:column;gap:1px}.proc-stat-num{font-size:20px;font-weight:700;color:var(--text-1);line-height:1.2}.proc-stat-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.proc-stat-amount{font-size:12px;color:var(--text-2);font-weight:500}.proc-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center}.proc-search-wrap{position:relative;flex:1;min-width:200px}.proc-search-wrap i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-2);font-size:13px}.proc-search{width:100%;padding:9px 12px 9px 34px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s}.proc-search:focus{border-color:var(--accent)}.proc-select{padding:9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;outline:none;min-width:150px;cursor:pointer}.proc-select:focus{border-color:var(--accent)}.proc-input-date{padding:9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;outline:none}.proc-input-date:focus{border-color:var(--accent)}.proc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.proc-table-wrap{overflow-x:auto}.proc-table{width:100%;border-collapse:collapse;font-size:13px}.proc-table thead{position:sticky;top:0;z-index:2}.proc-table th{padding:12px 14px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-2);background:var(--bg-card2);border-bottom:1px solid var(--border);white-space:nowrap}.proc-table td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text-1);vertical-align:middle}.proc-table tbody tr:nth-child(2n) td{background:var(--bg-card2)}.proc-table tbody tr:nth-child(odd) td{background:var(--bg-card)}.proc-table-sm{font-size:12px}.proc-table-sm th{padding:8px 10px;font-size:10px}.proc-table-sm td{padding:7px 10px}.proc-num{text-align:right}.proc-po-num{font-weight:600;color:var(--accent)}.proc-total-cell{font-weight:600}.proc-row-click{cursor:pointer;transition:background .12s}.proc-row-click:hover td{background:var(--bg-hover)!important}.proc-product-cell{display:flex;flex-direction:column;gap:2px}.proc-sku{font-size:11px;font-weight:600;color:var(--text-2);font-family:monospace}.proc-serial{font-family:monospace;font-size:11px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proc-qty-full{color:#22c55e;font-weight:600}.proc-qty-partial{color:#f97316;font-weight:600}.proc-qty-rejected{color:#ef4444;font-weight:600}.proc-outstanding{background:#f59e0b22;color:#f59e0b;font-weight:700;padding:2px 8px;border-radius:6px;font-size:13px}.proc-totals{padding:16px 20px;display:flex;flex-direction:column;align-items:flex-end;gap:6px;border-top:1px solid var(--border)}.proc-total-row{display:flex;justify-content:space-between;width:260px;font-size:13px;color:var(--text-2)}.proc-total-row span:last-child{font-weight:600;color:var(--text-1)}.proc-total-grand{padding-top:8px;margin-top:4px;border-top:2px solid var(--border);font-size:15px;font-weight:700}.proc-total-grand span{color:var(--text-1)!important}.proc-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;border:1px solid;white-space:nowrap}.proc-badge i{font-size:10px}.proc-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s,opacity .15s}.proc-btn:disabled{opacity:.5;cursor:not-allowed}.proc-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.proc-btn-primary:hover:not(:disabled){background:var(--accent-hov)}.proc-btn-secondary{background:var(--bg-card2);color:var(--text-2);border-color:var(--border)}.proc-btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-1)}.proc-btn-success{background:#22c55e;color:#fff;border-color:#22c55e}.proc-btn-success:hover:not(:disabled){background:#16a34a}.proc-btn-warning{background:#f59e0b;color:#fff;border-color:#f59e0b}.proc-btn-warning:hover:not(:disabled){background:#d97706}.proc-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.proc-btn-danger:hover:not(:disabled){background:#dc2626}.proc-btn-sm{padding:6px 12px;font-size:12px;border-radius:6px;background:var(--accent-dim);color:var(--accent);border-color:transparent}.proc-btn-sm:hover{background:var(--accent);color:#fff}.proc-icon-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:none;background:transparent;color:var(--text-2);cursor:pointer;font-size:13px;transition:background .12s,color .12s}.proc-icon-btn:hover{background:var(--bg-hover);color:var(--text-1)}.proc-icon-danger:hover{background:#ef444422;color:#ef4444}.proc-actions{display:flex;gap:4px}.proc-back-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;margin-bottom:20px;transition:background .12s,color .12s}.proc-back-btn:hover{background:var(--bg-hover);color:var(--text-1)}.proc-detail-header{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:20px}.proc-detail-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.proc-detail-title{font-size:20px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:10px;margin:0 0 8px}.proc-detail-title i{color:var(--accent)}.proc-detail-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--text-2)}.proc-detail-meta i{margin-right:4px;color:var(--text-2)}.proc-detail-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.proc-tabs{display:flex;gap:4px;margin-bottom:0;border-bottom:2px solid var(--border);padding:0 4px}.proc-tab{padding:10px 18px;font-size:13px;font-weight:600;color:var(--text-2);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .12s,border-color .12s;display:flex;align-items:center;gap:6px}.proc-tab:hover{color:var(--text-1)}.proc-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.proc-tab.active i{color:var(--accent)}.proc-line-actions{padding:16px 20px;border-top:1px solid var(--border)}.proc-empty{padding:48px 20px;text-align:center;color:var(--text-2)}.proc-empty i{font-size:36px;margin-bottom:12px;display:block;opacity:.4}.proc-empty p{margin:0;font-size:14px}.proc-loading{padding:40px 20px;text-align:center;color:var(--text-2);font-size:14px}.proc-loading i{margin-right:8px}.proc-loading-modal{background:var(--bg-card);border-radius:12px;padding:32px 40px;color:var(--text-1);font-size:14px;font-weight:600}.proc-loading-modal i{margin-right:8px}.proc-receive-header{padding:16px 20px;border-bottom:1px solid var(--border)}.proc-receipts{padding:12px;display:flex;flex-direction:column;gap:8px}.proc-receipt-card{border:1px solid var(--border);border-radius:10px;overflow:hidden}.proc-receipt-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card2);cursor:pointer;transition:background .12s}.proc-receipt-header:hover{background:var(--bg-hover)}.proc-receipt-info{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.proc-receipt-id{font-weight:600;color:var(--text-1);font-size:13px}.proc-receipt-id i{color:var(--accent);margin-right:4px}.proc-receipt-date,.proc-receipt-by{font-size:12px;color:var(--text-2)}.proc-receipt-by i{margin-right:4px}.proc-receipt-body{padding:12px 16px}.proc-receipt-notes{font-size:12px;color:var(--text-2);margin:0 0 10px;padding:8px 12px;background:var(--bg-card2);border-radius:6px}.proc-receipt-notes i{margin-right:6px;color:var(--text-2)}.proc-timeline{padding:24px 20px;position:relative}.proc-timeline:before{content:"";position:absolute;left:38px;top:32px;bottom:32px;width:2px;background:var(--border)}.proc-timeline-item{display:flex;align-items:center;gap:14px;padding:10px 0;position:relative}.proc-timeline-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;flex-shrink:0;z-index:1}.proc-timeline-content{display:flex;flex-direction:column;gap:2px}.proc-timeline-label{font-size:13px;font-weight:600;color:var(--text-1)}.proc-timeline-date{font-size:12px;color:var(--text-2)}.proc-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.proc-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.proc-modal-lg{max-width:860px}.proc-modal-xl{max-width:1040px}.proc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.proc-modal-header h3{font-size:17px;font-weight:700;color:var(--text-1);margin:0;display:flex;align-items:center;gap:8px}.proc-modal-header h3 i{color:var(--accent)}.proc-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:none;background:transparent;color:var(--text-2);cursor:pointer;font-size:16px;transition:background .12s,color .12s}.proc-modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.proc-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.proc-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0}.proc-form-section{margin-bottom:24px}.proc-form-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.proc-form-section-title{font-size:14px;font-weight:700;color:var(--text-1);margin:0 0 12px;display:flex;align-items:center;gap:7px}.proc-form-section-header .proc-form-section-title{margin-bottom:0}.proc-form-section-title i{color:var(--accent);font-size:13px}.proc-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.proc-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.proc-label{display:flex;flex-wrap:wrap;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--text-2)}.proc-label.proc-full{margin-top:12px}.proc-required{color:#ef4444;display:inline}.proc-input{padding:9px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s}.proc-input:focus{border-color:var(--accent)}.proc-textarea{padding:9px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;outline:none;resize:vertical;font-family:inherit;transition:border-color .15s}.proc-textarea:focus{border-color:var(--accent)}.proc-input-sm{padding:6px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text-1);font-size:12px;outline:none;width:100%;transition:border-color .15s}.proc-input-sm:focus{border-color:var(--accent)}.proc-textarea-sm{padding:6px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text-1);font-size:12px;outline:none;width:100%;resize:vertical;font-family:monospace;transition:border-color .15s}.proc-textarea-sm:focus{border-color:var(--accent)}.proc-select-sm{padding:6px 8px;font-size:12px;min-width:0;width:100%}.proc-edit-lines-wrap{max-height:340px;overflow-y:auto;border:1px solid var(--border);border-radius:8px}.proc-edit-table td{padding:8px 10px}.proc-edit-table th{padding:8px 10px;font-size:10px}.proc-line-total{font-weight:600;white-space:nowrap}.proc-edit-totals{margin-top:12px;border-top:none;padding:0}.proc-gr-table{max-height:400px;overflow-y:auto}@media print{body *{visibility:hidden}.proc-page,.proc-page *{visibility:visible}.proc-page{position:absolute;left:0;top:0;width:100%;padding:20px}.proc-back-btn,.proc-detail-actions,.proc-tabs,.proc-btn,.proc-icon-btn,.proc-line-actions,.proc-filters,.proc-stats{display:none!important}.proc-detail-header{border:none;padding:0 0 16px;margin-bottom:16px;border-bottom:2px solid #000}.proc-detail-title{color:#000;font-size:24px}.proc-detail-title i{display:none}.proc-detail-meta{color:#333}.proc-detail-meta i{display:none}.proc-badge{border:1px solid #000;color:#000!important;background:transparent!important;-webkit-print-color-adjust:exact}.proc-card{border:1px solid #ccc;box-shadow:none}.proc-table th{background:#f0f0f0!important;color:#000;-webkit-print-color-adjust:exact}.proc-table td{color:#000}.proc-table tbody tr:nth-child(2n) td{background:#f8f8f8!important}.proc-table tbody tr:nth-child(odd) td{background:#fff!important}.proc-totals{border-top:1px solid #ccc}.proc-total-row span{color:#000!important}.proc-total-grand{border-top:2px solid #000}.proc-sku{color:#666}}@media(max-width:768px){.proc-page{padding:16px 12px 36px}.proc-header{flex-direction:column}.proc-stats{flex-wrap:wrap}.proc-stat-card{min-width:120px}.proc-filters{flex-direction:column}.proc-search-wrap{min-width:100%}.proc-form-grid,.proc-form-row{grid-template-columns:1fr}.proc-detail-actions{flex-wrap:wrap}.proc-modal{margin:8px}.proc-total-row{width:100%}}.vmi-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:650;animation:vmi-fade .15s ease}@keyframes vmi-fade{0%{opacity:0}to{opacity:1}}.vmi-modal{background:var(--bg-sidebar);border:1px solid var(--border);border-radius:14px;width:640px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;animation:vmi-slide .2s ease}@keyframes vmi-slide{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.vmi-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.vmi-head h2{font-size:16px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px}.vmi-head h2 i{color:var(--accent);font-size:15px}.vmi-head-right{display:flex;align-items:center;gap:10px}.vmi-ext-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:6px;font-size:11px;font-weight:600;color:#10b981}.vmi-unread-badge{padding:2px 8px;background:var(--accent);color:#fff;border-radius:10px;font-size:11px;font-weight:600}.vmi-close{background:none;border:none;color:var(--text-3);font-size:16px;cursor:pointer;padding:4px;transition:color .15s}.vmi-close:hover{color:var(--text-1)}.vmi-body{flex:1;overflow-y:auto;padding:0}.vmi-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-3);text-align:center}.vmi-empty>i{font-size:36px;opacity:.3;margin-bottom:12px}.vmi-empty p{font-size:14px;font-weight:600;color:var(--text-2);margin-bottom:4px}.vmi-empty span{font-size:12.5px}.vmi-list{display:flex;flex-direction:column}.vmi-msg{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);transition:background .15s}.vmi-msg:hover{background:var(--bg-hover)}.vmi-msg:last-child{border-bottom:none}.vmi-msg-unread{background:#6366f10a;border-left:3px solid var(--accent)}.vmi-msg-playing{background:#6366f114}.vmi-play-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--bg-card);border:1px solid var(--border);color:var(--accent);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.vmi-play-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.vmi-play-btn:disabled{opacity:.5;cursor:default}.vmi-play-btn.vmi-playing{background:var(--accent);color:#fff;border-color:var(--accent);animation:vmi-pulse 1.5s ease infinite}@keyframes vmi-pulse{0%,to{box-shadow:0 0 #6366f14d}50%{box-shadow:0 0 0 8px #6366f100}}.vmi-msg-info{flex:1;min-width:0}.vmi-msg-caller{display:flex;align-items:center;gap:8px;margin-bottom:4px}.vmi-caller-name{font-size:13.5px;font-weight:600;color:var(--text-1)}.vmi-caller-number{font-size:12px;color:var(--text-3)}.vmi-new-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}.vmi-msg-meta{display:flex;align-items:center;gap:12px;font-size:11.5px;color:var(--text-3)}.vmi-msg-meta i{font-size:10px;margin-right:3px}.vmi-time{color:var(--text-3)}.vmi-transcription{margin-top:6px;padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;font-size:12px;color:var(--text-2);line-height:1.5;font-style:italic}.vmi-transcription i{color:var(--accent);font-size:9px;margin-right:4px;opacity:.6}.vmi-msg-actions{display:flex;gap:4px;flex-shrink:0}.vmi-act-btn{width:32px;height:32px;border-radius:7px;border:none;background:transparent;color:var(--text-3);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.vmi-act-btn:hover{background:var(--bg-card);color:var(--text-1)}.vmi-act-download:hover{background:#22c55e1a;color:#22c55e}.vmi-act-forward:hover{background:#6366f11a;color:var(--accent)}.vmi-act-delete:hover{background:#ef44441a;color:#ef4444}.vmi-act-btn:disabled{opacity:.4;cursor:default}.vmi-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border);gap:10px}.vmi-footer-info{font-size:12px;color:var(--text-3);flex:1}.vmi-btn-refresh{padding:7px 14px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}.vmi-btn-refresh:hover{background:var(--bg-hover);border-color:var(--accent)}.vmi-btn-close{padding:7px 16px;border-radius:7px;border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.vmi-btn-close:hover{background:var(--accent-hov)}.vmi-fwd-overlay{position:absolute;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:14px}.vmi-fwd-box{background:var(--bg-sidebar);border:1px solid var(--border);border-radius:12px;padding:20px;width:340px;max-width:90%}.vmi-fwd-title{font-size:15px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px;margin-bottom:10px}.vmi-fwd-title i{color:var(--accent)}.vmi-fwd-info{font-size:12px;color:var(--text-2);margin-bottom:14px;line-height:1.5}.vmi-fwd-label{font-size:11.5px;font-weight:600;color:var(--text-2);margin-bottom:6px;display:block}.vmi-fwd-select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-1);font-size:12.5px;outline:none;margin-bottom:14px;cursor:pointer}.vmi-fwd-select:focus{border-color:var(--accent)}.vmi-fwd-btns{display:flex;gap:8px;justify-content:flex-end}.vmi-fwd-cancel{padding:7px 14px;border-radius:7px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);font-size:12px;cursor:pointer;transition:all .15s}.vmi-fwd-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.vmi-fwd-send{padding:7px 16px;border-radius:7px;border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s}.vmi-fwd-send:hover{background:var(--accent-hov)}.vmi-fwd-send:disabled{opacity:.4;cursor:not-allowed}@media(max-width:600px){.vmi-modal{width:100%;max-width:100%;border-radius:0;max-height:100vh}.vmi-msg{flex-wrap:wrap;gap:8px}.vmi-msg-actions{width:100%;justify-content:flex-end}}.up-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:600;animation:up-fade-in .15s ease}@keyframes up-fade-in{0%{opacity:0}to{opacity:1}}.up-modal{background:var(--bg-sidebar);border:1px solid var(--border);border-radius:14px;width:720px;max-width:95vw;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;animation:up-slide-up .2s ease}@keyframes up-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.up-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.up-head h2{font-size:17px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px}.up-head h2 i{color:var(--accent);font-size:15px}.up-close{background:none;border:none;color:var(--text-3);font-size:16px;cursor:pointer;padding:4px;transition:color .15s}.up-close:hover{color:var(--text-1)}.up-tabs{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);overflow-x:auto}.up-tab{background:none;border:none;padding:11px 16px;color:var(--text-3);font-size:12.5px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap;display:flex;align-items:center;gap:6px}.up-tab:hover{color:var(--text-1)}.up-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.up-body{flex:1;overflow-y:auto;padding:20px 24px}.up-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:12px;display:flex;align-items:center;gap:6px}.up-section-title i{color:var(--accent);font-size:11px}.up-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.up-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px}.up-field{display:flex;flex-direction:column;gap:4px}.up-field label{font-size:12px;font-weight:500;color:var(--text-2)}.up-field input,.up-field select{padding:9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}.up-field input:focus,.up-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.up-field input:read-only{opacity:.6;cursor:default}.up-hint{font-size:11px;color:var(--text-3);font-weight:400}.up-identity-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-bottom:16px}.up-identity-avatar{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0}.up-identity-info{flex:1}.up-identity-name{font-size:16px;font-weight:700;color:var(--text-1)}.up-identity-email{font-size:12.5px;color:var(--text-2);margin-top:2px}.up-identity-badges{display:flex;gap:6px;margin-top:6px}.up-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:600}.up-badge-role{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(99,102,241,.2)}.up-badge-ext{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.up-status-row{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.up-status-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:12.5px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);transition:all .15s}.up-status-btn:hover{border-color:var(--text-3)}.up-status-btn i{font-size:8px}.up-status-btn.up-status-active{font-weight:600}.up-status-available.up-status-active{background:#10b9811f;border-color:#10b981;color:#10b981;box-shadow:0 0 12px #10b98133}.up-status-busy.up-status-active{background:#fb923c1f;border-color:#fb923c;color:#fb923c;box-shadow:0 0 12px #fb923c33}.up-status-break.up-status-active{background:#f59e0b1f;border-color:#f59e0b;color:#f59e0b;box-shadow:0 0 12px #f59e0b33}.up-status-dnd.up-status-active{background:#a855f71f;border-color:#a855f7;color:#a855f7;box-shadow:0 0 12px #a855f733}.up-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;margin-bottom:8px;cursor:pointer;transition:background .15s}.up-toggle-row:hover{background:var(--bg-hover)}.up-toggle-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-1)}.up-toggle-label i{color:var(--accent);width:18px;text-align:center}.up-toggle{width:38px;height:20px;background:var(--border);border-radius:10px;position:relative;transition:background .2s;flex-shrink:0}.up-toggle-on{background:var(--accent)}.up-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.up-toggle-on .up-toggle-thumb{transform:translate(18px)}.up-fwd-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;margin-bottom:8px}.up-fwd-label{font-size:12.5px;color:var(--text-1);min-width:120px;display:flex;align-items:center;gap:6px}.up-fwd-label i{color:var(--accent);font-size:11px}.up-fwd-input{flex:1;padding:7px 10px;background:var(--bg-base);border:1px solid var(--border);border-radius:6px;color:var(--text-1);font-size:12.5px;outline:none;transition:border-color .15s}.up-fwd-input:focus{border-color:var(--accent)}.up-fwd-input:disabled{opacity:.4}.up-did-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;margin-bottom:8px}.up-did-number{font-size:13.5px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:8px}.up-did-number i{color:#10b981;font-size:12px}.up-did-desc{font-size:12px;color:var(--text-3)}.up-empty{text-align:center;padding:24px;color:var(--text-3);font-size:13px}.up-empty i{font-size:24px;display:block;margin-bottom:8px;opacity:.4}.up-pwd-wrap{position:relative;display:flex;align-items:center}.up-pwd-wrap input{width:100%;padding-right:36px}.up-pwd-toggle{position:absolute;right:8px;background:none;border:none;color:var(--text-3);font-size:13px;cursor:pointer;padding:4px}.up-pwd-toggle:hover{color:var(--text-2)}.up-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1px solid var(--border)}.up-btn{padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:background .15s,transform .1s,opacity .15s;display:flex;align-items:center;gap:7px}.up-btn:hover:not(:disabled){transform:translateY(-1px)}.up-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.up-btn-ghost{background:var(--bg-card);border:1px solid var(--border);color:var(--text-1)}.up-btn-ghost:hover:not(:disabled){background:var(--bg-hover)}.up-btn-primary{background:var(--accent);color:#fff}.up-btn-primary:hover:not(:disabled){background:var(--accent-hov)}.up-btn-vm{background:#10b9811a;border:1px solid rgba(16,185,129,.25);color:#10b981}.up-btn-vm:hover:not(:disabled){background:#10b9812e;border-color:#10b981}.up-sync-msg{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:8px;font-size:12.5px;margin-bottom:12px}.up-sync-ok{background:#10b9811a;border:1px solid rgba(16,185,129,.25);color:#10b981}.up-sync-err{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#f87171}.up-loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-3);font-size:13px;gap:8px}.up-loading i{animation:up-spin 1s linear infinite}@keyframes up-spin{to{transform:rotate(360deg)}}@media(max-width:600px){.up-modal{width:100%;max-width:100%;border-radius:0;max-height:100vh}.up-grid-2,.up-grid-3{grid-template-columns:1fr}.up-fwd-row{flex-direction:column;align-items:stretch}.up-fwd-label{min-width:auto}}.chat-container{position:fixed;bottom:28px;right:88px;z-index:9000;display:flex;flex-direction:row;align-items:flex-end;gap:8px;transition:right .25s ease}.chat-fab{width:52px;height:52px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 20px #6366f180;transition:transform .2s,box-shadow .2s;cursor:pointer;flex-shrink:0;order:1;position:relative}.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #6366f199}.chat-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;background:#ef4444;color:#fff;border-radius:10px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--bg-base)}.chat-panel{width:340px;max-height:520px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 40px #00000040;display:flex;flex-direction:column;overflow:hidden;animation:chatSlideUp .2s ease-out;order:2}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.chat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.chat-panel-header h3{font-size:16px;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px}.chat-panel-header h3 i{color:var(--accent)}.chat-panel-actions{display:flex;gap:4px}.chat-panel-actions button{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:13px;transition:background .15s,color .15s}.chat-panel-actions button:hover{background:var(--bg-hover);color:var(--text-1)}.chat-search{padding:8px 12px;border-bottom:1px solid var(--border)}.chat-search input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:20px;padding:7px 14px 7px 34px;color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s}.chat-search input:focus{border-color:var(--accent)}.chat-search input::placeholder{color:var(--text-3)}.chat-search-wrap{position:relative}.chat-search-wrap i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:12px;pointer-events:none}.chat-tabs{display:flex;border-bottom:1px solid var(--border)}.chat-tab{flex:1;padding:8px 0;font-size:12px;font-weight:600;color:var(--text-2);text-align:center;transition:color .15s;border-bottom:2px solid transparent}.chat-tab:hover{color:var(--text-1)}.chat-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.chat-contact-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}.chat-contact-list::-webkit-scrollbar{width:4px}.chat-contact-list::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:2px}.chat-contact{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:background .12s;width:100%;text-align:left}.chat-contact:hover{background:var(--bg-hover)}.chat-contact-avatar{position:relative;flex-shrink:0}.chat-contact-avatar .avatar{width:40px;height:40px;font-size:14px}.chat-online-dot{position:absolute;bottom:0;right:0;width:12px;height:12px;background:#31a24c;border-radius:50%;border:2px solid var(--bg-card);box-shadow:0 0 #31a24c66}.chat-offline-dot{position:absolute;bottom:0;right:0;width:12px;height:12px;background:transparent;border-radius:50%;border:2px solid var(--text-3)}.chat-contact-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-contact-name{font-size:13px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-contact-preview{font-size:12px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-contact-preview.unread{color:var(--text-1);font-weight:600}.chat-contact-preview.chat-active-text{color:#31a24c;font-weight:500}.chat-contact-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.chat-contact-time{font-size:11px;color:var(--text-3)}.chat-unread-badge{min-width:18px;height:18px;background:var(--accent);color:#fff;border-radius:9px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px}.chat-empty{padding:40px 20px;text-align:center;color:var(--text-3);font-size:13px}.chat-empty i{display:block;font-size:32px;margin-bottom:12px;opacity:.4}.chat-window{position:fixed;bottom:0;width:328px;height:440px;background:var(--bg-card);border:1px solid var(--border);border-bottom:none;border-radius:12px 12px 0 0;box-shadow:0 -4px 24px #00000026;z-index:9002;display:flex;flex-direction:column;overflow:hidden;animation:chatWindowUp .2s ease-out}.chat-window.minimized{height:48px}@keyframes chatWindowUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-window-header{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-sidebar);border-bottom:1px solid var(--border);cursor:pointer;flex-shrink:0}.chat-window-avatar-wrap{position:relative;flex-shrink:0}.chat-window-header .avatar{width:30px;height:30px;font-size:11px}.chat-header-online-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;background:#31a24c;border-radius:50%;border:2px solid var(--bg-sidebar)}.chat-window-header-info{flex:1;min-width:0}.chat-window-header-name{font-size:13px;font-weight:700;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-window-header-status{font-size:11px;color:#31a24c;display:flex;align-items:center;gap:4px}.chat-status-dot{width:6px;height:6px;border-radius:50%;background:#31a24c;flex-shrink:0}.chat-window-header-status.offline{color:var(--text-3)}.chat-window-actions{display:flex;gap:2px}.chat-window-actions button{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:12px;transition:background .15s,color .15s}.chat-window-actions button:hover{background:var(--bg-hover);color:var(--text-1)}.chat-messages{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:2px}.chat-msg-group{display:flex;flex-direction:column;gap:2px}.chat-msg-group.sent{align-items:flex-end}.chat-msg-group.received{align-items:flex-start}.chat-msg-sender{font-size:11px;color:var(--text-3);margin-bottom:2px;padding:0 8px}.chat-bubble{max-width:100%;padding:8px 12px;border-radius:18px;font-size:13px;line-height:1.4;word-wrap:break-word}.chat-bubble.sent{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:4px}.chat-bubble.received{background:var(--bg-card2);color:var(--text-1);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-msg-time{font-size:9px;color:var(--text-3);padding:0 12px;margin-top:1px;opacity:0;transition:opacity .15s}.chat-msg-group:hover .chat-msg-time{opacity:1}.chat-day-divider{text-align:center;margin:12px 0;font-size:11px;color:var(--text-3);position:relative}.chat-day-divider:before,.chat-day-divider:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:var(--border)}.chat-day-divider:before{left:0}.chat-day-divider:after{right:0}.chat-typing{padding:4px 10px;font-size:12px;color:var(--text-3);font-style:italic}.chat-input-area{display:flex;align-items:center;gap:6px;padding:8px 10px;border-top:1px solid var(--border);background:var(--bg-sidebar)}.chat-input-area input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:20px;padding:8px 14px;color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s}.chat-input-area input:focus{border-color:var(--accent)}.chat-input-area input::placeholder{color:var(--text-3)}.chat-send-btn{width:34px;height:34px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;transition:transform .15s,opacity .15s;flex-shrink:0}.chat-send-btn:hover{transform:scale(1.1)}.chat-send-btn:disabled{opacity:.4;transform:none}.chat-input-actions{display:flex;gap:2px}.chat-input-actions button{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:14px;transition:color .15s}.chat-input-actions button:hover{color:var(--accent)}.chat-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:9010;display:flex;align-items:center;justify-content:center;animation:chatFadeIn .15s ease-out}@keyframes chatFadeIn{0%{opacity:0}to{opacity:1}}.chat-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:380px;max-height:500px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 12px 40px #0000004d}.chat-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.chat-modal-header h3{font-size:15px;font-weight:700;color:var(--text-1)}.chat-modal-body{padding:14px 16px;overflow-y:auto;flex:1}.chat-modal-body label{display:block;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px}.chat-modal-body input[type=text]{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text-1);font-size:13px;outline:none;margin-bottom:14px}.chat-modal-body input[type=text]:focus{border-color:var(--accent)}.chat-member-list{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.chat-member-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .12s}.chat-member-item:hover{background:var(--bg-hover)}.chat-member-item .avatar{width:32px;height:32px;font-size:11px}.chat-member-item span{flex:1;font-size:13px;color:var(--text-1)}.chat-member-check{width:20px;height:20px;border-radius:4px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;color:transparent;transition:all .15s;flex-shrink:0}.chat-member-check.checked{background:var(--accent);border-color:var(--accent);color:#fff}.chat-modal-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.chat-modal-footer button{padding:7px 18px;border-radius:8px;font-size:13px;font-weight:600;transition:background .15s}.chat-btn-cancel{color:var(--text-2)}.chat-btn-cancel:hover{background:var(--bg-hover)}.chat-btn-create{background:var(--accent);color:#fff}.chat-btn-create:hover{background:var(--accent-hov)}.chat-btn-create:disabled{opacity:.4}.chat-group-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;flex-shrink:0}.chat-selected-members{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.chat-member-chip{display:flex;align-items:center;gap:4px;padding:3px 8px 3px 4px;background:var(--accent-dim);border-radius:12px;font-size:11px;color:var(--accent);font-weight:600}.chat-member-chip button{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--accent)}.chat-member-chip button:hover{background:#6366f133}.chat-attach-preview{display:flex;align-items:center;gap:8px;padding:6px 10px;border-top:1px solid var(--border);background:var(--bg-card2)}.chat-attach-thumb{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.chat-attach-file-icon{width:40px;height:40px;border-radius:6px;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--accent);flex-shrink:0}.chat-attach-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-attach-name{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-attach-size{font-size:11px;color:var(--text-3)}.chat-attach-remove{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:11px;flex-shrink:0;transition:background .15s,color .15s}.chat-attach-remove:hover{background:#ef444426;color:#ef4444}.chat-attach-error{font-size:11px;color:#ef4444;padding:4px 10px;background:#ef444414;border-top:1px solid rgba(239,68,68,.15)}.chat-upload-progress{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:3px}.chat-upload-progress-bar{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:2px;transition:width .2s}.chat-bubble-image{max-width:200px;border-radius:12px;cursor:pointer;transition:opacity .15s}.chat-bubble-image:hover{opacity:.9}.chat-bubble-file{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff14;border-radius:10px;text-decoration:none;color:inherit;transition:background .15s;max-width:200px}.chat-bubble.received .chat-bubble-file{background:var(--bg-hover)}.chat-bubble-file:hover{background:#ffffff24}.chat-bubble.received .chat-bubble-file:hover{background:var(--bg-input)}.chat-bubble-file-icon{width:32px;height:32px;border-radius:6px;background:#ffffff1f;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.chat-bubble.received .chat-bubble-file-icon{background:var(--accent-dim);color:var(--accent)}.chat-bubble-file-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-bubble-file-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-bubble-file-size{font-size:10px;opacity:.7}.chat-lightbox{position:fixed;inset:0;background:#000000d9;z-index:9999;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:chatFadeIn .15s ease-out}.chat-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px #00000080}.chat-lightbox-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .15s}.chat-lightbox-close:hover{background:#ffffff40}.chat-bubble-wrap{position:relative;max-width:80%}.chat-msg-group.sent .chat-bubble-wrap{margin-left:auto}.chat-msg-group.received .chat-bubble-wrap{margin-right:auto}.chat-react-btn{position:absolute;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:var(--bg-card2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-3);opacity:0;transition:opacity .15s,background .15s,color .15s;z-index:2}.chat-react-btn.left{right:100%;margin-right:4px}.chat-react-btn.right{left:100%;margin-left:4px}.chat-bubble-wrap:hover .chat-react-btn{opacity:1}.chat-react-btn:hover{background:var(--bg-hover);color:var(--text-1)}.chat-emoji-picker{position:absolute;bottom:100%;margin-bottom:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:4px 6px;display:flex;gap:2px;box-shadow:0 4px 16px #0003;z-index:10;animation:chatFadeIn .12s ease-out;white-space:nowrap}.chat-emoji-picker.left{right:0}.chat-emoji-picker.right{left:0}.chat-emoji-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;transition:transform .12s,background .12s;flex-shrink:0}.chat-emoji-btn:hover{transform:scale(1.25);background:var(--bg-hover)}.chat-reactions{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}.chat-reactions.sent{justify-content:flex-end}.chat-reaction-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:10px;background:var(--bg-card2);border:1px solid var(--border);font-size:13px;cursor:pointer;transition:background .12s,border-color .12s;line-height:1.4}.chat-reaction-badge:hover{background:var(--bg-hover)}.chat-reaction-badge.mine{border-color:var(--accent);background:var(--accent-dim)}.chat-reaction-emoji{font-size:14px}.chat-reaction-count{font-size:11px;font-weight:600;color:var(--text-2)}.chat-reaction-badge.mine .chat-reaction-count{color:var(--accent)}@media(max-width:720px){.chat-container{right:62px;bottom:16px;flex-direction:column}.chat-panel{width:calc(100vw - 16px);max-height:70vh}.chat-window{width:100%;right:0!important;left:0;height:60vh}}:root,[data-theme=dark]{--bg-base: #252a32;--bg-sidebar: #252a32;--bg-card: #2f3440;--bg-card2: #343a47;--bg-hover: #383f4e;--bg-input: #2c3240;--border: #3a424f;--text-1: #e2e2f0;--text-2: #8888b0;--text-3: #50507a;--accent: #6366f1;--accent-hov: #4f46e5;--accent-dim: rgba(99, 102, 241, .14);--scrollbar: #3a424f}[data-theme=light]{--bg-base: #f0f2f8;--bg-sidebar: #ffffff;--bg-card: #ffffff;--bg-card2: #f7f8ff;--bg-hover: #eef0ff;--bg-input: #f4f5ff;--border: #e4e6f0;--text-1: #1a1835;--text-2: #64748b;--text-3: #94a3b8;--accent: #4f46e5;--accent-hov: #4338ca;--accent-dim: rgba(79, 70, 229, .1);--scrollbar: #d4d7f0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button{cursor:pointer;border:none;background:none;font-family:inherit}input{font-family:inherit}select{font-family:inherit;background:var(--bg-input);color:var(--text-1);border:1px solid var(--border)}select option{background:var(--bg-card);color:var(--text-1)}b{font-weight:600}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 30px #00000040;z-index:999;overflow:hidden}.user-menu-header{display:flex;align-items:center;gap:10px;padding:16px 16px 8px}.user-menu-divider{height:1px;background:var(--border);margin:4px 0}.user-menu-status-btn{display:flex;align-items:center;gap:10px;width:100%;padding:7px 0;background:none;border:none;color:var(--text-1);font-size:13px;cursor:pointer;border-radius:6px;transition:background .15s}.user-menu-status-btn:hover{background:var(--bg-hover)}.user-menu-action{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:none;border:none;color:var(--text-1);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.user-menu-action:hover{background:var(--bg-hover)}.user-menu-action i{width:16px;text-align:center;font-size:13px;color:var(--text-2)}.app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg-base);color:var(--text-1);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px;transition:background .2s,color .2s}.sidebar{width:220px;min-width:220px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width .22s ease,min-width .22s ease;overflow:hidden}.sidebar.collapsed{width:58px;min-width:58px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 12px 16px;border-bottom:1px solid var(--border);min-height:64px}.logo{display:flex;flex-direction:column;line-height:1.15}.logo-main{font-size:18px;font-weight:700;color:var(--text-1)}.logo-sub{font-size:13px;font-weight:600;color:var(--accent);letter-spacing:.3px}.collapse-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-2);font-size:11px;flex-shrink:0;transition:background .15s,color .15s}.collapse-btn:hover{background:var(--bg-hover);color:var(--text-1)}.sidebar-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:1px;overflow-y:auto;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{display:flex;align-items:center;gap:11px;padding:4px 10px;border-radius:6px;color:var(--text-2);font-size:12px;font-weight:500;white-space:nowrap;width:100%;text-align:left;transition:background .15s,color .15s}.nav-item i{width:16px;text-align:center;flex-shrink:0;font-size:13px}a.nav-item{text-decoration:none;cursor:pointer}.nav-item:hover{background:var(--bg-hover);color:var(--text-1)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item.active i{color:var(--accent)}.nav-cat-group{margin-top:1px}.nav-category{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px 10px;border:none;background:none;font-size:12px;font-weight:500;text-transform:none;letter-spacing:0;color:#f97316;white-space:nowrap;overflow:hidden;cursor:pointer;transition:color .15s}.nav-category:hover{color:#fb923c}.nav-category-label{flex:1;text-align:left}.nav-category-arrow{font-size:9px;transition:transform .2s;transform:rotate(-90deg)}.nav-category-arrow.open{transform:rotate(0)}.nav-item.nav-item-child{padding-left:10px}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.sidebar-user{display:flex;align-items:center;gap:9px;padding:4px}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-user-name{font-size:12.5px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--text-2)}.footer-label{font-size:11px;color:var(--text-3);padding:0 6px}.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.3px;-webkit-user-select:none;user-select:none}.avatar-sm{width:30px;height:30px;font-size:11px}.avatar-xs{width:26px;height:26px;font-size:10px}.main-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:60px;min-height:60px;background:var(--bg-sidebar);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;gap:14px}.kb-topbar-stats{display:flex;align-items:center;gap:18px;font-size:12px;color:var(--text-3);white-space:nowrap}.kb-topbar-stats span{display:flex;align-items:center;gap:5px}.kb-topbar-stats i{color:var(--accent)}.topbar-tagline{font-size:12px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.search-wrap{position:relative;flex:1;max-width:340px}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:12px;pointer-events:none}.search-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:8px 12px 8px 34px;color:var(--text-1);font-size:13px;outline:none;transition:border-color .15s}.search-input::placeholder{color:var(--text-3)}.search-input:focus{border-color:var(--accent)}.topbar-right{display:flex;align-items:center;gap:8px}.btn-new-ticket{display:flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.btn-new-ticket:hover{background:var(--accent-hov)}.icon-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:15px;transition:background .15s,color .15s}.icon-btn:hover{background:var(--bg-hover);color:var(--text-1)}.topbar-avatar{cursor:pointer}.content{flex:1;overflow-y:auto;padding:28px 28px 48px;scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}.content-full{padding:0!important;display:flex;flex-direction:column}.content::-webkit-scrollbar{width:6px}.content::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}.content::-webkit-scrollbar-track{background:transparent}.page-heading{margin-bottom:24px}.page-heading h1{font-size:22px;font-weight:700;color:var(--text-1);margin-bottom:4px}.page-heading p{font-size:13px;color:var(--text-2)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:16px;transition:background .15s}.stat-card:hover{background:var(--bg-hover)}.stat-icon-box{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;flex-shrink:0}.stat-icon-box.blue{background:#3b82f6}.stat-icon-box.purple{background:#8b5cf6}.stat-icon-box.green{background:#22c55e}.stat-icon-box.orange{background:#f97316}.stat-val{font-size:28px;font-weight:700;line-height:1;color:var(--text-1)}.stat-label{font-size:12px;color:var(--text-2);margin-top:3px}.mid-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:18px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px}.card-heading{font-size:14px;font-weight:600;color:var(--text-1);margin-bottom:16px;display:flex;align-items:center;gap:8px}.card-heading i{color:var(--text-2);font-size:13px}.pill-list{display:flex;flex-direction:column;gap:13px}.pill-row{display:flex;align-items:center;gap:10px}.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.pill-label{flex:1;color:var(--text-2);font-size:13px}.pill-count{font-size:13px;font-weight:600;color:var(--text-1)}.team-list{display:flex;flex-direction:column;gap:11px}.team-row{display:flex;align-items:center;gap:10px}.team-info{display:flex;flex-direction:column}.team-name{font-size:13px;font-weight:500;color:var(--text-1)}.team-status{font-size:11px;color:var(--text-2);display:flex;align-items:center;gap:5px;margin-top:2px}.status-online{color:#22c55e;font-size:8px}.live-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}.live-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-1)}.live-title i{color:var(--accent)}.version{font-size:11px;color:var(--text-3);font-weight:400}.live-badges{display:flex;gap:7px;flex-wrap:wrap}.lbadge{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-2);background:var(--bg-card2);border:1px solid var(--border);border-radius:20px;padding:4px 11px}.lbadge.green{color:#22c55e;border-color:#22c55e4d;background:#22c55e14}.live-meta{display:flex;flex-wrap:wrap;gap:18px;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:16px;font-size:12.5px;color:var(--text-2)}.live-meta i{color:var(--text-3);margin-right:4px}.live-meta b{color:var(--text-1)}.warn{color:#f59e0b!important}.live-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:8px;overflow:hidden}.live-panel{background:var(--bg-card2);padding:14px 16px;display:flex;flex-direction:column;gap:10px}.live-panel-title{font-size:11px;font-weight:700;color:var(--text-3);letter-spacing:.6px;margin-bottom:4px}.live-row{display:flex;align-items:center;gap:9px}.live-row-info{flex:1;display:flex;flex-direction:column;min-width:0}.live-row-name{font-size:13px;font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.live-row-sub{font-size:11px;color:var(--text-2)}.live-empty{font-size:12.5px;color:var(--text-3)}.trunk-online{color:#22c55e;font-size:9px;flex-shrink:0}.trunk-offline{color:#ef4444;font-size:9px;flex-shrink:0}.badge-avail,.badge-online{font-size:11px;font-weight:600;color:#22c55e;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.badge-busy{font-size:11px;font-weight:600;color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.badge-status-busy{font-size:11px;font-weight:600;color:#fb923c;background:#fb923c1a;border:1px solid rgba(251,146,60,.25);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.badge-status-break{font-size:11px;font-weight:600;color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.badge-status-dnd{font-size:11px;font-weight:600;color:#a855f7;background:#a855f71a;border:1px solid rgba(168,85,247,.25);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.badge-idle{font-size:11px;font-weight:600;color:var(--text-2);background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.badge-offline{font-size:11px;font-weight:600;color:#ef4444;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:20px;padding:2px 9px;white-space:nowrap;flex-shrink:0}.fab{position:fixed;bottom:24px;right:24px;width:48px;height:48px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 16px #6366f173;transition:background .15s,transform .15s;z-index:100}.fab:hover{background:var(--accent-hov);transform:scale(1.08)}@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.mid-grid{grid-template-columns:1fr 1fr}.live-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:720px){.stats-grid{grid-template-columns:1fr 1fr}.mid-grid{grid-template-columns:1fr}.live-grid{grid-template-columns:1fr 1fr}.sidebar{display:none}.content{padding:16px 16px 60px}.topbar{padding:0 14px}.btn-new-ticket span{display:none}}
