@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap);@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#e0e7ff;--primary-gradient:linear-gradient(135deg,#667eea,#764ba2);--success:#10b981;--success-bg:#d1fae5;--success-text:#065f46;--warning:#f59e0b;--warning-bg:#fef3c7;--warning-text:#92400e;--danger:#ef4444;--danger-bg:#fee2e2;--danger-text:#991b1b;--info:#3b82f6;--info-bg:#dbeafe;--info-text:#1e40af;--white:#fff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--black:#000;--font-sans:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code","Courier New",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:clamp(1.25rem,3vw,1.5rem);--text-3xl:clamp(1.5rem,4vw,1.875rem);--text-4xl:clamp(1.75rem,5vw,2.25rem);--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-xs:0 1px 2px 0 #0000000a;--shadow-sm:0 1px 3px 0 #00000014,0 1px 2px -1px #0000000f;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000a;--shadow-2xl:0 25px 50px -12px #0000002e;--shadow-inner:inset 0 2px 4px 0 #0000000f;--z-below:-1;--z-base:0;--z-raised:10;--z-dropdown:200;--z-sticky:300;--z-overlay:400;--z-modal:500;--z-popover:600;--z-toast:700;--z-navbar:800;--z-sidebar:100;--navbar-height:60px;--sidebar-width:260px;--sidebar-collapsed-width:60px;--sidebar-tablet-width:220px;--content-max-width:1440px;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms cubic-bezier(0.4,0,0.2,1)}html{-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;background-color:var(--gray-50);color:#1e293b;color:var(--gray-800);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);line-height:1.6;min-height:100vh}code{font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-family:var(--font-mono);font-size:.9em}:focus-visible{border-radius:.25rem;border-radius:var(--radius-sm);outline:2px solid #6366f1;outline:2px solid var(--primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}img,svg,video{display:block;max-width:100%}a{color:#6366f1;color:var(--primary);text-decoration:none;transition:color .2s ease;transition:color var(--transition-base)}a:hover{color:#4f46e5;color:var(--primary-dark)}.container{padding:0 1rem;padding:0 var(--spacing-md)}.container,.page-wrapper{margin:0 auto;max-width:1440px;max-width:var(--content-max-width)}.page-wrapper{padding:2rem;padding:var(--spacing-xl)}@media (max-width:768px){.page-wrapper{padding:1rem;padding:var(--spacing-md)}}.btn{-webkit-tap-highlight-color:transparent;border:1px solid #0000;border-radius:.5rem;border-radius:var(--radius-md);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-size:var(--text-sm);gap:.5rem;line-height:1;min-height:44px;padding:.625rem 1.25rem;text-decoration:none;transition:all .2s ease;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:disabled,.btn[aria-disabled=true]{cursor:not-allowed;opacity:.5;pointer-events:none}.btn-primary{background:var(--primary-gradient);border-color:#0000;box-shadow:0 2px 8px #667eea59;color:var(--white)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea73}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--white);border-color:#cbd5e1;border-color:var(--gray-300);box-shadow:0 1px 2px 0 #0000000a;box-shadow:var(--shadow-xs);color:#334155;color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:#94a3b8;border-color:var(--gray-400);color:#1e293b;color:var(--gray-800)}.btn-danger{background:var(--danger);border-color:#0000;color:var(--white)}.btn-danger:hover:not(:disabled){transform:translateY(-1px)}.btn-ghost{background:#0000;border-color:#0000;color:#475569;color:var(--gray-600)}.btn-ghost:hover:not(:disabled){background:#f1f5f9;background:var(--gray-100);color:#1e293b;color:var(--gray-800)}.btn-sm{border-radius:.25rem;border-radius:var(--radius-sm);font-size:.75rem;font-size:var(--text-xs);min-height:36px;padding:.375rem .875rem}.btn-lg{font-size:1rem;font-size:var(--text-base);min-height:52px;padding:.875rem 1.75rem}.btn-icon{border-radius:.5rem;border-radius:var(--radius-md);min-height:44px;min-width:44px;padding:0}.btn-icon.btn-sm{min-height:36px;min-width:36px}.card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #00000014,0 1px 2px -1px #0000000f;box-shadow:var(--shadow-sm);padding:1.5rem;padding:var(--spacing-lg)}.card-sm{padding:1rem;padding:var(--spacing-md)}.card-lg{padding:2rem;padding:var(--spacing-xl)}.badge{border-radius:9999px;border-radius:var(--radius-full);font-size:.75rem;font-size:var(--text-xs);gap:.25rem;letter-spacing:.02em;padding:.25rem .625rem;white-space:nowrap}.badge-success{background:#d1fae5;background:var(--success-bg);color:#065f46;color:var(--success-text)}.badge-warning{background:#fef3c7;background:var(--warning-bg);color:#92400e;color:var(--warning-text)}.badge-danger{background:#fee2e2;background:var(--danger-bg);color:#991b1b;color:var(--danger-text)}.badge-info{background:var(--info-bg);color:var(--info-text)}.badge-gray{background:#f1f5f9;background:var(--gray-100);color:#475569;color:var(--gray-600)}.badge-primary{background:#e0e7ff;background:var(--primary-light);color:#4f46e5;color:var(--primary-dark)}.form-group{margin-bottom:1rem;margin-bottom:var(--spacing-md)}.form-label{color:#334155;color:var(--gray-700);display:block;font-size:.875rem;font-size:var(--text-sm);font-weight:600;margin-bottom:.375rem}.form-label .required{color:#ef4444;color:var(--danger);margin-left:.125rem}.form-input,.form-select,.form-textarea{appearance:none;-webkit-appearance:none;background:#fff;background:var(--white);border:1px solid #cbd5e1;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-md);color:#1e293b;color:var(--gray-800);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-size:.875rem;font-size:var(--text-sm);min-height:44px;padding:.625rem .875rem;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition-base),box-shadow var(--transition-base);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#6366f1;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11f;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8;color:var(--gray-400)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:#f8fafc;background:var(--gray-50);color:#94a3b8;color:var(--gray-400);cursor:not-allowed}.form-input.error,.form-select.error,.form-textarea.error{border-color:#ef4444;border-color:var(--danger);box-shadow:0 0 0 3px #ef44441a}.form-error{align-items:center;color:#ef4444;color:var(--danger);display:flex;gap:.25rem}.form-error,.form-hint{font-size:.75rem;font-size:var(--text-xs);margin-top:.25rem}.form-hint{color:#64748b;color:var(--gray-500);line-height:1.4}.table-wrap{-webkit-overflow-scrolling:touch;border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);overflow-x:auto;width:100%}.table-wrap:after{content:"";display:none}@media (max-width:768px){.table-wrap{border-radius:.5rem;border-radius:var(--radius-md)}}.table{border-collapse:collapse;font-size:.875rem;font-size:var(--text-sm);width:100%}.table th{background:#f8fafc;background:var(--gray-50);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);color:#64748b;color:var(--gray-500);font-size:.75rem;font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);color:#334155;color:var(--gray-700);padding:.875rem 1rem;vertical-align:middle}.table tbody tr{transition:background .15s ease;transition:background var(--transition-fast)}.table tbody tr:hover{background:#f8fafc;background:var(--gray-50)}.table tbody tr:last-child td{border-bottom:none}.alert{align-items:flex-start;border:1px solid #0000;border-radius:.5rem;border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.5;padding:.875rem 1rem}.alert-success{background:#d1fae5;background:var(--success-bg);border-color:#a7f3d0;color:#065f46;color:var(--success-text)}.alert-warning{background:var(--warning-bg);border-color:#fde68a;color:var(--warning-text)}.alert-danger{background:#fee2e2;background:var(--danger-bg);border-color:#fecaca;color:#991b1b;color:var(--danger-text)}.alert-info{background:var(--info-bg);border-color:#bfdbfe;color:var(--info-text)}.modal-overlay{animation:fadeIn ease .2s ease;animation:fadeIn var(--transition-base) ease;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);background:#0f172a8c;inset:0;padding:1rem;padding:var(--spacing-md);z-index:500;z-index:var(--z-modal)}.modal-box{animation:slideUp .3s cubic-bezier(.4,0,.2,1);animation:slideUp var(--transition-slow);background:#fff;background:var(--white);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #0000002e;box-shadow:var(--shadow-2xl);max-height:calc(100vh - 2rem);max-height:calc(100vh - var(--spacing-md)*2);max-width:560px;overflow-y:auto;width:100%}.modal-box-sm{max-width:400px}.modal-box-lg{max-width:720px}.modal-box-xl{max-width:900px}.spinner{animation:spin .7s linear infinite;border:2px solid #e2e8f0;border-top-color:#6366f1;border:2px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary);display:inline-block;height:1.5rem;width:1.5rem}.spinner-sm{height:1rem;width:1rem}.spinner-lg{border-width:3px;height:2.5rem;width:2.5rem}.loading-center{align-items:center;color:#64748b;color:var(--gray-500);display:flex;flex-direction:column;font-size:.875rem;font-size:var(--text-sm);gap:.75rem;justify-content:center;padding:3rem;padding:var(--spacing-2xl)}.empty-state{color:#94a3b8;color:var(--gray-400);gap:.75rem;padding:3rem 2rem;padding:var(--spacing-2xl) var(--spacing-xl)}.empty-state p{font-size:.875rem;font-size:var(--text-sm);line-height:1.5;max-width:32ch}.page-header{flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.page-header-left{align-items:center;display:flex;gap:.75rem;min-width:0}.page-title{color:#0f172a;color:var(--gray-900);font-size:clamp(1.75rem,5vw,2.25rem);font-size:var(--text-4xl);font-weight:800;letter-spacing:-.02em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-subtitle{color:#64748b;color:var(--gray-500);font-size:.875rem;font-size:var(--text-sm);margin-top:.125rem}@media (max-width:640px){.page-header{align-items:flex-start;flex-direction:column}.page-header-left{width:100%}}.status-chip{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-size:var(--text-xs);font-weight:600;gap:.25rem;padding:.25rem .75rem;white-space:nowrap}.status-chip:before{background:currentColor;border-radius:50%;content:"";flex-shrink:0;height:6px;width:6px}.status-pending{background:#fef3c7;background:var(--warning-bg);color:#92400e;color:var(--warning-text)}.status-approved{background:#d1fae5;background:var(--success-bg);color:#065f46;color:var(--success-text)}.status-rejected{background:#fee2e2;background:var(--danger-bg);color:#991b1b;color:var(--danger-text)}.status-cancelled{color:#64748b;color:var(--gray-500)}.status-cancelled,.status-draft{background:#f1f5f9;background:var(--gray-100)}.status-draft{color:#475569;color:var(--gray-600)}.status-submitted{background:#dbeafe;background:var(--info-bg);color:#1e40af;color:var(--info-text)}.status-processing{background:#fef3c7;color:#b45309}.status-finalized{background:#e0e7ff;background:var(--primary-light);color:#4f46e5;color:var(--primary-dark)}.status-active{background:#d1fae5;background:var(--success-bg);color:#065f46;color:var(--success-text)}.status-inactive{background:#f1f5f9;background:var(--gray-100);color:#64748b;color:var(--gray-500)}.divider{background:#e2e8f0;background:var(--gray-200);border:none;height:1px;margin:1.5rem 0;margin:var(--spacing-lg) 0}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--gray-400)}@keyframes spin{to{transform:rotate(1turn)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){.btn,.form-input,.form-select,.form-textarea{border-width:2px}}@media (max-width:640px){.hide-mobile{display:none!important}}@media (min-width:641px){.show-mobile-only{display:none!important}}@media (max-width:1024px){.hide-tablet{display:none!important}}.code-input-group{gap:0}.code-input-group .code-input{border-bottom-right-radius:0!important;border-right:none!important;border-top-right-radius:0!important;flex:1 1;font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-family:var(--font-mono,"JetBrains Mono",monospace);letter-spacing:.05em}.code-input-group .code-input:focus{border-right:none!important;position:relative;z-index:1}.btn-generate{background:#f8f9ff;border:1px solid #d1d5db;border-bottom-left-radius:0;border-bottom-right-radius:8px;border-left-color:#e5e7eb;border-top-left-radius:0;border-top-right-radius:8px;color:#667eea;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans,"Plus Jakarta Sans",sans-serif);gap:5px;padding:0 14px;transition:all .18s ease}.btn-generate:hover{background:#667eea;border-color:#667eea}.btn-generate:hover svg{animation:spin-once .35s ease}.btn-generate:active{transform:scale(.97)}.btn-generate:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.45}@keyframes spin-once{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-container{max-width:420px;padding:var(--spacing-md);width:100%}.login-card{padding:var(--spacing-2xl)}.login-header{margin-bottom:var(--spacing-xl);text-align:center}.login-header h1{color:var(--gray-900);font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:var(--gray-600);font-size:.875rem}.login-form{margin-bottom:var(--spacing-lg)}.login-footer{border-top:1px solid var(--gray-200);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.demo-credentials{background-color:var(--gray-50);border-radius:var(--radius-md);color:var(--gray-600);font-size:.75rem;line-height:1.6;margin-bottom:.5rem;padding:var(--spacing-md);text-align:center}.allowed-domains{color:var(--gray-500);font-size:.625rem;margin-top:.5rem;text-align:center}.navbar{align-items:center;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);background:#ffffffeb;border-bottom:1px solid #6366f114;box-shadow:0 1px 0 #6366f10f,0 4px 16px -4px #0000000f;display:flex;gap:1rem;height:var(--navbar-height);justify-content:space-between;left:0;padding:0 1.25rem;position:fixed;right:0;top:0;z-index:var(--z-navbar)}.navbar-accent{background:linear-gradient(90deg,#667eea,#764ba2 45%,#6366f1);height:2px;left:0;pointer-events:none;position:absolute;right:0;top:0}.navbar-left{gap:.625rem}.navbar-hamburger,.navbar-left{align-items:center;display:flex;flex-shrink:0}.navbar-hamburger{-webkit-tap-highlight-color:transparent;background:#0000;border:none;border-radius:8px;color:var(--gray-500);cursor:pointer;height:36px;justify-content:center;transition:background .15s,color .15s;width:36px}.navbar-hamburger:hover{background:var(--gray-100);color:var(--gray-800)}.navbar-brand{gap:.5rem;text-decoration:none;-webkit-user-select:none;user-select:none}.brand-mark,.navbar-brand{align-items:center;display:flex}.brand-mark{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 2px 8px #667eea59;flex-shrink:0;height:32px;justify-content:center;width:32px}.brand-q{color:#fff;font-size:.875rem;font-weight:800;letter-spacing:-.03em;line-height:1}.brand-text{display:flex;flex-direction:column;gap:0;line-height:1}.brand-name{color:var(--gray-900);font-size:.9375rem;font-weight:800;letter-spacing:-.03em;line-height:1.1}.brand-sub{color:var(--gray-400);font-size:.625rem;font-weight:500;letter-spacing:.06em;line-height:1.2;text-transform:uppercase}.navbar-right{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.nb-divider{background:var(--gray-200);flex-shrink:0;height:20px;margin:0 .25rem;width:1px}.nb-bell-btn,.nb-bell-wrap{position:relative}.nb-bell-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:8px;color:var(--gray-500);cursor:pointer;display:flex;height:36px;justify-content:center;transition:background .15s,color .15s;width:36px}.nb-bell-active,.nb-bell-btn:hover{background:#6366f114;color:#6366f1}.nb-badge{align-items:center;border:1.5px solid #fff;border-radius:8px;display:flex;font-size:9px;font-weight:700;height:15px;justify-content:center;line-height:1;min-width:15px;padding:0 3px;position:absolute;right:5px;top:5px}.nb-badge-high{background:#ef4444;color:#fff}.nb-badge-normal{background:#6366f1;color:#fff}.nb-dropdown{animation:nb-drop-in .18s ease;background:#fff;border:1px solid #6366f11a;border-radius:14px;box-shadow:0 12px 40px -8px #00000029,0 0 0 1px #6366f10a;overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:340px;z-index:var(--z-popover)}@keyframes nb-drop-in{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.nb-dropdown-header{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;gap:8px;padding:14px 16px}.nb-dropdown-title{color:var(--gray-800);font-size:.8125rem;font-weight:700;letter-spacing:-.01em}.nb-count-chip{background:#6366f1;border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:1px 6px}.nb-close{align-items:center;background:none;border:none;border-radius:4px;color:var(--gray-400);cursor:pointer;display:flex;margin-left:auto;padding:2px;transition:color .12s,background .12s}.nb-close:hover{background:var(--gray-100);color:var(--gray-700)}.nb-empty{color:var(--gray-400);font-size:.8125rem;padding:32px 16px;text-align:center}.nb-empty-icon{display:block;margin:0 auto 8px;opacity:.35}.nb-list{max-height:380px;overflow-y:auto}.nb-item{border-bottom:1px solid var(--gray-50);display:flex;gap:10px;padding:12px 16px;transition:background .1s}.nb-item:last-child{border-bottom:none}.nb-item:hover{background:var(--gray-50)}.nb-item-high{border-left:3px solid #ef4444}.nb-item-medium{border-left:3px solid #f59e0b}.nb-item-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:28px;justify-content:center;margin-top:2px;width:28px}.nb-icon-subscription{background:#6366f11a;color:#6366f1}.nb-icon-invoice{background:#ef44441a;color:#ef4444}.nb-icon-task{background:#10b9811a;color:#10b981}.nb-item-body{flex:1 1;min-width:0}.nb-item-title{color:var(--gray-600);font-size:.6875rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.nb-item-msg{color:var(--gray-800);font-size:.8125rem;line-height:1.4;margin-top:2px}.nb-item-date{color:var(--gray-400);font-size:.6875rem;margin-top:4px}.nb-user-chip{-webkit-tap-highlight-color:transparent;align-items:center;border-radius:10px;cursor:pointer;display:flex;gap:.5rem;padding:.3125rem .625rem .3125rem .3125rem;position:relative;transition:background .15s;-webkit-user-select:none;user-select:none}.nb-user-chip:hover{background:#6366f10f}.nb-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 6px #667eea59;color:#fff;display:flex;flex-shrink:0;font-size:.6875rem;font-weight:700;height:32px;justify-content:center;letter-spacing:.03em;width:32px}.nb-user-info{align-items:flex-start;display:flex;flex-direction:column;gap:2px;min-width:0}.nb-user-name{color:var(--gray-800);font-size:.8125rem;font-weight:600;letter-spacing:-.01em;line-height:1.1;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nb-role-pill{border-radius:4px;font-size:.5625rem;font-weight:700;letter-spacing:.07em;line-height:1.5;padding:1px 6px;text-transform:uppercase;white-space:nowrap}.nb-role-admin{background:#6366f11a;color:#4f46e5}.nb-role-manager{background:#10b9811a;color:#059669}.nb-role-accounts{background:#f59e0b1a;color:#d97706}.nb-role-employee{background:#64748b1a;color:#475569}.nb-chevron{color:var(--gray-400);flex-shrink:0;transition:transform .2s ease,color .15s}.nb-chevron-open{color:#6366f1;transform:rotate(180deg)}.nb-user-menu{animation:nb-drop-in .18s ease;background:#fff;border:1px solid #6366f11a;border-radius:14px;box-shadow:0 12px 40px -8px #00000029,0 0 0 1px #6366f10a;overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:220px;z-index:var(--z-popover)}.nb-user-menu-header{align-items:center;display:flex;gap:10px;padding:14px 14px 12px}.nb-user-menu-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:36px;justify-content:center;letter-spacing:.03em;width:36px}.nb-user-menu-name{color:var(--gray-900);font-size:.8125rem;font-weight:700;letter-spacing:-.01em}.nb-user-menu-email,.nb-user-menu-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nb-user-menu-email{color:var(--gray-400);font-size:.6875rem;margin-top:1px}.nb-user-menu-divider{background:var(--gray-100);height:1px;margin:0}.nb-user-menu-item{align-items:center;background:#0000;border:none;color:var(--gray-700);cursor:pointer;display:flex;font-family:inherit;font-size:.8125rem;font-weight:500;gap:8px;padding:10px 14px;text-align:left;transition:background .12s,color .12s;width:100%}.nb-user-menu-item:hover{background:var(--gray-50);color:var(--gray-900)}.nb-user-menu-logout{color:#ef4444}.nb-user-menu-logout:hover{background:#ef44440d;color:#dc2626}.hide-mobile{display:flex}@media (max-width:768px){.navbar{padding:0 1rem}}@media (max-width:560px){.hide-mobile{display:none!important}.nb-user-chip{padding:.3125rem}.nb-chevron{display:none}.nb-user-menu{right:-8px;width:200px}.nb-dropdown{right:-8px;width:calc(100vw - 24px)}}@media (max-width:400px){.brand-text{display:none}}@media (prefers-reduced-motion:reduce){.nb-dropdown,.nb-user-menu{animation:none}.nb-chevron{transition:none}}.sidebar{background:#f8fafc;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;height:calc(100vh - var(--navbar-height));left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:var(--navbar-height);transition:width var(--transition-slow),transform var(--transition-slow);z-index:var(--z-sidebar)}.sidebar-expanded{width:var(--sidebar-width)}.sidebar-collapsed{width:var(--sidebar-collapsed-width)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.sidebar-toggle{align-items:center;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);color:var(--gray-500);cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;position:absolute;right:12px;top:12px;transition:all var(--transition-base);width:32px;z-index:10}.sidebar-toggle:hover{background:var(--gray-100);border-color:var(--gray-300);color:var(--gray-800)}.sidebar-collapsed .sidebar-toggle{right:50%;transform:translateX(50%)}.sidebar-nav{flex:1 1;padding:52px var(--spacing-sm) var(--spacing-md)}.sidebar-section{animation:slideIn var(--transition-slow) ease-out;margin-bottom:20px}.sidebar-section:first-child{margin-bottom:28px}.sidebar-section-title{color:var(--gray-400);font-size:10px;font-weight:700;letter-spacing:.06em;margin-bottom:4px;padding:6px 10px;text-transform:uppercase;-webkit-user-select:none;user-select:none}.sidebar-collapsed .sidebar-section-title{height:0;margin:0;opacity:0;overflow:hidden;padding:0}.sidebar-section-items{display:flex;flex-direction:column;gap:2px}.sidebar-link{align-items:center;border-radius:var(--radius-md);color:var(--gray-600);display:flex;font-size:var(--text-sm);font-weight:500;min-height:40px;overflow:hidden;padding:9px 10px;position:relative;text-decoration:none;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.sidebar-link:hover{background:var(--gray-200);color:var(--gray-900)}.sidebar-link:active{transform:scale(.98)}.sidebar-link-disabled{cursor:not-allowed;opacity:.45;pointer-events:none}.sidebar-link-active{background:linear-gradient(135deg,#667eea,#764ba2)!important;box-shadow:0 2px 8px #667eea4d;color:var(--white)!important;font-weight:600}.sidebar-link-active:hover{background:linear-gradient(135deg,#5568d3,#64368a)!important}.sidebar-icon{align-items:center;color:currentColor;display:flex;flex-shrink:0;justify-content:center;min-width:20px;transition:transform var(--transition-fast)}.sidebar-link:hover .sidebar-icon{transform:scale(1.07)}.sidebar-label{flex:1 1;margin-left:10px;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--transition-base),width var(--transition-base)}.sidebar-collapsed .sidebar-label{margin:0;opacity:0;width:0}.sidebar-parent{cursor:pointer}.sidebar-chevron{color:var(--gray-400);flex-shrink:0;margin-left:auto;transition:transform var(--transition-base),color var(--transition-fast)}.sidebar-parent:hover .sidebar-chevron{color:var(--gray-600)}.sidebar-menu-group,.sidebar-submenu{display:flex;flex-direction:column}.sidebar-submenu{border-left:2px solid var(--gray-200);gap:1px;margin:2px 0 4px 21px;padding-left:16px}.sidebar-sublink{border-radius:var(--radius-sm);color:var(--gray-500);font-size:var(--text-xs);padding:7px 10px}.sidebar-sublink .sidebar-icon{min-width:18px}.sidebar-sublink:hover{background:var(--gray-200);color:var(--gray-900)}.sidebar-sublink.sidebar-link-active{background:linear-gradient(135deg,#667eea,#764ba2)!important;box-shadow:0 2px 6px #667eea40;color:var(--white)!important;font-weight:600}.sidebar-collapsed .sidebar-link{justify-content:center;padding:9px}.sidebar-collapsed .sidebar-icon{margin:0}.sidebar-collapsed .sidebar-link:after{background:var(--gray-900);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);color:var(--white);content:attr(title);font-size:var(--text-xs);left:calc(100% + 12px);opacity:0;padding:5px 10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:opacity var(--transition-base);white-space:nowrap;z-index:var(--z-popover)}.sidebar-collapsed .sidebar-link:hover:after{opacity:1}@media (max-width:1024px) and (min-width:769px){.sidebar-expanded{width:var(--sidebar-tablet-width)}.sidebar-collapsed{width:var(--sidebar-collapsed-width)}}@media (max-width:768px){.sidebar{box-shadow:none;transform:translateX(-100%);transition:transform var(--transition-slow);width:var(--sidebar-width)!important}.sidebar-expanded{box-shadow:var(--shadow-xl);transform:translateX(0)}.sidebar-collapsed{transform:translateX(-100%)}.sidebar-toggle{display:none}}.sidebar-link:focus-visible,.sidebar-toggle:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media (prefers-contrast:high){.sidebar{border-right:2px solid #000}.sidebar-link-active{background:#000!important;color:#fff!important}}@media (prefers-reduced-motion:reduce){.sidebar,.sidebar-icon,.sidebar-label,.sidebar-link,.sidebar-section,.sidebar-toggle{animation:none!important;transition:none!important}}.dashboard-layout{background-color:var(--gray-50);min-height:100vh}.dashboard-container{display:flex;padding-top:var(--navbar-height)}.dashboard-content{flex:1 1;min-height:calc(100vh - var(--navbar-height));min-width:0;padding:var(--spacing-xl);transition:margin-left var(--transition-slow)}.content-expanded{margin-left:var(--sidebar-width)}.content-collapsed{margin-left:var(--sidebar-collapsed-width)}.content-mobile{margin-left:0}@media (max-width:1024px) and (min-width:769px){.content-expanded{margin-left:var(--sidebar-tablet-width)}}@media (max-width:768px){.dashboard-content{margin-left:0!important;padding:var(--spacing-md)}}@media (min-width:1600px){.dashboard-content{max-width:calc(var(--content-max-width) + var(--sidebar-width))}}.sidebar-backdrop{animation:fadeIn var(--transition-base) ease;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);background:#0f172a73;cursor:pointer;inset:var(--navbar-height) 0 0 0;position:fixed;z-index:calc(var(--z-sidebar) - 1)}.db-page{max-width:1300px;padding:24px}.db-welcome{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.db-greeting{color:var(--gray-900);font-size:var(--text-2xl);font-weight:700;margin:0 0 4px}.db-subtitle{color:var(--gray-500);font-size:var(--text-sm);margin:0}.db-grid-4{grid-gap:14px;gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.db-grid-2,.db-grid-4{display:grid;margin-bottom:20px}.db-grid-2{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:900px){.db-grid-2{grid-template-columns:1fr}}@media (max-width:600px){.db-grid-4{grid-template-columns:1fr 1fr}}.db-stat-card{align-items:center;background:#fff;border:1px solid var(--gray-200);border-left:4px solid #0000;border-radius:12px;display:flex;gap:14px;padding:16px 18px}.db-stat-primary{border-left-color:#6366f1}.db-stat-primary .db-stat-icon{background:#6366f11a;color:#6366f1}.db-stat-success{border-left-color:#10b981}.db-stat-success .db-stat-icon{background:#10b9811a;color:#10b981}.db-stat-warning{border-left-color:#f59e0b}.db-stat-warning .db-stat-icon{background:#f59e0b1a;color:#f59e0b}.db-stat-info{border-left-color:#3b82f6}.db-stat-info .db-stat-icon{background:#3b82f61a;color:#3b82f6}.db-stat-danger{border-left-color:#ef4444}.db-stat-danger .db-stat-icon{background:#ef44441a;color:#ef4444}.db-stat-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.db-stat-body{display:flex;flex-direction:column;gap:2px;min-width:0}.db-stat-label{color:var(--gray-500);font-size:var(--text-xs);font-weight:500;letter-spacing:.4px;text-transform:uppercase}.db-stat-value{color:var(--gray-900);font-size:var(--text-xl);font-weight:700;line-height:1.2}.db-stat-sub{color:var(--gray-400);font-size:var(--text-xs)}.db-card{background:#fff;border:1px solid var(--gray-200);border-radius:12px;margin-bottom:0;padding:20px}.db-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.db-card-title{color:var(--gray-800);font-size:var(--text-base);font-weight:600;margin:0 0 16px}.db-card-subtitle{color:var(--gray-400);font-size:var(--text-xs)}.db-empty{color:var(--gray-400);font-size:var(--text-sm);padding:20px 0;text-align:center}.db-list{display:flex;flex-direction:column;gap:10px}.db-list-row{align-items:center;border-bottom:1px solid var(--gray-50);display:flex;gap:10px;padding:8px 0}.db-list-row:last-child{border-bottom:none}.db-list-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.db-list-body{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.db-list-name{color:var(--gray-800);font-size:var(--text-sm);font-weight:500}.db-list-sub{color:var(--gray-500);font-size:var(--text-xs)}.db-list-right{align-items:flex-end;display:flex;flex-direction:column;gap:3px}.db-list-amount{color:var(--gray-800);font-size:var(--text-sm);font-weight:600}.db-project-list{display:flex;flex-direction:column;gap:8px}.db-project-row{align-items:center;background:var(--gray-50);border-radius:8px;display:flex;gap:8px;padding:8px}.db-project-icon{color:var(--gray-400);flex-shrink:0}.db-project-row span:nth-child(2){color:var(--gray-800);flex:1 1;font-size:var(--text-sm)}.db-leave-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.db-leave-chip{background:var(--gray-50);border-radius:8px;display:flex;flex-direction:column;gap:2px;padding:8px 12px}.db-leave-name{color:var(--gray-500);font-size:var(--text-xs);font-weight:500}.db-leave-val{color:var(--primary);font-size:var(--text-base);font-weight:700}.db-task-summary{display:flex;flex-direction:column;gap:12px}.db-task-row{align-items:center;display:flex;gap:10px}.db-task-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.db-task-label{color:var(--gray-700);font-size:var(--text-sm);width:90px}.db-task-val{color:var(--gray-800);font-size:var(--text-sm);font-weight:600;width:30px}.db-task-bar-wrap{background:var(--gray-100);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.db-task-bar{border-radius:4px;height:100%;transition:width .3s}.db-workload-wrap{align-items:center;display:flex;gap:8px}.db-workload-bar{background:var(--gray-100);border-radius:4px;height:8px;overflow:hidden;width:80px}.db-workload-fill{border-radius:4px;height:100%}.db-workload-pct{color:var(--gray-500);font-size:var(--text-xs);width:28px}.db-quick-actions{margin-top:8px}.db-section-title{color:var(--gray-800);font-size:var(--text-base);font-weight:600;margin-bottom:12px}.db-quick-actions-inline{display:flex;flex-wrap:wrap;gap:8px}.db-actions-row{display:flex;flex-wrap:wrap;gap:10px}.db-qa-btn{align-items:center;background:#fff;border:1.5px solid var(--gray-200);border-radius:10px;color:var(--gray-700);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:500;gap:8px;min-height:44px;padding:10px 18px;transition:border-color .15s,color .15s,background .15s,transform .1s}.db-qa-btn:hover{background:#6366f10a;border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.db-qa-small{font-size:var(--text-xs);padding:7px 12px}.db-card{margin-bottom:20px}.modal-overlay{animation:fadeIn .2s ease-in;background-color:#00000080}.delete-confirmation-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:500px;width:90%}.modal-title-section{align-items:center;display:flex;gap:12px}.modal-title-section h2{color:#111827;font-size:1.25rem;font-weight:600;margin:0}.warning-icon{color:#ef4444}.close-button{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:color .2s}.close-button:hover{color:#111827}.warning-message{color:#374151;line-height:1.5;margin-bottom:16px}.item-info{background-color:#fef3c7;border:1px solid #fbbf24;border-radius:6px;color:#78350f;font-size:.9rem;margin-bottom:20px;padding:12px}.item-info strong{font-weight:600}.confirmation-input-section{margin-top:20px}.confirmation-input-section label{color:#374151;display:block;font-size:.95rem;margin-bottom:8px}.confirmation-input-section label strong{color:#ef4444;font-weight:600}.confirmation-input{border:2px solid #d1d5db;border-radius:6px;font-size:1rem;padding:10px 12px;transition:border-color .2s;width:100%}.confirmation-input:focus{border-color:#ef4444;outline:none}.modal-actions .btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.modal-actions .btn-secondary{background-color:#f3f4f6;color:#374151}.modal-actions .btn-secondary:hover{background-color:#e5e7eb}.modal-actions .btn-danger{background-color:#ef4444;color:#fff}.modal-actions .btn-danger:hover:not(:disabled){background-color:#dc2626}.modal-actions .btn-danger:disabled{background-color:#fca5a5;cursor:not-allowed;opacity:.6}.om-page{margin:0 auto;max-width:1400px;padding:2rem}.om-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.om-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.om-breadcrumb-parent{color:#64748b}.om-breadcrumb-sep{color:#94a3b8;margin:0 .1rem}.om-breadcrumb-active{color:#6366f1;font-weight:500}.om-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.om-subtitle{color:#64748b;margin:0}.om-add-btn,.om-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.om-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;outline:none;padding:.75rem 1.5rem;text-decoration:none;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.om-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.om-add-btn:active{transform:translateY(0)}.om-alert{align-items:center;border-radius:10px;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1.25rem;padding:.875rem 1.125rem}.om-alert--error{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #dc2626;color:#991b1b}.om-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;border-left:4px solid #16a34a;color:#166534}.om-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:2rem}.om-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000f;gap:1rem;padding:1rem 1.25rem}.om-stat,.om-stat-icon{align-items:center;display:flex}.om-stat-icon{border-radius:.5rem;flex-shrink:0;justify-content:center;padding:.75rem}.om-stat-icon--blue{background:#dbeafe;color:#2563eb}.om-stat-icon--green{background:#dcfce7;color:#16a34a}.om-stat-icon--yellow{background:#fef9c3;color:#ca8a04}.om-stat-icon--red{background:#fee2e2;color:#dc2626}.om-stat-label{color:#64748b;font-size:.65rem;font-weight:700;letter-spacing:.08em;margin:0 0 .2rem;text-transform:uppercase}.om-stat-label,.om-stat-value{font-family:Plus Jakarta Sans,sans-serif}.om-stat-value{color:#0f172a;font-size:1.375rem;font-weight:800;line-height:1;margin:0}.om-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000d;overflow:hidden}.om-toolbar{border-bottom:1px solid #e2e8f0;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.25rem}.om-filters,.om-toolbar{align-items:center;display:flex}.om-filters{gap:.25rem}.om-filter-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#0000;border:none;border-radius:.5rem;box-shadow:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;line-height:1.5;outline:none;padding:.4375rem 1rem;text-decoration:none;transition:background .12s,color .12s}.om-filter-btn:hover{background:#f8fafc;color:#1e293b}.om-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.om-toolbar-right{align-items:center;display:flex;gap:.5rem}.om-action-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;gap:.375rem;line-height:1.5;outline:none;padding:.4375rem .875rem;text-decoration:none;transition:background .12s,border-color .12s}.om-action-btn:hover{background:#f8fafc;border-color:#cbd5e1}.om-table-wrap{overflow-x:auto}.om-table{border-collapse:collapse;text-align:left;width:100%}.om-table thead tr{background:#f8fafc}.om-table th{color:#64748b;font-size:.7rem;font-weight:700;letter-spacing:.07em;padding:.875rem 1.5rem;text-transform:uppercase;white-space:nowrap}.om-table td,.om-table th{font-family:Plus Jakarta Sans,sans-serif}.om-table td{border-bottom:1px solid #f1f5f9;color:#475569;font-size:.875rem;padding:1.125rem 1.5rem;vertical-align:middle}.om-table tbody tr:last-child td{border-bottom:none}.om-table tbody tr{cursor:pointer;transition:background .1s}.om-table tbody tr:hover{background:#f8fafc}.om-org-cell{gap:.75rem}.om-avatar,.om-org-cell{align-items:center;display:flex}.om-avatar{border-radius:.75rem;flex-shrink:0;font-size:1rem;font-weight:800;height:40px;justify-content:center;line-height:1;width:40px}.om-avatar,.om-org-name{font-family:Plus Jakarta Sans,sans-serif}.om-org-name{color:#0f172a;font-size:.9rem;font-weight:700;line-height:1.3;margin:0}.om-org-sub{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;margin:.125rem 0 0}.om-code{background:#f1f5f9;border-radius:.25rem;color:#475569;display:inline-block;font-family:JetBrains Mono,Courier New,monospace;font-size:.8125rem;font-weight:500;padding:.2rem .5rem;white-space:nowrap}.om-muted{color:#64748b;font-size:.875rem}.om-dash{color:#cbd5e1}.om-status{align-items:center;border-radius:9999px;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;gap:.375rem;padding:.2rem .75rem;white-space:nowrap}.om-status:before{background:currentColor;border-radius:50%;content:"";display:inline-block;flex-shrink:0;height:6px;width:6px}.om-status--active{background:#dcfce7;color:#15803d}.om-status--inactive{background:#f1f5f9;color:#64748b}.om-row-actions{align-items:center;display:flex;gap:.25rem;justify-content:flex-end}.om-delete-btn,.om-edit-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#0000;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;justify-content:center;outline:none;padding:.4rem;transition:background .12s,color .12s}.om-edit-btn{color:#64748b}.om-delete-btn{color:#f87171}.om-edit-btn:hover{background:#e2e8f0;color:#334155}.om-delete-btn:hover{background:#fee2e2;color:#dc2626}.om-empty{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;padding:4rem 1rem;text-align:center}.om-footer{align-items:center;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.25rem 1.5rem}.om-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;margin:0}.om-count strong{color:#0f172a;font-weight:600}.om-pagination{align-items:center;display:flex;gap:.375rem}.om-page-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#374151;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;justify-content:center;min-width:2.25rem;outline:none;padding:.4375rem .875rem;text-align:center;text-decoration:none;transition:background .12s}.om-page-btn:hover:not(:disabled){background:#f8fafc}.om-page-btn:disabled{cursor:not-allowed;opacity:.45}.om-page-btn--active{background:#6366f1;border-color:#6366f1;box-shadow:0 1px 4px #6366f159;color:#fff;font-weight:700}.om-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;padding:4rem 1.5rem!important;text-align:center}@keyframes om-fade-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes om-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes od-pulse{0%,to{opacity:1}50%{opacity:.35}}.od-page{animation:om-fade-in .22s ease-out;margin:0 auto;max-width:1400px;padding:0}.od-back-btn{align-items:center;-webkit-appearance:none;appearance:none;background:none;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.25rem;margin-bottom:1.5rem;padding:0;transition:color .15s}.od-back-btn:hover{color:#7c3aed}.od-back-btn svg{transition:transform .15s}.od-back-btn:hover svg{transform:translateX(-3px)}.od-alert{align-items:center;animation:om-slide-down .22s ease-out;border-radius:10px;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1.25rem;padding:.875rem 1.125rem}.od-alert--error{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #dc2626;color:#991b1b}.od-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;border-left:4px solid #16a34a;color:#166534}.od-header-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 1px 3px #0000000f;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem}.od-header-left{gap:1.25rem}.od-header-left,.od-org-icon{align-items:center;display:flex}.od-org-icon{background:#ede9fe;border-radius:1rem;color:#7c3aed;flex-shrink:0;height:5rem;justify-content:center;width:5rem}.od-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.25rem}.od-org-name{color:#0f172a;font-size:1.5rem;margin:0}.od-active-badge,.od-org-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:700}.od-active-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.7rem;gap:.375rem;letter-spacing:.06em;padding:.25rem .625rem}.od-active-badge--active{background:#d1fae5;color:#065f46}.od-active-badge--inactive{background:#f1f5f9;color:#64748b}.od-badge-dot{background:currentColor;border-radius:50%;display:inline-block;flex-shrink:0;height:6px;width:6px}.od-active-badge--active .od-badge-dot{animation:od-pulse 2s ease-in-out infinite}.od-meta{align-items:center;display:flex;gap:1rem;margin-top:.25rem}.od-meta-item{align-items:center;color:#64748b;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.3rem}.od-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.od-analytics-btn{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:background .15s}.od-analytics-btn:hover{background:#f8fafc}.od-edit-org-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#7c3aed;border:none;border-radius:.5rem;box-shadow:0 4px 6px -1px #7c3aed40;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s}.od-edit-org-btn:hover{background:#6d28d9}.od-content-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 1px 3px #0000000f;overflow:hidden}.od-tabs-nav{border-bottom:1px solid #e2e8f0;display:flex;overflow-x:auto;padding:0 2rem}.od-tab{-webkit-appearance:none;appearance:none;background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;margin-bottom:-1px;outline:none;padding:1rem 1.5rem;transition:color .15s,border-color .15s;white-space:nowrap}.od-tab:hover{border-bottom-color:#cbd5e1;color:#334155}.od-tab--active{border-bottom-color:#7c3aed;color:#7c3aed;font-weight:600}.od-tab-body{animation:om-fade-in .16s ease-out;padding:2rem}.od-field-grid{grid-gap:2.5rem 3rem;display:grid;gap:2.5rem 3rem;grid-template-columns:repeat(3,1fr)}.od-label{color:#94a3b8;display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.12em;margin-bottom:.5rem;text-transform:uppercase}.od-value{color:#0f172a;font-size:.9375rem;font-weight:600}.od-empty,.od-value{font-family:Plus Jakarta Sans,sans-serif;margin:0}.od-empty{color:#94a3b8;font-size:.875rem;font-style:italic;font-weight:500}.od-code-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.25rem;color:#475569;display:inline-block;font-family:JetBrains Mono,Courier New,monospace;font-size:.75rem;font-weight:700;padding:.25rem .5rem}.od-link{color:#7c3aed;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;text-decoration:none;word-break:break-all}.od-link:hover{text-decoration:underline}.od-desc-section{border-top:1px solid #f1f5f9;margin-top:3rem;padding-top:2.5rem}.od-desc-box{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:.75rem;margin-top:1rem;padding:1.5rem;text-align:center}.od-desc-text{color:#475569;text-align:left}.od-desc-empty,.od-desc-text{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;line-height:1.6;margin:0}.od-desc-empty{color:#64748b}.od-desc-link{background:none;border:none;color:#7c3aed;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:500;padding:0}.od-desc-link:hover{text-decoration:underline}.od-workday{background:#f1f5f9;border-radius:.375rem;color:#334155;display:inline-block;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:500;margin:.15rem;padding:.2rem .6rem}.od-footer{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-top:2rem;padding:0 .25rem}.od-footer-meta{color:#94a3b8}.od-deactivate-btn,.od-footer-meta{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem}.od-deactivate-btn{-webkit-appearance:none;appearance:none;background:none;border:none;color:#ef4444;cursor:pointer;font-weight:700;letter-spacing:.08em;padding:0;text-transform:uppercase;transition:color .15s}.od-deactivate-btn:hover{color:#b91c1c}.organization-management{margin:0 auto;max-width:1400px;padding:2rem}.organization-form-page{animation:om-fade-in .22s ease-out}.org-icon-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea59;color:#fff;display:flex;flex-shrink:0;height:46px;justify-content:center;width:46px}.form-page-header{border-bottom:1px solid #e5e7eb;margin-bottom:1.75rem;padding-bottom:1.25rem}.detail-header-identity{align-items:center;display:flex;flex:1 1;gap:.875rem;min-width:0}.detail-header-text{min-width:0}.detail-header-text h1{color:#111827;font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin:0 0 .35rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-back{border:1.5px solid #e5e7eb;border-radius:8px;color:#6b7280;display:inline-flex;flex-shrink:0;font-family:inherit;font-size:.8125rem;font-weight:600;gap:.35rem;padding:.45rem .875rem;transition:all .16s ease;white-space:nowrap}.btn-back:hover{background:#f5f3ff;border-color:#6366f1;color:#6366f1}.alert{animation:om-slide-down .22s ease-out;border-radius:10px;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1.25rem;padding:.875rem 1.125rem}.alert-error{border-left:4px solid #dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;border-left:4px solid #16a34a;color:#166534}.tabs{background:#f3f4f6;border:1px solid #e5e7eb;border-bottom:none;border-radius:12px 12px 0 0;gap:.25rem;padding:.75rem 1.5rem 0}.tab{border:1.5px solid #0000;border-radius:8px 8px 0 0;color:#6b7280;font-family:inherit;font-weight:600;letter-spacing:.01em;padding:.6rem 1.25rem;position:relative;top:1px;transition:all .16s ease}.tab:hover{background:#6366f114;color:#6366f1}.tab-active{background:#fff;border-color:#e5e7eb #e5e7eb #fff;box-shadow:inset 0 3px 0 0 #6366f1;color:#6366f1}.organization-form{background:#fff;border:1px solid #e5e7eb;border-radius:0 0 12px 12px;border-top:none;box-shadow:0 2px 12px #0000000d}.form-content-wrapper{padding:1.75rem 2rem}.tab-content{animation:om-fade-in .16s ease-out}.form-grid{grid-gap:1.375rem;gap:1.375rem}.form-group{gap:.375rem}.form-group.span-2{grid-column:span 2}.form-group label{font-size:.8125rem;font-weight:600;letter-spacing:.01em}.form-group input,.form-group select,.form-group textarea{border:1.5px solid #e5e7eb;color:#111827;font-size:.9rem;transition:border-color .16s,box-shadow .16s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.form-group input::placeholder,.form-group textarea::placeholder{color:#c4cad4}.form-helper{color:#a3aab5;font-size:.73rem;margin-top:.125rem}.checkbox-label{color:#374151;font-size:.875rem;font-weight:500;gap:.625rem;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{accent-color:#6366f1;height:16px;width:16px}.checkbox-label.inline{display:inline-flex;margin-bottom:.375rem;margin-right:.75rem}.checkbox-group{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;display:flex;flex-wrap:wrap;gap:.375rem;padding:.75rem}.code-input-group{align-items:stretch}.code-input{border-radius:8px 0 0 8px!important;border-right:none!important}.btn-generate{background:#f5f3ff;border:1.5px solid #ddd6fe;border-radius:0 8px 8px 0;color:#6d28d9;font-family:inherit;font-size:.8rem;font-weight:600;gap:.3rem;padding:.55rem .875rem;transition:all .15s}.btn-generate:hover{background:#6d28d9;border-color:#6d28d9;color:#fff}.form-actions{align-items:center;background:#fafafa;border-radius:0 0 12px 12px;border-top:1px solid #f3f4f6;padding:1rem 2rem}.btn{border-radius:8px;display:inline-flex;font-size:.875rem;font-weight:600;gap:.4rem;justify-content:center;letter-spacing:.01em;padding:.6rem 1.375rem;transition:all .16s ease}.btn-primary{box-shadow:0 1px 4px #667eea4d}.btn-primary:hover{box-shadow:0 4px 14px #667eea73;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1.5px solid #e5e7eb}.btn-secondary:hover{background:#f9fafb;border-color:#d1d5db}.btn-sm{padding:.4rem .875rem}.loading{align-items:center;color:#9ca3af;display:flex;font-size:.9rem;justify-content:center;padding:5rem}@media (max-width:1024px){.od-field-grid,.om-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.om-page{padding:1rem}.om-header{align-items:flex-start;flex-direction:column}.om-stats{grid-template-columns:repeat(2,1fr)}.om-table-wrap{overflow-x:auto}.om-table{min-width:640px}.om-footer,.om-toolbar{align-items:flex-start;flex-direction:column}.od-page{padding:0}.od-header-card{align-items:flex-start;flex-direction:column}.od-field-grid{grid-template-columns:1fr}.od-tabs-nav{padding:0 1rem}.od-tab{font-size:.8125rem;padding:.75rem .875rem}.od-tab-body{padding:1.25rem}.od-footer{align-items:flex-start;flex-direction:column}.organization-management{padding:1rem}.form-page-header{flex-wrap:wrap}.form-grid{grid-template-columns:1fr}.form-group.span-2{grid-column:span 1}.tabs{overflow-x:auto;padding:.5rem .75rem 0}.tab{font-size:.8125rem;padding:.5rem .75rem;white-space:nowrap}.form-content-wrapper{padding:1.125rem}.form-actions{flex-wrap:wrap;padding:.875rem 1.125rem}}@media (prefers-reduced-motion:reduce){.alert,.od-active-badge--active .od-badge-dot,.od-alert,.od-page,.od-tab-body,.organization-form-page,.tab-content{animation:none}}.of-page{animation:om-fade-in .22s ease-out;padding:0}.of-alert{animation:om-slide-down .22s ease-out}.of-tab-content{animation:om-fade-in .16s ease-out}.of-textarea{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:.75rem 1rem;resize:vertical;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}.of-textarea:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.of-textarea::placeholder{color:#c4cad4}.of-icon-input{align-items:center;display:flex;position:relative}.of-input-icon{color:#94a3b8;flex-shrink:0;left:.75rem;pointer-events:none;position:absolute}.of-input--icon{padding-left:2.75rem}.of-checkbox-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;display:flex;flex-wrap:wrap;gap:.5rem;padding:.875rem}.of-save-btn{box-shadow:0 4px 6px -1px #6366f14d,0 2px 4px -2px #6366f133}.of-danger-footer{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;padding:.25rem 0}.of-danger-note{color:#94a3b8;font-size:.75rem;margin:0}.of-danger-note,.of-deactivate-btn{font-family:Plus Jakarta Sans,sans-serif}.of-deactivate-btn{-webkit-appearance:none;appearance:none;background:none;border:1px solid #fca5a5;border-radius:.5rem;color:#ef4444;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.4375rem .875rem;transition:background .15s,border-color .15s}.of-deactivate-btn:hover{background:#fef2f2;border-color:#ef4444}.of-logo-upload-area{display:flex;flex-direction:column;gap:.75rem}.of-logo-preview{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;display:inline-flex;height:96px;justify-content:center;overflow:hidden;position:relative;width:96px}.of-logo-img{height:100%;object-fit:contain;padding:4px;width:100%}.of-logo-remove{align-items:center;background:#0000008c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:20px;justify-content:center;line-height:1;padding:0;position:absolute;right:4px;top:4px;width:20px}.of-logo-remove:hover{background:#ef4444}.of-logo-inputs{align-items:center;display:flex;flex-wrap:wrap;gap:.625rem}.of-logo-file-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;flex-shrink:0;font-family:inherit;font-size:.8125rem;font-weight:500;gap:.375rem;height:2.75rem;padding:0 .875rem;transition:border-color .15s,background .15s;white-space:nowrap}.of-logo-file-btn:hover{background:#f5f3ff;border-color:#6366f1;color:#6366f1}.of-logo-divider{color:#94a3b8;flex-shrink:0;font-size:.75rem;white-space:nowrap}@media (max-width:768px){.of-form-body{padding:1.25rem}.of-form-grid{grid-template-columns:1fr}.of-span-2{grid-column:span 1}.of-tabs-nav{padding:0 1rem}.of-tab{font-size:.8125rem;padding:.75rem .875rem}.of-form-actions{flex-wrap:wrap;padding:1rem 1.25rem}.of-card-header{padding:1.25rem}.of-danger-footer{align-items:flex-start;flex-direction:column}}@media (prefers-reduced-motion:reduce){.of-alert,.of-page,.of-tab-content{animation:none}}.em-page{margin:0 auto;max-width:1400px;padding:2rem}.em-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.em-spinner{animation:em-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes em-spin{to{transform:rotate(1turn)}}.em-alert{border-radius:.75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.em-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.em-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.em-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.em-header-left{flex:1 1}.em-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.em-breadcrumb-parent{color:#64748b}.em-breadcrumb-sep{color:#94a3b8}.em-breadcrumb-active{color:#6366f1;font-weight:500}.em-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.em-subtitle{color:#64748b;margin:0}.em-add-btn,.em-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.em-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.em-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.em-add-btn:active{transform:translateY(0)}.em-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.em-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.em-stat,.em-stat-icon{align-items:center;display:flex}.em-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.em-stat-icon--blue{background:#eff6ff;color:#2563eb}.em-stat-icon--green{background:#f0fdf4;color:#16a34a}.em-stat-icon--yellow{background:#fefce8;color:#ca8a04}.em-stat-icon--purple{background:#f5f3ff;color:#7c3aed}.em-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.em-stat-label,.em-stat-value{font-family:Plus Jakarta Sans,sans-serif}.em-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.em-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.em-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.em-filters{display:flex;gap:.25rem}.em-filter-btn{align-items:center;background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s}.em-filter-btn:hover{background:#f8fafc;color:#334155}.em-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.em-filter-btn--ex{color:#9333ea}.em-filter-btn--ex:hover{background:#faf5ff;color:#7e22ce}.em-filter-btn--ex-active{background:#f3e8ff;color:#7e22ce;font-weight:700}.em-ex-count{background:#9333ea;border-radius:999px;color:#fff;font-size:.7rem;font-weight:700;line-height:1.4;margin-left:.375rem;padding:.1rem .4rem}.em-toolbar-right{align-items:center;display:flex;gap:.75rem}.em-search-wrap{align-items:center;display:flex;position:relative}.em-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.em-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.em-search-input:focus{background:#fff;border-color:#6366f1}.em-action-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:background .15s,border-color .15s}.em-action-btn:hover{background:#f8fafc;border-color:#cbd5e1}.em-table-wrap{overflow-x:auto}.em-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.em-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.em-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.em-table tbody tr:last-child{border-bottom:none}.em-clickable-row{cursor:pointer}.em-clickable-row:hover{background:#fafbff}.em-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.em-emp-cell{gap:.75rem}.em-avatar,.em-emp-cell{align-items:center;display:flex}.em-avatar{background:#ede9fe;border-radius:.5rem;color:#6366f1;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.em-emp-name{color:#0f172a;font-weight:600}.em-emp-sub{color:#94a3b8;font-size:.75rem;margin-top:1px}.em-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;font-family:Courier New,monospace;letter-spacing:.04em;padding:.2rem .5rem}.em-code,.em-type-badge{display:inline-block;font-size:.75rem;font-weight:600}.em-type-badge{border-radius:999px;padding:.2rem .625rem;text-transform:capitalize}.em-type-badge--full-time{background:#f0fdf4;color:#16a34a}.em-type-badge--contract{background:#fefce8;color:#ca8a04}.em-type-badge--part-time{background:#eff6ff;color:#2563eb}.em-muted{color:#94a3b8!important}.em-dash{color:#cbd5e1}.em-row-actions{align-items:center;display:flex;gap:.375rem}.em-delete-btn,.em-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.em-edit-btn{color:#475569}.em-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.em-delete-btn{color:#94a3b8}.em-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.em-reactivate-btn{align-items:center;background:#f3e8ff;border:1px solid #d8b4fe;border-radius:.5rem;color:#7e22ce;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:600;gap:.375rem;padding:.375rem .875rem;transition:background .15s,border-color .15s}.em-reactivate-btn:hover{background:#ede9fe;border-color:#c4b5fd}.em-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.em-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.em-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.em-count strong{color:#0f172a}.em-pagination{display:flex;gap:.25rem}.em-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.em-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.em-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.em-page-btn:disabled{cursor:not-allowed;opacity:.4}.em-detail-page{margin:0 auto;max-width:1400px;padding:0}.em-back-btn{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.375rem;margin-bottom:1.5rem;padding:0;transition:color .15s}.em-back-btn:hover{color:#6366f1}.em-detail-header-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.75rem 2rem}.em-detail-header-left{align-items:center;display:flex;flex:1 1;gap:1.25rem}.em-detail-avatar{align-items:center;background:#ede9fe;border-radius:1rem;color:#6366f1;display:flex;flex-shrink:0;font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;height:68px;justify-content:center;width:68px}.em-detail-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.em-detail-name{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0}.em-detail-name,.em-detail-role-badge{font-family:Plus Jakarta Sans,sans-serif}.em-detail-role-badge{background:#ede9fe;border-radius:999px;color:#6d28d9;font-size:.6875rem;font-weight:700;letter-spacing:.05em;padding:.25rem .625rem}.em-detail-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.em-detail-meta-item{align-items:center;color:#64748b;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem}.em-detail-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.em-detail-edit-btn{align-items:center;background:#6366f1;border:none;border-radius:.625rem;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s}.em-detail-edit-btn:hover{background:#4f46e5}.em-detail-content-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;margin-bottom:1.5rem;overflow:hidden}.em-detail-tabs-nav{border-bottom:1px solid #e2e8f0;display:flex;padding:0 1.5rem}.em-detail-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:1rem 1.25rem;transition:color .15s,border-color .15s}.em-detail-tab:hover{color:#334155}.em-detail-tab--active{border-bottom-color:#6366f1;color:#6366f1;font-weight:700}.em-detail-tab-body{padding:1.75rem 2rem}.em-detail-field-grid{grid-gap:1.5rem 2rem;display:grid;gap:1.5rem 2rem;grid-template-columns:repeat(3,1fr)}.em-detail-label{color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.375rem;text-transform:uppercase}.em-detail-label,.em-detail-value{font-family:Plus Jakarta Sans,sans-serif}.em-detail-value{color:#0f172a;font-size:.9375rem;font-weight:600}.em-detail-empty{color:#94a3b8;font-style:italic;font-weight:400}.em-detail-link{color:#6366f1;text-decoration:none}.em-detail-code-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.8125rem;font-weight:600;letter-spacing:.04em;padding:.2rem .625rem}.em-detail-footer{align-items:center;display:flex;justify-content:space-between;padding:.875rem 0}.em-detail-footer-meta{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem}.employee-management{margin:0 auto;max-width:1400px;padding:2rem}.employee-management .header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.employee-management .header-content{align-items:center;display:flex;gap:1rem}.employee-management .header-icon{color:var(--primary)}.employee-management h1{color:var(--gray-900);font-size:1.75rem;font-weight:700;margin:0}.form-page-header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.form-page-header .header-title{align-items:center;display:flex;flex:1 1;gap:.75rem}.form-page-header h1{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin:0}.tabs{border-bottom:2px solid var(--gray-200);display:flex;gap:0;margin-bottom:1.5rem}.tab{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--gray-500);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.5rem;transition:color .2s,border-color .2s}.tab:hover{color:var(--gray-700)}.tab-active{border-bottom-color:var(--primary);color:var(--primary);font-weight:600}.employee-form .form-content-wrapper{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;margin-bottom:1.5rem;padding:2rem}.tab-content .form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.form-group label{color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid var(--gray-300);border-radius:.5rem;color:var(--gray-900);font-size:.875rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.form-helper{color:var(--gray-400);font-size:.75rem}.code-input-group{display:flex;gap:.5rem}.code-input{flex:1 1}.btn-generate{align-items:center;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:.5rem;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:.8125rem;gap:.375rem;padding:.5rem .875rem;transition:background .15s;white-space:nowrap}.btn-generate:hover{background:var(--gray-200)}.form-group.full-width{grid-column:1/-1}.form-actions{gap:.75rem;padding-top:1rem}.detail-content .detail-sections{display:flex;flex-direction:column;gap:2rem}.detail-section{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;padding:1.5rem}.section-title{border-bottom:1px solid var(--gray-100);color:var(--gray-900);font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.75rem}.detail-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(2,1fr)}.detail-item{flex-direction:column;gap:.375rem}.detail-item label{color:var(--gray-400);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.detail-item p{color:var(--gray-900);font-size:.9375rem;font-weight:500;margin:0}.detail-item.full-width{grid-column:1/-1}.status-badge{border-radius:999px}.status-badge.active{background:#f0fdf4;color:#16a34a}.status-badge.inactive{background:#fef2f2;color:#dc2626}.employee-list{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;padding:0 2rem}.employee-list h2{border-bottom:1px solid var(--gray-100);color:var(--gray-900);font-size:1.125rem;font-weight:600;margin:0;padding:1.25rem 0}.employee-table{border-collapse:collapse;font-size:.875rem;width:100%}.employee-table th{background:var(--gray-50);border-bottom:1px solid var(--gray-200);color:var(--gray-400);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.75rem 1rem;text-align:left;text-transform:uppercase}.employee-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:.875rem 1rem}.employee-table tr:last-child td{border-bottom:none}.clickable-row{cursor:pointer;transition:background .1s}.clickable-row:hover{background:var(--gray-50)}.no-data{color:var(--gray-400);padding:3rem;text-align:center}.btn-back{background:#0000;border:1px solid var(--gray-300);border-radius:.5rem;color:var(--gray-600);font-size:.875rem;padding:.5rem 1rem;transition:all .15s}.btn-back:hover{background:var(--gray-100)}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:1rem;width:1rem}@media (max-width:1024px){.em-detail-field-grid,.em-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.em-detail-page,.em-page{padding:1rem}.em-header{align-items:flex-start;flex-direction:column}.em-stats{grid-template-columns:repeat(2,1fr)}.em-toolbar{align-items:flex-start;flex-direction:column}.em-detail-field-grid{grid-template-columns:1fr}.em-detail-header-card{flex-direction:column}.tab-content .form-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.em-spinner{animation:none}}.dep-page{margin:0 auto;max-width:1400px;padding:2rem}.dep-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.dep-spinner{animation:dep-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes dep-spin{to{transform:rotate(1turn)}}.dep-alert{border-radius:.75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.dep-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.dep-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.dep-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.dep-header-left{flex:1 1}.dep-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.dep-breadcrumb-parent{color:#64748b}.dep-breadcrumb-sep{color:#94a3b8}.dep-breadcrumb-active{color:#6366f1;font-weight:500}.dep-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.dep-subtitle{color:#64748b;margin:0}.dep-add-btn,.dep-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.dep-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.dep-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.dep-add-btn:active{transform:translateY(0)}.dep-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.dep-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.dep-stat,.dep-stat-icon{align-items:center;display:flex}.dep-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.dep-stat-icon--blue{background:#eff6ff;color:#2563eb}.dep-stat-icon--green{background:#f0fdf4;color:#16a34a}.dep-stat-icon--yellow{background:#fefce8;color:#ca8a04}.dep-stat-icon--purple{background:#f5f3ff;color:#7c3aed}.dep-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.dep-stat-label,.dep-stat-value{font-family:Plus Jakarta Sans,sans-serif}.dep-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.dep-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.dep-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.dep-filters{display:flex;gap:.25rem}.dep-filter-btn{background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s}.dep-filter-btn:hover{background:#f8fafc;color:#334155}.dep-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.dep-toolbar-right{align-items:center;display:flex;gap:.75rem}.dep-search-wrap{align-items:center;display:flex;position:relative}.dep-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.dep-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.dep-search-input:focus{background:#fff;border-color:#6366f1}.dep-action-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:background .15s,border-color .15s}.dep-action-btn:hover{background:#f8fafc;border-color:#cbd5e1}.dep-table-wrap{overflow-x:auto}.dep-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.dep-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.dep-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.dep-table tbody tr:last-child{border-bottom:none}.dep-clickable-row{cursor:pointer}.dep-clickable-row:hover{background:#fafbff}.dep-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.dep-name-wrapper{align-items:center;display:flex;gap:.375rem}.dep-hierarchy-icon{color:#94a3b8;flex-shrink:0}.dep-has-children{color:#0f172a;font-weight:600}.dep-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.2rem .5rem}.dep-muted{color:#94a3b8!important}.dep-dash{color:#cbd5e1}.dep-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .625rem}.dep-status-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.dep-status--active{background:#f0fdf4;color:#16a34a}.dep-status--inactive{background:#fef2f2;color:#dc2626}.dep-row-actions{align-items:center;display:flex;gap:.375rem}.dep-delete-btn,.dep-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.dep-edit-btn{color:#475569}.dep-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.dep-delete-btn{color:#94a3b8}.dep-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.dep-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.dep-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.dep-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.dep-count strong{color:#0f172a}.dep-pagination{display:flex;gap:.25rem}.dep-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.dep-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.dep-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.dep-page-btn:disabled{cursor:not-allowed;opacity:.4}.dep-detail-page{margin:0 auto;max-width:1400px;padding:0}.dep-back-btn{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.375rem;margin-bottom:1.5rem;padding:0;transition:color .15s}.dep-back-btn:hover{color:#6366f1}.dep-detail-header-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.75rem 2rem}.dep-detail-header-left{align-items:center;display:flex;flex:1 1;gap:1.25rem}.dep-detail-org-icon{align-items:center;background:#ede9fe;border-radius:1rem;color:#6366f1;display:flex;flex-shrink:0;height:68px;justify-content:center;width:68px}.dep-detail-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.dep-detail-name{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0}.dep-detail-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.6875rem;font-weight:700;gap:.375rem;letter-spacing:.05em;padding:.3rem .75rem}.dep-detail-status-badge--active{background:#dcfce7;color:#15803d}.dep-detail-status-badge--inactive{background:#fef2f2;color:#dc2626}.dep-detail-badge-dot{animation:dep-pulse 2s infinite;background:#16a34a;border-radius:50%;height:7px;width:7px}@keyframes dep-pulse{0%,to{opacity:1}50%{opacity:.4}}.dep-detail-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.dep-detail-meta-item{align-items:center;color:#64748b;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem}.dep-detail-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.dep-detail-edit-btn{align-items:center;background:#6366f1;border:none;border-radius:.625rem;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s}.dep-detail-edit-btn:hover{background:#4f46e5}.dep-detail-content-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;margin-bottom:1.5rem;overflow:hidden}.dep-detail-tabs-nav{border-bottom:1px solid #e2e8f0;display:flex;padding:0 1.5rem}.dep-detail-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:1rem 1.25rem;transition:color .15s,border-color .15s}.dep-detail-tab:hover{color:#334155}.dep-detail-tab--active{border-bottom-color:#6366f1;color:#6366f1;font-weight:700}.dep-detail-tab-body{padding:1.75rem 2rem}.dep-detail-field-grid{grid-gap:1.5rem 2rem;display:grid;gap:1.5rem 2rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.dep-detail-label{color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.375rem;text-transform:uppercase}.dep-detail-label,.dep-detail-value{font-family:Plus Jakarta Sans,sans-serif}.dep-detail-value{color:#0f172a;font-size:.9375rem;font-weight:600}.dep-detail-empty{color:#94a3b8;font-style:italic;font-weight:400}.dep-detail-code-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.8125rem;font-weight:600;letter-spacing:.04em;padding:.2rem .625rem}.dep-detail-desc-section{margin-top:.5rem}.dep-detail-desc-box{background:#fafbff;border:1.5px dashed #e2e8f0;border-radius:.625rem;margin-top:.75rem;padding:1.25rem 1.5rem}.dep-detail-desc-text{color:#334155;font-size:.9375rem;line-height:1.6}.dep-detail-desc-empty,.dep-detail-desc-text{font-family:Plus Jakarta Sans,sans-serif;margin:0}.dep-detail-desc-empty{color:#94a3b8;font-size:.875rem;text-align:center}.dep-detail-desc-link{background:none;border:none;color:#6366f1;cursor:pointer;font-family:inherit;font-size:.875rem;padding:0;text-decoration:underline}.dep-detail-footer{align-items:center;display:flex;justify-content:space-between;padding:.875rem 0}.dep-detail-footer-meta{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem}.department-management{margin:0 auto;max-width:1400px;padding:2rem}.department-management .header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.department-management .header-content{align-items:center;display:flex;gap:1rem}.department-management .header-icon{color:var(--primary)}.department-management h1{color:var(--gray-900);font-size:1.75rem;font-weight:700;margin:0}.department-management .form-page-header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.department-management .form-page-header .header-title{align-items:center;display:flex;flex:1 1;gap:.75rem}.department-management .form-page-header h1{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin:0}.department-form .form-content-wrapper{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;margin-bottom:1.5rem;padding:2rem}.department-form .form-section{margin-bottom:2rem}.department-form .form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.dept-level-1{background:#fafbff}.dept-level-2{background:#f8fafc}.department-list{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;padding:0 2rem}.department-list h2{border-bottom:1px solid var(--gray-100);color:var(--gray-900);font-size:1.125rem;font-weight:600;margin:0;padding:1.25rem 0}.department-table{border-collapse:collapse;font-size:.875rem;width:100%}.department-table th{background:var(--gray-50);border-bottom:1px solid var(--gray-200);color:var(--gray-400);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.75rem 1rem;text-align:left;text-transform:uppercase}.department-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:.875rem 1rem}.department-table tr:last-child td{border-bottom:none}.dept-name-wrapper{align-items:center;display:flex;gap:.5rem}.dept-hierarchy-icon{color:var(--gray-400)}.dept-code{background:var(--gray-100);border-radius:.25rem;font-family:monospace;font-size:.75rem;padding:.2rem .5rem}.dept-name .has-children{font-weight:600}@media (max-width:1024px){.dep-detail-field-grid,.dep-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dep-detail-page,.dep-page{padding:1rem}.dep-header{align-items:flex-start;flex-direction:column}.dep-stats{grid-template-columns:repeat(2,1fr)}.dep-toolbar{align-items:flex-start;flex-direction:column}.dep-detail-field-grid{grid-template-columns:1fr}.dep-detail-header-card{flex-direction:column}.department-form .form-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.dep-detail-badge-dot,.dep-spinner{animation:none}}.dep-action-btn--active{background:#ede9fe;border-color:#a5b4fc;color:#6366f1}.dep-action-btn--active:hover{background:#e0e7ff}.dep-filter-count{align-items:center;background:#6366f1;border-radius:50%;color:#fff;display:inline-flex;font-size:.625rem;font-weight:700;height:1.125rem;justify-content:center;margin-left:.125rem;width:1.125rem}.dep-filter-panel{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 8px 24px #0000001a;position:absolute;right:0;top:calc(100% + 8px);width:280px;z-index:300}.dep-filter-panel-header{align-items:center;border-bottom:1px solid #f1f5f9;color:#1e293b;display:flex;font-size:.8125rem;font-weight:600;justify-content:space-between;padding:.875rem 1rem .75rem}.dep-filter-panel-close{background:none;border:none;border-radius:.375rem;color:#94a3b8;cursor:pointer;display:flex;padding:.25rem}.dep-filter-panel-close:hover{background:#f1f5f9;color:#475569}.dep-filter-panel-body{display:flex;flex-direction:column;gap:.875rem;padding:.875rem 1rem}.dep-filter-field{display:flex;flex-direction:column;gap:.375rem}.dep-filter-label{color:#94a3b8;font-size:.625rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.dep-filter-select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:2.375rem;padding:0 .75rem}.dep-filter-select:focus{border-color:#818cf8;box-shadow:0 0 0 3px #6366f11f;outline:none}.dep-filter-panel-footer{border-top:1px solid #f1f5f9;padding:.625rem 1rem .875rem}.dep-filter-clear-btn{background:none;border:none;color:#ef4444;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;padding:0}.dep-filter-clear-btn:hover{text-decoration:underline}.cl-page{margin:0 auto;max-width:1400px;padding:2rem}.cl-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.cl-spinner{animation:cl-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes cl-spin{to{transform:rotate(1turn)}}.cl-alert{border-radius:.75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.cl-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.cl-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.cl-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.cl-header-left{flex:1 1}.cl-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.cl-breadcrumb-parent{color:#64748b}.cl-breadcrumb-sep{color:#94a3b8}.cl-breadcrumb-active{color:#6366f1;font-weight:500}.cl-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.cl-subtitle{color:#64748b;margin:0}.cl-add-btn,.cl-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.cl-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.cl-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.cl-add-btn:active{transform:translateY(0)}.cl-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.cl-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.cl-stat,.cl-stat-icon{align-items:center;display:flex}.cl-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.cl-stat-icon--blue{background:#eff6ff;color:#2563eb}.cl-stat-icon--green{background:#f0fdf4;color:#16a34a}.cl-stat-icon--yellow{background:#fefce8;color:#ca8a04}.cl-stat-icon--red{background:#fff1f2;color:#e11d48}.cl-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.cl-stat-label,.cl-stat-value{font-family:Plus Jakarta Sans,sans-serif}.cl-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.cl-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.cl-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.cl-filters{display:flex;gap:.25rem}.cl-filter-btn{background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s}.cl-filter-btn:hover{background:#f8fafc;color:#334155}.cl-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.cl-toolbar-right{align-items:center;display:flex;gap:.75rem}.cl-search-wrap{align-items:center;display:flex;position:relative}.cl-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.cl-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.cl-search-input:focus{background:#fff;border-color:#6366f1}.cl-action-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:background .15s}.cl-action-btn:hover{background:#f8fafc;border-color:#cbd5e1}.cl-table-wrap{overflow-x:auto}.cl-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.cl-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.cl-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.cl-table tbody tr:last-child{border-bottom:none}.cl-clickable-row{cursor:pointer}.cl-clickable-row:hover{background:#fafbff}.cl-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.cl-client-cell{gap:.75rem}.cl-avatar,.cl-client-cell{align-items:center;display:flex}.cl-avatar{background:#fef3c7;border-radius:.5rem;color:#d97706;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.cl-client-name{color:#0f172a;font-weight:600}.cl-client-sub{color:#94a3b8;font-size:.75rem;margin-top:1px}.cl-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;font-family:Courier New,monospace;letter-spacing:.04em;padding:.2rem .5rem}.cl-code,.cl-org-badge{display:inline-block;font-size:.75rem;font-weight:600}.cl-org-badge{background:#eff6ff;border-radius:999px;color:#2563eb;padding:.2rem .625rem}.cl-muted{color:#94a3b8!important}.cl-dash{color:#cbd5e1}.cl-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .625rem}.cl-status-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.cl-status--active{background:#f0fdf4;color:#16a34a}.cl-status--inactive{background:#fef2f2;color:#dc2626}.cl-status--paused{background:#fff7ed;color:#c2410c}.cl-status--closed{background:#fef2f2;color:#dc2626}.cl-row-actions{align-items:center;display:flex;gap:.375rem}.cl-delete-btn,.cl-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.cl-edit-btn{color:#475569}.cl-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.cl-delete-btn{color:#94a3b8}.cl-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.cl-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.cl-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.cl-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.cl-count strong{color:#0f172a}.cl-pagination{display:flex;gap:.25rem}.cl-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.cl-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.cl-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.cl-page-btn:disabled{cursor:not-allowed;opacity:.4}.cl-detail-page{margin:0 auto;max-width:1400px;padding:0}.cl-back-btn{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.375rem;margin-bottom:1.5rem;padding:0;transition:color .15s}.cl-back-btn:hover{color:#6366f1}.cl-detail-header-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.75rem 2rem}.cl-detail-header-left{align-items:center;display:flex;flex:1 1;gap:1.25rem}.cl-detail-avatar{align-items:center;background:#fef3c7;border-radius:1rem;color:#d97706;display:flex;flex-shrink:0;font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;height:68px;justify-content:center;width:68px}.cl-detail-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.cl-detail-name{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0}.cl-detail-name,.cl-detail-status-badge{font-family:Plus Jakarta Sans,sans-serif}.cl-detail-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.6875rem;font-weight:700;gap:.375rem;letter-spacing:.05em;padding:.3rem .75rem}.cl-detail-status-badge--active{background:#dcfce7;color:#15803d}.cl-detail-status-badge--inactive{background:#fef2f2;color:#dc2626}.cl-detail-status-badge--paused{background:#fff7ed;color:#c2410c}.cl-detail-status-badge--closed{background:#fef2f2;color:#dc2626}.cl-detail-badge-dot{animation:cl-pulse 2s infinite;background:#16a34a;border-radius:50%;height:7px;width:7px}@keyframes cl-pulse{0%,to{opacity:1}50%{opacity:.4}}.cl-detail-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.cl-detail-meta-item{align-items:center;color:#64748b;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem}.cl-detail-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.cl-detail-edit-btn{align-items:center;background:#6366f1;border:none;border-radius:.625rem;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s}.cl-detail-edit-btn:hover{background:#4f46e5}.cl-detail-content-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;margin-bottom:1.5rem;overflow:hidden}.cl-detail-tabs-nav{border-bottom:1px solid #e2e8f0;display:flex;padding:0 1.5rem}.cl-detail-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:1rem 1.25rem;transition:color .15s,border-color .15s}.cl-detail-tab:hover{color:#334155}.cl-detail-tab--active{border-bottom-color:#6366f1;color:#6366f1;font-weight:700}.cl-detail-tab-body{padding:1.75rem 2rem}.cl-detail-field-grid{grid-gap:1.5rem 2rem;display:grid;gap:1.5rem 2rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.cl-detail-label{color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.375rem;text-transform:uppercase}.cl-detail-label,.cl-detail-value{font-family:Plus Jakarta Sans,sans-serif}.cl-detail-value{align-items:center;color:#0f172a;display:flex;font-size:.9375rem;font-weight:600;gap:.375rem}.cl-detail-empty{color:#94a3b8;font-style:italic;font-weight:400}.cl-detail-link{align-items:center;color:#6366f1;display:inline-flex;font-weight:500;gap:.25rem;text-decoration:none}.cl-detail-link:hover{text-decoration:underline}.cl-detail-code-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.8125rem;font-weight:600;letter-spacing:.04em;padding:.2rem .625rem}.cl-detail-desc-section{margin-top:.5rem}.cl-detail-desc-box{background:#fafbff;border:1.5px dashed #e2e8f0;border-radius:.625rem;margin-top:.75rem;padding:1.25rem 1.5rem}.cl-detail-desc-text{color:#334155;font-size:.9375rem;line-height:1.6}.cl-detail-desc-empty,.cl-detail-desc-text{font-family:Plus Jakarta Sans,sans-serif;margin:0}.cl-detail-desc-empty{color:#94a3b8;font-size:.875rem;text-align:center}.cl-detail-desc-link{background:none;border:none;color:#6366f1;cursor:pointer;font-family:inherit;font-size:.875rem;padding:0;text-decoration:underline}.cl-org-assignments{display:flex;flex-direction:column;gap:1rem}.cl-org-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.25rem 1.5rem}.cl-org-card-title{color:#0f172a;font-size:1rem;font-weight:700;margin:0 0 1rem}.cl-no-orgs,.cl-org-card-title{font-family:Plus Jakarta Sans,sans-serif}.cl-no-orgs{color:#94a3b8;font-size:.875rem;padding:2rem;text-align:center}.cl-detail-footer{align-items:center;display:flex;justify-content:space-between;padding:.875rem 0}.cl-detail-footer-meta{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem}.cl-detail-company{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.9375rem;font-weight:500;margin-bottom:.375rem}.cm-tab-loading{min-height:120px}.cm-empty-state,.cm-tab-loading{align-items:center;display:flex;justify-content:center}.cm-empty-state{color:#94a3b8;flex-direction:column;font-family:Plus Jakarta Sans,sans-serif;font-size:.9375rem;gap:.75rem;min-height:140px}.cm-empty-state svg{opacity:.35}.cm-empty-state p{margin:0}.cm-detail-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.cm-detail-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.625rem 1rem;text-align:left;text-transform:uppercase}.cm-detail-table tbody tr{border-bottom:1px solid #f8fafc}.cm-detail-table tbody tr:last-child{border-bottom:none}.cm-detail-table td{color:#334155;padding:.75rem 1rem;vertical-align:middle}.cl-billing-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-top:1.5rem;padding:1.25rem 1.5rem}.cl-billing-summary-title{color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:700;margin-bottom:1rem}.cl-billing-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.client-management{margin:0 auto;max-width:1400px;padding:2rem}.client-management .header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.client-management .header-content{align-items:center;display:flex;gap:1rem}.client-management .header-icon{color:var(--primary)}.client-management h1{color:var(--gray-900);font-size:1.75rem;font-weight:700;margin:0}.client-management .form-page-header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.client-management .form-page-header .header-title{align-items:center;display:flex;flex:1 1;gap:.75rem}.client-management .form-page-header h1{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin:0}.client-form .form-tabs{border-bottom:2px solid var(--gray-200);display:flex;gap:0;margin-bottom:1.5rem}.client-form .tab-button{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--gray-500);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.5rem}.client-form .tab-button:hover{color:var(--gray-700)}.client-form .tab-button.active{border-bottom-color:var(--primary);color:var(--primary);font-weight:600}.client-form .form-content{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;margin-bottom:1.5rem;padding:2rem}.client-form .form-section{padding:0}.client-form .form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.client-form .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.org-assignment-form{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:.75rem;margin-bottom:1rem;padding:1.25rem}.org-assignment-form .assignment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.org-assignment-form h4{color:var(--gray-900);font-size:.9375rem;font-weight:600;margin:0}.btn-icon.btn-remove{background:#fff1f2;border-color:var(--danger);color:var(--danger)}.client-list{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;padding:0 2rem}.client-list h2{border-bottom:1px solid var(--gray-100);color:var(--gray-900);font-size:1.125rem;font-weight:600;margin:0;padding:1.25rem 0}.client-table{border-collapse:collapse;font-size:.875rem;width:100%}.client-table th{background:var(--gray-50);border-bottom:1px solid var(--gray-200);color:var(--gray-400);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.75rem 1rem;text-align:left;text-transform:uppercase}.client-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:.875rem 1rem}.client-table tr:last-child td{border-bottom:none}.client-name{color:var(--gray-900);font-weight:600}.client-code{border-radius:.25rem;font-family:monospace;padding:.2rem .5rem}.client-code,.org-count{background:var(--gray-100);font-size:.75rem}.org-count{border-radius:999px;display:inline-block;font-weight:500;padding:.2rem .625rem}.org-assignments-view{display:flex;flex-direction:column;gap:1rem}.org-assignment-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:.75rem;padding:1.25rem}.org-assignment-card h4{font-size:1rem;font-weight:600;margin:0 0 1rem}@media (max-width:1024px){.cl-detail-field-grid,.cl-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.cl-detail-page,.cl-page{padding:1rem}.cl-header{align-items:flex-start;flex-direction:column}.cl-stats{grid-template-columns:repeat(2,1fr)}.cl-toolbar{align-items:flex-start;flex-direction:column}.cl-detail-field-grid{grid-template-columns:1fr}.cl-detail-header-card{flex-direction:column}.client-form .form-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.cl-detail-badge-dot,.cl-spinner{animation:none}}.cl-sub-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.25rem}.cl-sub-header{align-items:center;display:flex;justify-content:space-between}.cl-sub-service{color:#1e293b;font-size:.9375rem;font-weight:600}.cl-sub-plan{color:#64748b;font-size:.8125rem}.cl-sub-fee{color:#6366f1;font-size:1.125rem;font-weight:700}.cl-sub-meta{align-items:center;color:#94a3b8;display:flex;flex-wrap:wrap;font-size:.75rem;gap:1rem}.cl-sub-actions{display:flex;gap:.5rem}.cl-sub-delete-btn,.cl-sub-edit-btn{align-items:center;background:none;border:none;border-radius:.375rem;cursor:pointer;display:inline-flex;font-size:.75rem;gap:.25rem;padding:.25rem .5rem}.cl-sub-edit-btn{color:#6366f1}.cl-sub-edit-btn:hover{background:#ede9fe}.cl-sub-delete-btn{color:#ef4444}.cl-sub-delete-btn:hover{background:#fef2f2}.cl-sub-add-btn{align-items:center;background:#6366f1;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:600;gap:.375rem;padding:.5rem 1rem}.cl-sub-add-btn:hover{background:#4f46e5}.cl-sub-form-card{background:#f5f3ff;border:1px solid #c7d2fe;border-radius:.75rem;display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.cl-sub-form-grid{grid-gap:.875rem;display:grid;gap:.875rem;grid-template-columns:1fr 1fr}.cl-sub-form-actions{display:flex;gap:.5rem;justify-content:flex-end}.cl-billing-summary{display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:1.25rem}.cl-billing-stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;flex:1 1;min-width:120px;padding:.875rem 1.25rem}.cl-billing-stat-label{color:#94a3b8;font-size:.625rem;font-weight:700;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.cl-billing-stat-value{color:#1e293b;font-size:1.375rem;font-weight:700}.cl-billing-stat-value--indigo{color:#6366f1}.cl-subs-list{display:flex;flex-direction:column;gap:.75rem}.cl-cycle-badge{align-items:center;background:#e0e7ff;border-radius:999px;color:#4338ca;display:inline-flex;font-size:.6875rem;font-weight:600;padding:.125rem .5rem}.cl-overview-finance{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem}.cl-overview-finance-title{color:var(--gray-500);font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.cl-fin-section{display:flex;flex-direction:column;gap:.625rem}.cl-fin-section-label{align-items:center;color:var(--gray-500);display:flex;font-size:.75rem;font-weight:700;gap:.5rem;letter-spacing:.05em;text-transform:uppercase}.cl-fin-section-count{font-weight:400;letter-spacing:0;text-transform:none}.cl-fin-section-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.cl-fin-section-dot--blue{background:#3b82f6}.cl-fin-section-dot--indigo{background:#6366f1}.cl-fin-grid{grid-gap:.625rem;display:grid;gap:.625rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.cl-fin-card{background:#fff;border:1px solid var(--gray-200);border-radius:10px;display:flex;flex-direction:column;gap:.15rem;padding:.75rem 1rem}.cl-fin-card--sub{border-left:3px solid #a5b4fc}.cl-fin-card--total{background:#f5f3ff;border-color:#c4b5fd}.cl-fin-card-label{color:var(--gray-400);font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.cl-fin-card-value{align-items:baseline;color:var(--gray-800);display:flex;font-size:1.0625rem;font-weight:700;gap:.15rem}.cl-fin-card-value--green{color:#16a34a}.cl-fin-card-value--red{color:#dc2626}.cl-fin-card-value--orange{color:#d97706}.cl-fin-card-value--blue{color:#2563eb}.cl-fin-card-value--indigo{color:#6366f1}.cl-fin-card-cycle{color:#94a3b8;font-size:.75rem;font-weight:500}.cl-fin-card-hint{color:var(--gray-400);font-size:.6875rem}.cl-fin-empty{background:var(--gray-50);border:1px dashed var(--gray-200);border-radius:10px;color:var(--gray-400);font-size:.875rem;padding:1rem;text-align:center}.cl-projects-list{gap:.625rem}.cl-proj-card,.cl-projects-list{display:flex;flex-direction:column}.cl-proj-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;gap:.75rem;padding:1rem 1.125rem;transition:border-color .15s,box-shadow .15s}.cl-proj-card:hover{border-color:#a5b4fc;box-shadow:0 2px 8px #6366f11a}.cl-proj-card-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.cl-proj-card-header-right{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.cl-proj-card-date{color:var(--gray-400);font-size:.75rem;white-space:nowrap}.cl-proj-card-name{color:var(--gray-800);font-size:.9375rem;font-weight:600}.cl-proj-card-type{color:var(--gray-400);font-size:.8125rem;margin-top:.125rem}.cl-proj-billing-simple{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.cl-proj-billing-label{color:var(--gray-400);font-size:.6875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.cl-proj-billing-amount{color:var(--gray-700);font-weight:700}.cl-proj-billing{display:flex;flex-direction:column;gap:.5rem}.cl-proj-billing-stats{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr)}.cl-proj-billing-stat{background:#fff;border:1px solid var(--gray-200);border-radius:8px;display:flex;flex-direction:column;gap:.1rem;padding:.5rem .75rem}.cl-proj-billing-stat-label{color:var(--gray-400);font-size:.625rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.cl-proj-billing-stat-value{color:var(--gray-800);font-size:.9375rem;font-weight:700}.cl-proj-billing-stat-note{color:var(--gray-400);font-size:.6875rem}.cl-proj-billing-stat--green{color:#16a34a}.cl-proj-billing-stat--blue{color:#2563eb}.cl-proj-billing-stat--orange{color:#d97706}.cl-proj-billing-bar-wrap{align-items:center;display:flex;gap:.75rem}.cl-proj-billing-bar{background:var(--gray-200);border-radius:99px;display:flex;flex:1 1;height:6px;overflow:hidden}.cl-proj-billing-bar-paid{background:#16a34a;border-radius:99px;transition:width .4s ease}.cl-proj-billing-bar-invoiced{background:#93c5fd;border-radius:99px;transition:width .4s ease}.cl-proj-billing-bar-label{color:var(--gray-400);font-size:.6875rem;white-space:nowrap}.cl-proj-hint{color:var(--gray-400);font-size:.8125rem;margin-top:.75rem;text-align:center}@media (max-width:600px){.cl-proj-billing-stats{grid-template-columns:repeat(2,1fr)}}.onboarding-management{margin:0 auto;max-width:1400px;padding:2rem}.ob-page-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.ob-header-left{flex:1 1}.ob-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.ob-breadcrumb-parent{color:#64748b}.ob-breadcrumb-sep{color:#94a3b8}.ob-breadcrumb-active{color:#6366f1;font-weight:500}.ob-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.ob-subtitle{color:#64748b;margin:0}.ob-add-btn,.ob-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.ob-add-btn{align-items:center;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.ob-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.ob-add-btn:active{transform:translateY(0)}.ob-back-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:.75rem;color:#374151;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .15s;white-space:nowrap}.ob-back-btn:hover{background:#f8fafc;border-color:#cbd5e1}.tabs-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.tabs-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex}.tab-button{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-size:.9375rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:all .2s}.tab-button:hover{background:#f3f4f6;color:#374151}.tab-button.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.tab-content{padding:2rem}.onboardings-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr))}.onboarding-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s}.onboarding-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.onboarding-card-header{align-items:start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.onboarding-card-header h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0}.onboarding-card-body,.progress-section{margin-bottom:1rem}.progress-header{align-items:center;margin-bottom:.5rem}.progress-label{color:#374151;font-size:.875rem;font-weight:500}.progress-value{color:#667eea;font-size:.875rem;font-weight:600}.progress-bar{width:100%}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2)}.progress-text{color:#6b7280;font-size:.8125rem;margin:.5rem 0 0}.onboarding-meta{display:flex;flex-direction:column;gap:.5rem}.meta-item{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem}.meta-item svg{color:#9ca3af}.onboarding-card-footer{border-top:1px solid #f3f4f6;display:flex;gap:.5rem;padding-top:1rem}.templates-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.template-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s}.template-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.template-header{align-items:start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.template-header h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0}.step-count{background:#f3f4f6;border-radius:12px;color:#6b7280;font-size:.8125rem;font-weight:500;padding:.25rem .75rem}.template-steps{display:flex;flex-direction:column;gap:.5rem}.template-step-preview{align-items:center;color:#374151;display:flex;font-size:.875rem;gap:.5rem}.template-step-preview svg{color:#9ca3af}.onboarding-details{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:320px 1fr}.details-sidebar{height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:2rem}.details-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem}.details-card h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.details-card h4{color:#374151;font-size:.9375rem;font-weight:600;margin:1.5rem 0 1rem}.details-list{display:flex;flex-direction:column;gap:1rem}.detail-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.detail-label{color:#6b7280;font-size:.875rem;font-weight:500}.circular-progress{display:flex;justify-content:center;margin:1rem 0}.progress-circle{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;height:120px;justify-content:center;position:relative;width:120px}.progress-circle:before{background:#fff;border-radius:50%;content:"";height:100px;position:absolute;width:100px}.progress-percentage{color:#667eea;font-size:1.5rem;font-weight:700;position:relative;z-index:1}.details-main{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem}.steps-container h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.steps-list{display:flex;flex-direction:column;gap:1rem}.step-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s}.step-card:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.step-header{display:flex;gap:1rem;margin-bottom:1rem}.step-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:32px;justify-content:center;width:32px}.step-content{flex:1 1}.step-content h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 .5rem}.step-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.75rem}.step-actions{border-top:1px solid #e5e7eb;display:flex;gap:.5rem;padding-top:.75rem}.onboarding-form{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;width:100%}.form-section{background:#f9fafb;border-radius:8px;display:block;margin-bottom:2rem;padding:1.5rem;width:100%}.form-section:last-of-type{margin-bottom:0}.form-section .section-header,.form-section h3{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 1.5rem;padding-bottom:.75rem}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);width:100%}@media (max-width:768px){.form-grid{grid-template-columns:1fr}}.form-group{gap:.5rem;min-width:0}.form-group label{font-size:.875rem}.form-group input,.form-group select,.form-group textarea{border-radius:8px;color:#1f2937;font-size:.9375rem;padding:.625rem .875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{font-family:inherit;min-height:80px}.required{color:#ef4444}.form-actions{gap:1rem;padding-top:1.5rem}.btn-danger,.btn-primary,.btn-secondary,.btn-success{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.625rem 1.25rem;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 6px #667eea4d;transform:translateY(-1px)}.btn-secondary{border:1px solid #d1d5db;color:#374151}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-danger{background:#ef4444}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{font-size:.8125rem;padding:.5rem .875rem}.btn-danger:disabled,.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.status-badge{color:#fff;font-size:.75rem;padding:.25rem .75rem}.alert{border-radius:8px;gap:.75rem;padding:1rem 1.25rem}.alert-error{background:#fef2f2}.alert-close{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;padding:0}.alert-close,.empty-state{align-items:center;display:flex}.empty-state{flex-direction:column;justify-content:center;padding:4rem 2rem}.empty-state svg{color:#d1d5db;margin-bottom:1rem}.empty-state h3{font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.empty-state p{margin:0 0 1.5rem}.loading-spinner{align-items:center;color:#6b7280;display:flex;font-size:1.125rem;justify-content:center;min-height:400px}.text-muted{color:#6b7280;font-size:.875rem}.section-header{align-items:center;display:flex;gap:.75rem}.section-header svg{color:#667eea;flex-shrink:0}.section-header-with-action{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:.75rem}.section-header-with-action .section-header{border-bottom:none;margin-bottom:0;padding-bottom:0}.steps-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto}.steps-table{border-collapse:collapse;font-size:.875rem;width:100%}.steps-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.steps-table th{color:#374151;font-weight:600;padding:.75rem 1rem;text-align:left;white-space:nowrap}.steps-table th .required{color:#ef4444;margin-left:2px}.steps-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.steps-table tbody tr:hover{background:#f9fafb}.steps-table tbody tr:last-child{border-bottom:none}.steps-table td{padding:.75rem 1rem;vertical-align:middle}.steps-table td.text-center{text-align:center}.table-input,.table-select{border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;padding:.5rem .75rem;transition:all .2s;width:100%}.table-input:focus,.table-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.table-input::placeholder{color:#9ca3af}.empty-state{background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;padding:3rem 1rem}.empty-icon{color:#d1d5db;margin-bottom:1rem}.empty-state p{margin:.5rem 0}.btn-icon{background:#0000;border:1px solid #0000;border-radius:6px;display:inline-flex;padding:.5rem}.btn-icon.btn-danger{color:#fff}.btn-icon.btn-danger:hover{border-color:#fecaca}.btn-sm{padding:.5rem 1rem}.notes-textarea{border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:.9375rem;padding:.75rem 1rem;resize:vertical;transition:all .2s;width:100%}.notes-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.notes-textarea::placeholder{color:#9ca3af}.form-actions button{align-items:center;display:inline-flex;gap:.5rem}.ob-no-org-warning{align-items:flex-start;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#92400e;display:flex;font-size:.875rem;gap:.5rem;line-height:1.5;padding:.75rem 1rem}.ob-no-org-warning svg{color:#d97706;flex-shrink:0;margin-top:.125rem}.ob-no-org-link{color:#6366f1;cursor:pointer;font-weight:600;text-decoration:underline}.ob-no-org-link:hover{color:#4f46e5}.ob-stats-bar{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.ob-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem 1.5rem}.ob-stat-value{color:#1f2937;font-size:1.875rem;font-weight:700;line-height:1}.ob-stat-label{color:#6b7280;font-size:.8125rem;font-weight:500;margin-top:.375rem}.ob-stat-inprogress .ob-stat-value{color:#3b82f6}.ob-stat-completed .ob-stat-value{color:#10b981}.ob-stat-overdue .ob-stat-value{color:#ef4444}.ob-filters{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.ob-search-wrapper{flex:1 1;min-width:200px;position:relative}.ob-search-icon{color:#9ca3af;left:.75rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.ob-search-input{border:1px solid #d1d5db;border-radius:8px;color:#1f2937;font-size:.9375rem;padding:.625rem .875rem .625rem 2.25rem;transition:all .2s;width:100%}.ob-search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.ob-status-filter{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#1f2937;cursor:pointer;font-size:.9375rem;min-width:160px;padding:.625rem .875rem}.ob-status-filter:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.ob-progress-cell{align-items:center;display:flex;gap:.625rem;min-width:120px}.ob-progress-bar-wrap{background:#f3f4f6;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.ob-progress-bar-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;height:100%;transition:width .3s ease}.ob-progress-label{color:#6b7280;font-size:.75rem;font-weight:600;white-space:nowrap}.ob-status-chip{border-radius:6px;font-size:.75rem;padding:.25rem .625rem}.ob-overdue-badge,.ob-status-chip{align-items:center;display:inline-flex;font-weight:600;white-space:nowrap}.ob-overdue-badge{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:.6875rem;gap:.25rem;padding:.2rem .5rem}.ob-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:28px;justify-content:center;width:28px}.ob-step-count-badge{align-items:center;background:#f3f4f6;border-radius:6px;color:#374151;display:inline-flex;font-size:.8125rem;font-weight:500;padding:.25rem .625rem}.ob-step-status-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.8125rem;padding:.375rem .625rem}.ob-step-status-select:focus{border-color:#667eea;outline:none}.ob-notes-section{border-top:1px solid #e5e7eb;margin-top:1.5rem;padding-top:1rem}.ob-notes-section h4{color:#374151;font-size:.9375rem;font-weight:600;margin:0 0 .75rem}.ob-notes-text{color:#6b7280;font-size:.875rem;line-height:1.6;margin:0;white-space:pre-wrap}.ob-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:500}.ob-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:620px;overflow-y:auto;width:100%}.ob-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.ob-modal-header h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0}.ob-modal-body{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.ob-modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.ob-modal-steps-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem}.ob-modal-steps-header h4{color:#1f2937;font-size:.9375rem;font-weight:600;margin:0}.ob-modal-empty-steps{color:#9ca3af;font-size:.875rem;margin:.5rem 0 0}.ob-checkbox-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.ob-checkbox-label input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:16px;width:16px}@media (max-width:1024px){.onboarding-details{grid-template-columns:1fr}.details-sidebar{position:static}.steps-table-container{overflow-x:scroll}.steps-table{min-width:900px}}@media (max-width:768px){.onboarding-management{padding:1rem}.header-content{align-items:flex-start;flex-direction:column}.ob-stats-bar{grid-template-columns:repeat(2,1fr)}.ob-modal{border-radius:0;max-height:100vh;max-width:100%}.form-grid,.onboardings-grid,.templates-list{grid-template-columns:1fr}.tab-button{font-size:.8125rem;padding:.875rem 1rem}.section-header-with-action{align-items:flex-start;flex-direction:column;gap:1rem}.section-header-with-action .section-header{margin-bottom:0}}.ra-page{margin:0 auto;max-width:1400px;padding:2rem}.ra-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.ra-spinner{animation:ra-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes ra-spin{to{transform:rotate(1turn)}}.ra-alert{align-items:center;border-radius:.75rem;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.75rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.ra-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.ra-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.ra-alert-close{align-items:center;background:#0000;border:none;color:inherit;cursor:pointer;display:flex;margin-left:auto;padding:.25rem}.ra-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.ra-header-left{flex:1 1}.ra-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.ra-breadcrumb-parent{color:#64748b}.ra-breadcrumb-sep{color:#94a3b8}.ra-breadcrumb-active{color:#6366f1;font-weight:500}.ra-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.ra-subtitle{color:#64748b;margin:0}.ra-add-btn,.ra-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.ra-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.ra-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.ra-add-btn:active{transform:translateY(0)}.ra-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.ra-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.ra-stat,.ra-stat-icon{align-items:center;display:flex}.ra-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.ra-stat-icon--blue{background:#eff6ff;color:#2563eb}.ra-stat-icon--green{background:#f0fdf4;color:#16a34a}.ra-stat-icon--yellow{background:#fefce8;color:#ca8a04}.ra-stat-icon--indigo{background:#ede9fe;color:#6366f1}.ra-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.ra-stat-label,.ra-stat-value{font-family:Plus Jakarta Sans,sans-serif}.ra-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.ra-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.ra-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.ra-filters{display:flex;gap:.25rem}.ra-filter-btn{background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s}.ra-filter-btn:hover{background:#f8fafc;color:#334155}.ra-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.ra-toolbar-right{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.ra-search-wrap{align-items:center;display:flex;position:relative}.ra-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.ra-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:200px}.ra-search-input:focus{background:#fff;border-color:#6366f1}.ra-filter-select{-webkit-appearance:none;appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;outline:none;padding:.5rem .75rem;transition:border-color .15s}.ra-filter-select:focus{background:#fff;border-color:#6366f1}.ra-table-wrap{overflow-x:auto}.ra-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.ra-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.ra-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.ra-table tbody tr:last-child{border-bottom:none}.ra-clickable-row{cursor:pointer}.ra-clickable-row:hover{background:#fafbff}.ra-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.ra-employee-cell{gap:.75rem}.ra-avatar,.ra-employee-cell{align-items:center;display:flex}.ra-avatar{background:#dcfce7;border-radius:.5rem;color:#16a34a;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.ra-employee-name{color:#0f172a;font-weight:600}.ra-employee-sub{color:#94a3b8;font-size:.75rem;margin-top:1px}.ra-workload{background:#ede9fe;border-radius:.375rem;color:#7c3aed;display:inline-block;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:600;padding:.2rem .625rem}.ra-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .625rem}.ra-status-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.ra-status--active{background:#f0fdf4;color:#16a34a}.ra-status--planned{background:#fff7ed;color:#c2410c}.ra-status--completed{background:#f1f5f9;color:#64748b}.ra-date-range{color:#64748b;font-size:.8125rem;white-space:nowrap}.ra-row-actions{align-items:center;display:flex;gap:.375rem}.ra-delete-btn,.ra-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.ra-edit-btn{color:#475569}.ra-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.ra-delete-btn{color:#94a3b8}.ra-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.ra-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.ra-empty-cell{padding:3rem 1rem!important}.ra-empty-state{align-items:center;color:#94a3b8;display:flex;flex-direction:column;font-family:Plus Jakarta Sans,sans-serif;gap:.75rem}.ra-empty-state svg{opacity:.35}.ra-empty-state h3{color:#475569;font-size:1rem;font-weight:600;margin:0}.ra-empty-state p{color:#94a3b8;font-size:.875rem;margin:0}.ra-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.ra-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.ra-count strong{color:#0f172a}.ra-pagination{display:flex;gap:.25rem}.ra-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.ra-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.ra-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.ra-page-btn:disabled{cursor:not-allowed;opacity:.4}.of-alert--warning{background:#fffbeb;border:1px solid #fed7aa;border-left:4px solid #f59e0b;color:#b45309}.of-alert--info{background:#eff6ff;border:1px solid #bfdbfe;border-left:4px solid #3b82f6;color:#1e40af}.of-input-with-unit{display:flex;position:relative}.of-input-with-unit .of-input{flex:1 1;padding-right:3.5rem}.of-unit-suffix{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;pointer-events:none;position:absolute;right:1rem;top:50%;transform:translateY(-50%)}@media (max-width:1024px){.ra-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.of-page,.ra-page{padding:1rem}.ra-header{align-items:flex-start;flex-direction:column}.ra-stats{grid-template-columns:repeat(2,1fr)}.ra-toolbar{align-items:flex-start;flex-direction:column}.ra-toolbar-right{flex-wrap:wrap}.of-form-body{padding:1.25rem}.of-form-grid{grid-template-columns:1fr}.of-span-2{grid-column:span 1}.of-tabs-nav{padding:0 1rem}.of-tab{font-size:.8125rem;padding:.75rem .875rem}.of-form-actions{flex-wrap:wrap;padding:1rem 1.25rem}.of-card-header{padding:1.25rem}}@media (prefers-reduced-motion:reduce){.ra-spinner{animation:none}}.pr-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.pr-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.pr-add-btn:active{transform:translateY(0)}.pr-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.pr-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.pr-stat,.pr-stat-icon{align-items:center;display:flex}.pr-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.pr-stat-icon--blue{background:#eff6ff;color:#2563eb}.pr-stat-icon--green{background:#f0fdf4;color:#16a34a}.pr-stat-icon--yellow{background:#fefce8;color:#ca8a04}.pr-stat-icon--indigo{background:#ede9fe;color:#6366f1}.pr-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.pr-stat-label,.pr-stat-value{font-family:Plus Jakarta Sans,sans-serif}.pr-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.pr-filters{display:flex;gap:.25rem}.pr-filter-btn{background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s}.pr-filter-btn:hover{background:#f8fafc;color:#334155}.pr-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.pr-toolbar-right{align-items:center;display:flex;gap:.75rem}.pr-search-wrap{align-items:center;display:flex;position:relative}.pr-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.pr-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.pr-search-input:focus{background:#fff;border-color:#6366f1}.pr-table-wrap{overflow-x:auto}.pr-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.pr-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.pr-table tbody tr:last-child{border-bottom:none}.pr-clickable-row{cursor:pointer}.pr-clickable-row:hover{background:#fafbff}.pr-table td{color:#334155;padding:.875rem 1rem}.pr-client-cell{gap:.75rem}.pr-avatar,.pr-client-cell{align-items:center;display:flex}.pr-avatar{background:#ede9fe;border-radius:.5rem;color:#6366f1;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.pr-client-name{color:#0f172a;font-weight:600}.pr-client-sub{align-items:center;color:#94a3b8;display:flex;font-size:.75rem;gap:.375rem;margin-top:2px}.pr-client-inline{color:#64748b;font-weight:500}.pr-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.2rem .5rem}.pr-muted{color:#94a3b8!important}.pr-dash{color:#cbd5e1}.pr-manager{color:#374151;font-size:.83rem;gap:8px}.pr-manager,.pr-manager-avatar{align-items:center;display:flex}.pr-manager-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:.72rem;font-weight:700;height:28px;justify-content:center;width:28px}.pr-billing-amount{color:#1f2937;font-size:.83rem;font-weight:600;white-space:nowrap}.pr-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .625rem}.pr-status-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.pr-status--active{background:#f0fdf4;color:#16a34a}.pr-status--inactive{background:#fef2f2;color:#dc2626}.pr-status--paused{background:#fff7ed;color:#c2410c}.pr-status--closed{background:#f1f5f9;color:#64748b}.pr-status--completed{background:#ede9fe;color:#6366f1}.pr-row-actions{align-items:center;display:flex;gap:.375rem}.pr-delete-btn,.pr-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.pr-edit-btn{color:#475569}.pr-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.pr-delete-btn{color:#94a3b8}.pr-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.pr-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.pr-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.pr-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.pr-count strong{color:#0f172a}.pr-pagination{display:flex;gap:.25rem}.pr-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.pr-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.pr-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.pr-page-btn:disabled{cursor:not-allowed;opacity:.4}.pr-detail-page{margin:0 auto;max-width:1400px;padding:2rem}.pr-back-btn{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.375rem;margin-bottom:1.5rem;padding:0;transition:color .15s}.pr-back-btn:hover{color:#6366f1}.pr-detail-header-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.75rem 2rem}.pr-detail-header-left{align-items:center;display:flex;flex:1 1;gap:1.25rem}.pr-detail-avatar{align-items:center;background:#ede9fe;border-radius:1rem;color:#6366f1;display:flex;flex-shrink:0;font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;height:68px;justify-content:center;width:68px}.pr-detail-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.pr-detail-name{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0}.pr-detail-name,.pr-detail-status-badge{font-family:Plus Jakarta Sans,sans-serif}.pr-detail-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.6875rem;font-weight:700;gap:.375rem;letter-spacing:.05em;padding:.3rem .75rem}.pr-detail-status-badge--active{background:#dcfce7;color:#15803d}.pr-detail-status-badge--on-hold{background:#fff7ed;color:#c2410c}.pr-detail-status-badge--completed{background:#ede9fe;color:#6366f1}.pr-detail-status-badge--archived{background:#f1f5f9;color:#64748b}.pr-detail-code-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.8125rem;font-weight:600;letter-spacing:.04em;padding:.2rem .625rem}.pr-detail-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.pr-detail-meta-item{align-items:center;color:#64748b;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem}.pr-detail-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.pr-detail-edit-btn{align-items:center;background:#6366f1;border:none;border-radius:.625rem;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s}.pr-detail-edit-btn:hover{background:#4f46e5}.pr-detail-delete-btn{align-items:center;background:#fff;border:1px solid #fecaca;border-radius:.625rem;color:#dc2626;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s,border-color .15s}.pr-detail-delete-btn:hover{background:#fef2f2;border-color:#dc2626}.pr-detail-content-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;margin-bottom:1.5rem;overflow:hidden}.pr-detail-tabs-nav{border-bottom:1px solid #e2e8f0;display:flex;overflow-x:auto;padding:0 1.5rem}.pr-detail-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:1rem 1.25rem;transition:color .15s,border-color .15s;white-space:nowrap}.pr-detail-tab:hover{color:#334155}.pr-detail-tab--active{border-bottom-color:#6366f1;color:#6366f1;font-weight:700}.pr-detail-tab-body{padding:1.75rem 2rem}.pr-detail-field-grid{grid-gap:1.5rem 2rem;display:grid;gap:1.5rem 2rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.pr-detail-label{color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.375rem;text-transform:uppercase}.pr-detail-label,.pr-detail-value{font-family:Plus Jakarta Sans,sans-serif}.pr-detail-value{align-items:center;color:#0f172a;display:flex;font-size:.9375rem;font-weight:600;gap:.375rem}.pr-detail-empty{color:#94a3b8;font-style:italic;font-weight:400}.pr-detail-desc-section{margin-top:.5rem}.pr-detail-desc-box{background:#fafbff;border:1.5px dashed #e2e8f0;border-radius:.625rem;margin-top:.75rem;padding:1.25rem 1.5rem}.pr-detail-desc-text{color:#334155;font-size:.9375rem;line-height:1.6}.pr-detail-desc-empty,.pr-detail-desc-text{font-family:Plus Jakarta Sans,sans-serif;margin:0}.pr-detail-desc-empty{color:#94a3b8;font-size:.875rem;text-align:center}.pr-status-change{border-top:1px solid #f1f5f9;margin-top:1.5rem;padding-top:1.25rem}.pr-status-change-label{color:#94a3b8;display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.6875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.5rem;text-transform:uppercase}.pr-status-select-wrap{position:relative}.pr-status-select-wrap .of-input{padding-right:2rem}.pr-select-chevron{color:#94a3b8;pointer-events:none;position:absolute;right:.7rem;top:50%;transform:translateY(-50%)}.pr-tab-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.pr-tab-header h3{color:#0f172a;font-size:1rem;font-weight:700;margin:0}.pr-tab-add-btn,.pr-tab-header h3{font-family:Plus Jakarta Sans,sans-serif}.pr-tab-add-btn{align-items:center;background:#6366f1;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:600;gap:.375rem;padding:.5rem 1rem;transition:background .15s}.pr-tab-add-btn:hover{background:#4f46e5}.pr-tab-ghost-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:background .15s}.pr-tab-ghost-btn:hover{background:#f8fafc}.pr-ms-form{background:#f5f3ff;border:1px solid #c7d2fe;border-radius:.75rem;margin-bottom:1.25rem;padding:1.25rem 1.5rem}.pr-ms-form h4{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.9375rem;font-weight:700;margin:0 0 1rem}.pr-ms-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.pr-ms-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.pr-ms-list{display:flex;flex-direction:column;gap:.75rem}.pr-ms-item{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;display:flex;gap:1rem;padding:1rem 1.25rem;transition:box-shadow .15s}.pr-ms-item:hover{box-shadow:0 2px 8px #0000000f}.pr-ms-item--done{opacity:.75}.pr-ms-icon{align-items:center;background:#f1f5f9;border-radius:50%;color:#94a3b8;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.pr-ms-item--done .pr-ms-icon{background:#dcfce7;color:#16a34a}.pr-ms-body{flex:1 1;min-width:0}.pr-ms-title{color:#0f172a;font-size:.9375rem;font-weight:600;margin-bottom:.2rem}.pr-ms-desc,.pr-ms-title{font-family:Plus Jakarta Sans,sans-serif}.pr-ms-desc{color:#64748b;font-size:.8125rem;margin-bottom:.25rem}.pr-ms-date{color:#94a3b8;display:flex;font-family:Plus Jakarta Sans,sans-serif;gap:.3rem}.pr-ms-date,.pr-ms-status{align-items:center;font-size:.75rem}.pr-ms-status{border-radius:999px;display:inline-flex;font-weight:600;gap:.375rem;padding:.2rem .625rem}.pr-ms-status--pending{background:#fefce8;color:#ca8a04}.pr-ms-status--completed{background:#dcfce7;color:#16a34a}.pr-ms-actions{display:flex;flex-shrink:0;gap:.375rem}.pr-ms-delete-btn,.pr-ms-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.375rem;cursor:pointer;display:flex;height:28px;justify-content:center;transition:background .15s,color .15s;width:28px}.pr-ms-edit-btn{color:#475569}.pr-ms-edit-btn:hover{background:#f1f5f9;color:#6366f1}.pr-ms-delete-btn{color:#94a3b8}.pr-ms-delete-btn:hover{background:#fef2f2;color:#e11d48}.pr-tab-loading{min-height:120px}.pr-empty-state,.pr-tab-loading{align-items:center;display:flex;justify-content:center}.pr-empty-state{color:#94a3b8;flex-direction:column;font-family:Plus Jakarta Sans,sans-serif;font-size:.9375rem;gap:.75rem;min-height:140px;padding:2rem}.pr-empty-state svg{opacity:.35}.pr-empty-state p{margin:0;text-align:center}.pr-team-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.pr-team-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.625rem 1rem;text-align:left;text-transform:uppercase}.pr-team-table tbody tr{border-bottom:1px solid #f8fafc}.pr-team-table tbody tr:last-child{border-bottom:none}.pr-team-table td{color:#334155;padding:.75rem 1rem;vertical-align:middle}.pr-team-cell{gap:.625rem}.pr-team-avatar,.pr-team-cell{align-items:center;display:flex}.pr-team-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:.8125rem;font-weight:700;height:32px;justify-content:center;overflow:hidden;width:32px}.pr-team-avatar img{height:100%;object-fit:cover;width:100%}.pr-team-name{color:#0f172a;font-weight:600}.pr-files-list{display:flex;flex-direction:column;gap:.75rem}.pr-file-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;display:flex;gap:1rem;padding:.875rem 1.25rem}.pr-file-icon{color:#6366f1;flex-shrink:0}.pr-file-info{flex:1 1;min-width:0}.pr-file-name{color:#0f172a;font-size:.9375rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pr-file-meta,.pr-file-name{font-family:Plus Jakarta Sans,sans-serif}.pr-file-meta{color:#94a3b8;font-size:.75rem;margin-top:.15rem}.pr-file-actions{align-items:center;display:flex;flex-shrink:0;gap:.375rem}.pr-download-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.4rem .875rem;text-decoration:none;transition:background .15s}.pr-download-btn:hover{background:#f8fafc}.pr-detail-footer{align-items:center;display:flex;justify-content:space-between;padding:.875rem 0}.pr-detail-footer-meta{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem}.of-code-group{align-items:stretch;display:flex}.of-code-input{border-radius:.5rem 0 0 .5rem!important;border-right:none!important;flex:1 1}.of-generate-btn{align-items:center;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:0 .5rem .5rem 0;color:#6d28d9;cursor:pointer;display:inline-flex;flex-shrink:0;font-family:inherit;font-size:.8rem;font-weight:600;gap:.3rem;height:2.75rem;padding:0 .875rem;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.of-generate-btn:hover{background:#6d28d9;border-color:#6d28d9;color:#fff}.of-checkbox-label{align-items:center;color:#374151;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.5rem;-webkit-user-select:none;user-select:none}.of-checkbox-label input[type=checkbox]{accent-color:#6366f1;cursor:pointer;height:16px;width:16px}@media (max-width:1024px){.pr-detail-field-grid,.pr-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.of-page,.pr-detail-page,.pr-page{padding:1rem}.pr-header{align-items:flex-start;flex-direction:column}.pr-stats{grid-template-columns:repeat(2,1fr)}.pr-toolbar{align-items:flex-start;flex-direction:column}.pr-detail-field-grid{grid-template-columns:1fr}.pr-detail-header-card{flex-direction:column}.pr-ms-form-grid{grid-template-columns:1fr}.of-form-body{padding:1.25rem}.of-form-grid{grid-template-columns:1fr}.of-span-2{grid-column:span 1}.of-tabs-nav{padding:0 1rem}.of-tab{font-size:.8125rem;padding:.75rem .875rem}.of-form-actions{flex-wrap:wrap;padding:1rem 1.25rem}.of-card-header{padding:1.25rem}}@media (prefers-reduced-motion:reduce){.pr-spinner{animation:none}}.pr-billing-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(min(160px,100%),1fr));margin-bottom:1.5rem}.pr-billing-stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1rem 1.25rem}.pr-billing-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.35rem;text-transform:uppercase}.pr-billing-stat-value{color:#0f172a;font-size:1.2rem;font-weight:800}.pr-billing-stat-value--paid{color:#16a34a}.pr-billing-stat-value--invoiced{color:#2563eb}.pr-billing-stat-value--pending{color:#d97706}.pr-billing-stat-value--remaining{color:#6366f1}.pr-billing-stat-value--over{color:#dc2626}.pr-billing-progress-section{margin-bottom:1.5rem}.pr-billing-progress-labels{color:#64748b;display:flex;font-size:.75rem;justify-content:space-between;margin-bottom:.4rem}.pr-billing-progress-track{background:#e2e8f0;border-radius:5px;display:flex;height:10px;overflow:hidden}.pr-billing-progress-paid{background:#16a34a;height:100%;transition:width .3s ease}.pr-billing-progress-invoiced{background:#93c5fd;height:100%;transition:width .3s ease}.pr-co-section{margin-top:1.5rem}.pr-co-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.875rem}.pr-co-title{color:var(--gray-800);font-size:.9375rem;font-weight:600;margin:0 0 .125rem}.pr-co-subtitle{color:var(--gray-500);font-size:.8125rem;margin:0}.pr-co-empty{color:var(--gray-400);font-size:.8125rem;margin:0;padding:.75rem 0}.pr-co-form{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;margin-bottom:1rem;padding:1rem}.pr-co-form-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.pr-co-field{display:flex;flex-direction:column;gap:.25rem}.pr-co-field--wide{grid-column:span 2}.pr-co-field--check{justify-content:flex-end}.pr-co-field label{color:var(--gray-600);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.pr-co-input{background:#fff;border:1px solid var(--gray-300);border-radius:6px;font-family:inherit;font-size:.875rem;padding:.5rem .75rem}.pr-co-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126;outline:none}.pr-co-check-label{align-items:center;color:var(--gray-700);cursor:pointer;display:flex;font-size:.875rem;font-weight:400;gap:.5rem;letter-spacing:0;text-transform:none}.pr-co-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.75rem}.pr-co-list{display:flex;flex-direction:column;gap:.5rem}.pr-co-item{align-items:center;border:1px solid;border-radius:8px;display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.pr-co-item--approved{background:#f0fdf4;border-color:#bbf7d0}.pr-co-item--pending{background:#fffbeb;border-color:#fde68a}.pr-co-item-main{align-items:center;display:flex;flex-wrap:wrap;gap:.625rem;min-width:0}.pr-co-badge{border-radius:4px;font-size:.6875rem;font-weight:700;padding:.125rem .4rem;white-space:nowrap}.pr-co-badge--approved{background:#d1fae5;color:#065f46}.pr-co-badge--pending{background:#fef3c7;color:#92650a}.pr-co-item-title{color:var(--gray-800);font-size:.875rem;font-weight:500}.pr-co-item-desc{color:var(--gray-500);font-size:.8125rem}.pr-co-item-right{align-items:center;display:flex;flex-shrink:0;gap:.875rem}.pr-co-item-amount{color:#16a34a;font-size:.9375rem;font-weight:700}.pr-co-item-date{color:var(--gray-400);font-size:.8125rem}.pr-co-item-actions{display:flex;gap:.25rem}.pr-co-action-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;opacity:.7;padding:.25rem}.pr-co-action-btn:hover{background:var(--gray-100);opacity:1}.pr-co-action-btn--del:hover{background:#fee2e2}.pr-inv-context{color:var(--gray-400);font-size:.7rem;margin-top:.2rem}.pr-bal-due{color:#dc2626;font-weight:600}.pr-inv-type{background:var(--gray-100);border-radius:4px;color:var(--gray-600);display:inline-block;font-size:.6875rem;font-weight:600;letter-spacing:.02em;padding:.125rem .4rem}.pr-inv-type--advance{background:#fff3cd;color:#92650a}.pr-inv-type--milestone{background:#e0e7ff;color:#3730a3}.pr-inv-type--final{background:#d1fae5;color:#065f46}@media (prefers-reduced-motion:reduce){.pr-billing-progress-invoiced,.pr-billing-progress-paid{transition:none}}.tc-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 2px #0000000a;cursor:pointer;padding:10px 12px 10px 11px;position:relative;transition:box-shadow .15s ease,transform .15s ease}.tc-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.tc-locked{cursor:not-allowed;opacity:.55}.tc-title{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#1a202c;display:-webkit-box;font-size:.875rem;font-weight:500;line-height:1.45;margin:0 0 8px;overflow:hidden}.tc-date{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;color:#718096;display:inline-flex;font-size:.7rem;gap:4px;margin-bottom:10px;padding:2px 7px}.tc-date-icon{color:#a0aec0;flex-shrink:0}.tc-footer{align-items:center;display:flex;justify-content:space-between}.tc-key{align-items:center;color:#718096;display:inline-flex;font-family:Courier New,monospace;font-size:.7rem;font-weight:600;gap:5px}.tc-type-icon{flex-shrink:0}.tc-type-task{color:#3182ce}.tc-type-bug{color:#e53e3e}.tc-type-story{color:#805ad5}.tc-type-subtask{color:#718096}.tc-avatar{align-items:center;border:1.5px solid #fff;border-radius:50%;box-shadow:0 1px 3px #00000026;color:#fff;display:flex;flex-shrink:0;font-size:.62rem;font-weight:700;height:24px;justify-content:center;width:24px}.tc-actions{background:#fffffff5;border-radius:4px;box-shadow:0 2px 6px #0000001a;display:none;gap:2px;padding:2px 3px;position:absolute;right:6px;top:6px}.tc-card:hover .tc-actions{display:flex}.tc-action-btn{align-items:center;background:#0000;border:none;border-radius:3px;color:#718096;cursor:pointer;display:flex;padding:3px 5px;transition:background .15s,color .15s}.tc-action-btn:hover{background:#edf2f7;color:#2d3748}.tc-action-danger:hover{background:#fff5f5;color:#e53e3e}@media (max-width:768px){.tc-card{padding:8px 10px 8px 9px}.tc-actions{background:#0000;border-top:1px solid #edf2f7;box-shadow:none;display:flex;margin-top:8px;padding:6px 0 0;position:static}}@media (prefers-reduced-motion:reduce){.tc-card{transition:none}}.task-board{align-items:flex-start;display:flex;gap:12px;min-height:600px;overflow-x:auto;padding:4px 0 16px}.board-column{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;flex-shrink:0;max-height:calc(100vh - 240px);min-width:272px;width:272px}.column-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;padding:10px 12px}.column-title{color:#4a5568;flex:1 1;font-size:.78rem;font-weight:700;letter-spacing:.6px;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.column-header-right{align-items:center;display:flex;flex-shrink:0;gap:4px}.column-count{background:#edf2f7;border-radius:10px;color:#718096;font-size:.75rem;font-weight:600;min-width:22px;padding:1px 7px;text-align:center}.col-icon-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#a0aec0;cursor:pointer;display:flex;padding:3px 4px;transition:background .15s,color .15s}.col-icon-btn:hover{background:#edf2f7;color:#4a5568}.col-menu-wrap{position:relative}.col-menu-trigger{opacity:0;transition:opacity .15s}.board-column:hover .col-menu-trigger,.col-menu-trigger:focus{opacity:1}.col-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 16px #0000001a;min-width:140px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:600;z-index:var(--z-popover,600)}.col-dropdown-item{align-items:center;background:#0000;border:none;color:#4a5568;cursor:pointer;display:flex;font-size:.82rem;font-weight:500;gap:8px;padding:8px 14px;text-align:left;transition:background .12s;width:100%}.col-dropdown-item:hover{background:#f7fafc}.col-dropdown-danger{color:#e53e3e}.col-dropdown-danger:hover{background:#fff5f5}.column-edit-form{align-items:center;display:flex;flex:1 1;gap:4px}.column-edit-form input{border:1.5px solid #667eea;border-radius:4px;color:#4a5568;flex:1 1;font-size:.78rem;font-weight:700;letter-spacing:.5px;outline:none;padding:3px 8px;text-transform:uppercase}.column-content{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-x:hidden;overflow-y:auto;padding:10px}.column-content::-webkit-scrollbar{width:5px}.column-content::-webkit-scrollbar-track{background:#0000}.column-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.column-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}.inline-create-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:.82rem;font-weight:500;gap:6px;padding:5px 4px;transition:background .15s,color .15s;width:100%}.inline-create-btn:hover{background:#edf2f7;color:#2d3748}.inline-create-form{background:#fff;border-radius:6px;box-shadow:0 0 0 2px #667eea;padding:8px}.inline-create-form textarea{border:none;box-sizing:border-box;color:#1a202c;font-family:inherit;font-size:.875rem;margin-bottom:4px;min-height:52px;outline:none;resize:none;width:100%}.create-hint{color:#a0aec0;display:block;font-size:.68rem;text-align:right}.draggable-task{cursor:grab}.draggable-task:active{cursor:grabbing;opacity:.75}.board-column.drag-over{background:#ebf4ff;border-color:#667eea}.add-column-wrap{align-items:flex-start;display:flex;flex-direction:column;flex-shrink:0;padding-top:2px}.add-column-btn{align-items:center;background:#0000;border:1.5px dashed #cbd5e0;border-radius:8px;color:#a0aec0;cursor:pointer;display:flex;height:36px;justify-content:center;transition:border-color .15s,color .15s,background .15s;width:36px}.add-column-btn:hover{background:#ebf4ff;border-color:#667eea;color:#667eea}.add-column-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:10px;width:240px}.add-column-form input{border:1.5px solid #667eea;border-radius:5px;font-size:.875rem;outline:none;padding:6px 10px}.add-col-actions{align-items:center;display:flex;gap:6px}@media (max-width:768px){.task-board{align-items:stretch;flex-direction:column}.board-column{max-height:420px;min-width:auto;width:100%}}@media (prefers-reduced-motion:reduce){.col-icon-btn,.inline-create-btn,.tc-card{transition:none}}.task-detail-overlay{align-items:center;background-color:#091e428a;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.task-detail-modal{background:#fff;border-radius:3px;box-shadow:0 0 0 1px #091e4214,0 2px 4px #091e4214,0 8px 16px #091e4221;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;position:relative;width:100%}.modal-close{background:#0000;border-radius:3px;color:#6b778c;font-size:24px;padding:8px;position:absolute;right:16px;top:16px;z-index:10}.modal-close:hover{background-color:#ebecf0;color:#172b4d}.modal-content{flex:1 1}.modal-main{flex:1 1;min-width:0;overflow-y:auto;padding:40px 48px}.task-header{margin-bottom:16px}.task-key-type{align-items:center;color:#5e6c84;display:flex;font-size:14px;gap:8px}.task-type-icon{font-size:16px}.task-key-text{color:#172b4d;font-weight:600}.task-title{color:#172b4d;font-size:24px;font-weight:500;line-height:1.3;margin:0 0 24px}.task-section{margin-bottom:32px}.task-section h3{color:#5e6c84;font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.task-description{background-color:#f4f5f7;border-radius:3px;color:#172b4d;line-height:1.6;min-height:60px;padding:12px 16px}.task-description em{color:#6b778c}.comment-box{margin-bottom:24px}.comment-input-wrapper{background:#fff;border:2px solid #dfe1e6;border-radius:3px;transition:border-color .2s}.comment-input-wrapper:focus-within{border-color:#0052cc}.comment-input{border:none;color:#172b4d;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;outline:none;padding:12px;resize:vertical;width:100%}.comment-actions{background-color:#fafbfc;border-top:1px solid #dfe1e6;display:flex;gap:8px;padding:8px 12px}.comments-list{margin-top:24px}.no-comments{color:#6b778c;font-style:italic;padding:32px;text-align:center}.comment{display:flex;gap:12px;margin-bottom:20px}.comment.reply{margin-left:40px;margin-top:12px}.comment-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.comment-content{flex:1 1;min-width:0}.comment-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.comment-author{color:#172b4d;font-size:14px;font-weight:600}.comment-time{color:#6b778c;font-size:12px}.comment-edited{color:#6b778c;font-size:11px;font-style:italic}.comment-text{word-wrap:break-word;color:#172b4d;line-height:1.6;margin-bottom:8px}.comment-footer{display:flex;gap:12px}.comment-link{background:none;border:none;color:#6b778c;cursor:pointer;font-size:12px;font-weight:500;padding:4px 0;transition:color .2s}.comment-link:hover{color:#172b4d;text-decoration:underline}.comment-link.comment-delete:hover{color:#de350b}.comment-edit{margin-bottom:12px}.reply-box{background-color:#f4f5f7;border-radius:3px;padding:12px}.replies,.reply-box{margin-top:12px}.modal-sidebar{background-color:#f4f5f7;border-left:1px solid #dfe1e6;flex-shrink:0;overflow-y:auto;padding:24px;width:280px}.detail-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.detail-field{margin-bottom:20px}.detail-field label{color:#5e6c84;display:block;font-size:12px;font-weight:600;letter-spacing:.3px;margin-bottom:8px;text-transform:uppercase}.detail-value{color:#172b4d;font-size:14px}.detail-date{color:#6b778c}.status-badge{border-radius:3px;letter-spacing:.3px}.priority-badge{font-size:14px;gap:6px}.priority-badge,.user-info{align-items:center;display:flex}.user-info{gap:8px}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:10px;font-weight:600;height:24px;justify-content:center;width:24px}.unassigned{color:#6b778c;font-style:italic}.btn{border-radius:3px;font-family:inherit;padding:8px 12px}.btn-primary{background-color:#0052cc}.btn-primary:hover:not(:disabled){background-color:#0065ff}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background-color:#ebecf0;color:#42526e}.btn-secondary:hover{background-color:#dfe1e6}.btn-danger{background-color:#de350b}.btn-danger:hover{background-color:#ff5630}.btn-sm{font-size:13px;padding:6px 12px}.alert{border-radius:3px;margin-bottom:16px}.alert-error{background-color:#ffebe6;border-left:3px solid #de350b;color:#bf2600}.loading{color:#6b778c;padding:20px}@media (max-width:768px){.task-detail-modal{border-radius:0;max-height:100vh}.modal-content{flex-direction:column}.modal-main{padding:24px 16px}.modal-sidebar{border-left:none;border-top:1px solid #dfe1e6;width:100%}.task-title{font-size:20px}.comment.reply{margin-left:20px}}.task-modal-overlay{align-items:flex-start;background-color:#091e428a;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding-top:60px;position:fixed;right:0;top:0;z-index:1000}.task-modal{background:#fff;border-radius:3px;box-shadow:0 8px 16px -4px #091e4240,0 0 1px #091e424f;color:#172b4d;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin-bottom:60px;max-height:calc(100vh - 120px);max-width:800px;width:100%}.task-modal-header{align-items:center;border-bottom:2px solid #ebecf0;display:flex;justify-content:space-between;padding:20px 24px}.task-modal-header h2{color:#172b4d;font-size:20px;font-weight:500;line-height:1.2;margin:0}.modal-close-btn{align-items:center;background:#0000;border:none;border-radius:3px;color:#42526e;cursor:pointer;display:flex;font-size:20px;justify-content:center;padding:4px;transition:background-color .1s}.modal-close-btn:hover{background-color:#091e4214}.task-modal-content{flex-grow:1;overflow-y:auto;padding:24px}.jira-form{display:flex;flex-direction:column;gap:20px}.jira-form-row{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.jira-form-group{display:flex;flex-direction:column;gap:6px}.jira-form-group label{color:#5e6c84;font-size:12px;font-weight:600;margin-bottom:0}.jira-form-group input[type=number],.jira-form-group input[type=text],.jira-form-group select,.jira-form-group textarea{background-color:#f4f5f7;border:2px solid #0000;border-radius:3px;box-sizing:border-box;color:#172b4d;font-family:inherit;font-size:14px;padding:8px 12px;transition:background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.jira-form-group input[type=number]:hover,.jira-form-group input[type=text]:hover,.jira-form-group select:hover,.jira-form-group textarea:hover{background-color:#ebecf0}.jira-form-group input[type=number]:focus,.jira-form-group input[type=text]:focus,.jira-form-group select:focus,.jira-form-group textarea:focus{background-color:#fff;border-color:#4c9aff;outline:none}.jira-form-group select:disabled{background-color:#fafbfc;color:#a5adba;cursor:not-allowed}.jira-form-group textarea{line-height:1.4;min-height:120px;resize:vertical}.field-hint{color:#5e6c84;font-size:11px;margin-top:4px}.required-asterisk{color:#de350b;margin-left:2px}.task-modal-footer{background:#fff;border-radius:0 0 3px 3px;border-top:2px solid #ebecf0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.jira-btn{align-items:center;border:none;border-radius:3px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;height:32px;justify-content:center;padding:0 12px;transition:background-color .1s ease-out,box-shadow .1s ease-out,color .1s ease-out}.jira-btn-primary{background-color:#0052cc;color:#fff}.jira-btn-primary:hover{background-color:#0047b3}.jira-btn-primary:active{background-color:#003e99}.jira-btn-primary:disabled{background-color:#091e420a;color:#a5adba;cursor:not-allowed}.jira-btn-link{background-color:initial;color:#0052cc}.jira-btn-link:hover{background-color:#0052cc14;text-decoration:none}.jira-btn-link:active{background-color:#0052cc29}.select-with-icon{position:relative}@media (max-width:850px){.task-modal{margin:20px;width:calc(100% - 40px)}}@media (max-width:600px){.jira-form-row{gap:20px;grid-template-columns:1fr}}.sp-overlay{align-items:flex-start;background:#00000073;display:flex;inset:0;justify-content:flex-end;padding:0;position:fixed;z-index:var(--z-overlay)}.sp-panel{animation:sp-slide-in .22s ease;background:#fff;background:var(--white,#fff);box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;height:100dvh;max-width:100vw;overflow:hidden;width:420px}@keyframes sp-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (prefers-reduced-motion:reduce){.sp-panel{animation:none}}.sp-header{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100,#f1f5f9);flex-shrink:0;justify-content:space-between;padding:20px 20px 16px}.sp-header,.sp-header-info{align-items:center;display:flex}.sp-header-info{gap:10px}.sp-header-icon{color:#6366f1;color:var(--primary,#6366f1)}.sp-title{color:#0f172a;color:var(--gray-900,#0f172a);font-size:1rem;font-size:var(--text-base,1rem);font-weight:600;line-height:1.3;margin:0}.sp-subtitle{color:#64748b;color:var(--gray-500,#64748b);font-size:.75rem;font-size:var(--text-xs,.75rem);margin:2px 0 0}.sp-close{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;color:var(--gray-400,#94a3b8);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:background .15s,color .15s}.sp-close:hover{background:#f1f5f9;background:var(--gray-100,#f1f5f9);color:#334155;color:var(--gray-700,#334155)}.sp-error{flex-shrink:0;margin:0 20px}.sp-add-section{flex-shrink:0;padding:16px 20px 0}.sp-add-toggle{align-items:center;background:#f8fafc;background:var(--gray-50,#f8fafc);border:1.5px dashed #e2e8f0;border:1.5px dashed var(--gray-200,#e2e8f0);border-radius:8px;color:#6366f1;color:var(--primary,#6366f1);cursor:pointer;display:flex;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500;gap:7px;padding:9px 14px;transition:background .15s,border-color .15s;width:100%}.sp-add-toggle:hover{background:#eef2ff;background:var(--primary-light,#eef2ff);border-color:#6366f1;border-color:var(--primary,#6366f1)}.sp-add-form{background:#f8fafc;background:var(--gray-50,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--gray-200,#e2e8f0);border-radius:10px;display:flex;flex-direction:column;gap:10px;padding:14px}.sp-add-form-top{align-items:flex-start;display:flex;gap:8px}.sp-add-search-wrap{flex:1 1;position:relative}.sp-add-search{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--gray-200,#e2e8f0);border-radius:7px;box-sizing:border-box;color:#1e293b;color:var(--gray-800,#1e293b);font-size:.875rem;font-size:var(--text-sm,.875rem);outline:none;padding:8px 12px;width:100%}.sp-add-search:focus{border-color:#6366f1;border-color:var(--primary,#6366f1);box-shadow:0 0 0 3px #6366f11a}.sp-suggestions{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--gray-200,#e2e8f0);border-radius:8px;box-shadow:0 4px 16px #0000001a;left:0;max-height:220px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:10}.sp-suggestion{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:10px;padding:9px 12px;text-align:left;transition:background .1s;width:100%}.sp-suggestion:hover{background:#f8fafc;background:var(--gray-50,#f8fafc)}.sp-suggestion-info{display:flex;flex-direction:column;gap:1px}.sp-suggestion-name{color:#1e293b;color:var(--gray-800,#1e293b);font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500}.sp-suggestion-meta{color:#94a3b8;color:var(--gray-400,#94a3b8);font-size:11px}.sp-add-form-actions{display:flex;gap:8px;justify-content:flex-end}.sp-role-dropdown{position:relative}.sp-role-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--gray-200,#e2e8f0);border-radius:7px;color:#334155;color:var(--gray-700,#334155);cursor:pointer;display:flex;font-size:.875rem;font-size:var(--text-sm,.875rem);gap:4px;padding:7px 10px;transition:border-color .15s,background .15s;white-space:nowrap}.sp-role-btn:hover:not(:disabled){background:#eef2ff;background:var(--primary-light,#eef2ff);border-color:#6366f1;border-color:var(--primary,#6366f1)}.sp-role-btn:disabled{cursor:default;opacity:.7}.sp-role-chevron{color:#94a3b8;color:var(--gray-400,#94a3b8)}.sp-role-menu{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--gray-200,#e2e8f0);border-radius:10px;box-shadow:0 4px 20px #0000001f;padding:4px;position:absolute;right:0;top:calc(100% + 4px);width:210px;z-index:20}.sp-role-option{align-items:flex-start;background:none;border:none;border-radius:7px;cursor:pointer;display:flex;gap:10px;padding:9px 10px;text-align:left;transition:background .1s;width:100%}.sp-role-option:hover{background:#f8fafc;background:var(--gray-50,#f8fafc)}.sp-role-option-active{background:#eef2ff;background:var(--primary-light,#eef2ff)}.sp-role-option-icon{color:#6366f1;color:var(--primary,#6366f1);flex-shrink:0;margin-top:1px}.sp-role-option-text{display:flex;flex-direction:column;gap:1px}.sp-role-option-label{color:#1e293b;color:var(--gray-800,#1e293b);font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500}.sp-role-option-desc{color:#94a3b8;color:var(--gray-400,#94a3b8);font-size:11px}.sp-members{flex:1 1;overflow-y:auto;padding:16px 20px 20px}.sp-members-count{color:#94a3b8;color:var(--gray-400,#94a3b8);font-size:.75rem;font-size:var(--text-xs,.75rem);font-weight:600;letter-spacing:.05em;margin-bottom:10px;text-transform:uppercase}.sp-member{align-items:center;border-bottom:1px solid #f8fafc;border-bottom:1px solid var(--gray-50,#f8fafc);display:flex;gap:12px;padding:10px 0}.sp-member:last-child{border-bottom:none}.sp-member-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.sp-member-name{color:#1e293b;color:var(--gray-800,#1e293b);font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500}.sp-member-meta,.sp-member-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sp-member-meta{color:#94a3b8;color:var(--gray-400,#94a3b8);font-size:11px}.sp-member-actions{align-items:center;display:flex;flex-shrink:0;gap:6px}.sp-avatar{border-radius:50%;flex-shrink:0;object-fit:cover}.sp-avatar-initials{color:#fff;font-weight:600;letter-spacing:.02em}.sp-avatar-initials,.sp-remove-btn{align-items:center;display:flex;justify-content:center}.sp-remove-btn{background:none;border:none;border-radius:5px;color:#cbd5e1;color:var(--gray-300,#cbd5e1);cursor:pointer;padding:5px;transition:color .15s,background .15s}.sp-remove-btn:hover:not(:disabled){background:#e53e3e14;color:#e53e3e;color:var(--danger,#e53e3e)}.sp-remove-btn:disabled{cursor:default;opacity:.4}.sp-empty{align-items:center;color:#cbd5e1;color:var(--gray-300,#cbd5e1);display:flex;flex-direction:column;gap:10px;padding:40px 0;text-align:center}.sp-empty p{color:#94a3b8;color:var(--gray-400,#94a3b8);font-size:.875rem;font-size:var(--text-sm,.875rem);line-height:1.5;max-width:260px}@media (max-width:768px){.sp-panel{width:100vw}}.tasks-page{height:calc(100vh - 64px);height:calc(100vh - var(--navbar-height, 64px))}.spaces-panel,.tasks-page{display:flex;overflow:hidden}.spaces-panel{background:#f8fafc;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;min-width:230px;width:230px}.spaces-panel-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 14px 10px}.spaces-panel-title{color:#718096;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.spaces-panel-add{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:5px;color:#718096;cursor:pointer;display:flex;height:22px;justify-content:center;padding:0;transition:background .15s,color .15s;width:22px}.spaces-panel-add:hover{background:#667eea;border-color:#667eea;color:#fff}.spaces-panel-search{flex-shrink:0;padding:0 10px 8px;position:relative}.spaces-search-icon{color:#a0aec0;left:18px;pointer-events:none;position:absolute;top:50%;transform:translateY(-60%)}.spaces-search-input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-sizing:border-box;color:#2d3748;font-family:inherit;font-size:.8rem;outline:none;padding:5px 8px 5px 26px;transition:border-color .15s;width:100%}.spaces-search-input:focus{border-color:#667eea}.spaces-search-input::placeholder{color:#c5cbd8}.spaces-nav{flex:1 1;overflow-y:auto;padding:4px 8px 12px}.spaces-nav::-webkit-scrollbar{width:4px}.spaces-nav::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:2px}.spaces-nav-empty,.spaces-nav-loading{color:#a0aec0;font-size:.78rem;padding:20px 10px;text-align:center}.spaces-nav-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:7px 8px;position:relative;transition:background .12s}.spaces-nav-item:hover{background:#edf2f7}.spaces-nav-item:hover .spaces-nav-edit{opacity:1}.spaces-nav-item-active{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff}.spaces-nav-item-active .spaces-nav-code,.spaces-nav-item-active .spaces-nav-name{color:#fff!important}.spaces-nav-item-active .spaces-nav-dot{border:1.5px solid #ffffff80}.spaces-nav-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.spaces-nav-code{color:#4a5568;font-size:.72rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.spaces-nav-name{color:#718096;font-size:.75rem;line-height:1.2}.spaces-nav-edit{align-items:center;background:#0000;border:none;border-radius:4px;color:#a0aec0;cursor:pointer;display:flex;flex-shrink:0;opacity:0;padding:3px;transition:background .12s,color .12s,opacity .12s}.spaces-nav-edit:hover{background:#00000014;color:#fff}.spaces-nav-item-active .spaces-nav-edit{color:#ffffffb3}.spaces-board-area{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.spaces-welcome{align-items:center;color:#a0aec0;display:flex;flex:1 1;flex-direction:column;gap:12px;justify-content:center;padding:40px;text-align:center}.spaces-welcome-icon{color:#cbd5e0}.spaces-welcome h2{color:#4a5568;font-size:1.1rem;font-weight:600;margin:0}.spaces-welcome p{font-size:.875rem;margin:0}.space-board-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px 10px}.space-board-header-actions{align-items:center;display:flex;gap:8px}.space-board-title-wrap{align-items:center;display:flex;gap:10px}.space-board-color-dot{border-radius:3px;flex-shrink:0;height:12px;width:12px}.space-board-title{color:#1a202c;font-size:1.1rem;font-weight:700;letter-spacing:-.01em;line-height:1.3;margin:0}.space-board-client{color:#718096;display:block;font-size:.75rem;margin-top:1px}.spaces-board-area .task-controls{flex-shrink:0;margin:10px 20px}.spaces-board-area .task-board{flex:1 1;overflow-x:auto;padding:0 20px 16px}.spaces-board-scroll{flex:1 1;overflow:auto;padding:0 20px 16px}.spaces-board-area>.task-list{flex:1 1;margin:0 20px;overflow-y:auto}@media (max-width:768px){.tasks-page{flex-direction:column;height:auto;overflow:visible}.spaces-panel{border-bottom:1px solid #e2e8f0;border-right:none;max-height:280px;min-width:0;width:100%}.spaces-board-area{overflow:visible}}.spaces-section-label{align-items:center;color:#a0aec0;display:flex;font-size:.68rem;font-weight:700;gap:5px;letter-spacing:.06em;padding:6px 8px 3px;text-transform:uppercase;-webkit-user-select:none;user-select:none}.spaces-client-group{margin-bottom:2px}.spaces-client-header{align-items:center;background:none;border:none;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.72rem;font-weight:700;gap:6px;letter-spacing:.05em;padding:5px 8px 5px 10px;text-align:left;text-transform:uppercase;transition:background .12s;width:100%}.spaces-client-header:hover{background:#f1f5f9}.spaces-client-chevron{color:#94a3b8;display:inline-block;font-size:.75rem;line-height:1;transition:transform .15s}.spaces-client-chevron.collapsed{transform:rotate(-90deg)}.spaces-client-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spaces-client-count{background:#e2e8f0;border-radius:8px;color:#64748b;font-size:.65rem;font-weight:600;min-width:16px;padding:1px 5px;text-align:center}.spaces-client-items{padding-left:8px}.spaces-nav-type-pill{color:#d97706;flex-shrink:0;font-size:.65rem;font-weight:700}.spaces-nav-icon{align-items:center;border-radius:6px;display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.spaces-nav-icon-project{background:#dbeafe;color:#2563eb}.spaces-nav-icon-sub{background:#ede9fe;color:#7c3aed}.spaces-nav-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.spaces-nav-name{color:#1e293b;font-size:.78rem;font-weight:600;line-height:1.3}.spaces-nav-code,.spaces-nav-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spaces-nav-code{color:#94a3b8;font-size:.68rem;font-weight:500;line-height:1.2}.spaces-nav-item-active .spaces-nav-name{color:#6366f1}.spaces-nav-dot-sub{border-radius:3px!important}.sub-resolver{display:flex;flex-direction:column;gap:16px;padding:24px 24px 16px}.sub-resolver-header{align-items:flex-start;display:flex;gap:12px}.sub-resolver-icon{color:#667eea;flex-shrink:0;margin-top:3px}.sub-resolver-title{color:#1a202c;font-size:1.1rem;font-weight:700;margin:0}.sub-plan{color:#4a5568;font-weight:400}.sub-resolver-client{color:#718096;display:block;font-size:.8rem;margin-top:2px}.sub-resolver-hint{color:#718096;font-size:.85rem;margin:0}.sub-project-list{display:flex;flex-direction:column;gap:8px;max-width:480px}.sub-project-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:box-shadow .15s,border-color .15s}.sub-project-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.sub-project-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.sub-project-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.sub-project-code{color:#4a5568;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sub-project-name{color:#1a202c;font-size:.875rem;font-weight:500}.sub-project-arrow{color:#a0aec0;font-size:1.1rem}.sub-project-new-task{align-items:center;background:#6366f1;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:600;gap:4px;padding:5px 10px;transition:background .15s;white-space:nowrap}.sub-project-new-task:hover{background:#4f46e5}.add-work-overlay{align-items:center;animation:fadeIn .15s ease;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:500;z-index:var(--z-modal,500)}.add-work-modal{animation:slideUp .18s ease;background:#fff;border-radius:14px;box-shadow:0 20px 60px #0000002e;max-width:calc(100vw - 32px);padding:28px;width:420px}.add-work-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.add-work-title{color:#1a202c;font-size:1.15rem;font-weight:700;margin:0 0 4px}.add-work-sub{color:#718096;font-size:.82rem;margin:0}.add-work-close{align-items:center;background:#0000;border:none;border-radius:6px;color:#a0aec0;cursor:pointer;display:flex;flex-shrink:0;padding:4px;transition:background .15s,color .15s}.add-work-close:hover{background:#f1f5f9;color:#4a5568}.add-work-options{display:flex;flex-direction:column;gap:10px}.add-work-option{align-items:flex-start;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;cursor:pointer;display:flex;gap:14px;padding:16px;text-align:left;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}.add-work-option:hover{background:#fafbff;border-color:#667eea;box-shadow:0 2px 12px #667eea1f}.add-work-option-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.add-work-icon-project{background:#ebf4ff;color:#3182ce}.add-work-icon-recurring{background:#f3eeff;color:#805ad5}.add-work-option-text{display:flex;flex-direction:column;gap:4px}.add-work-option-title{color:#1a202c;font-size:.95rem;font-weight:600}.add-work-option-desc{color:#718096;font-size:.8rem;line-height:1.45}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.add-work-modal,.add-work-overlay{animation:none}}.task-management{margin:0 auto;max-width:1600px;padding:2rem}.header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.header h1{color:#1a202c;font-size:1.4rem;font-weight:700;letter-spacing:-.01em;margin:0}.header-actions{gap:1rem}.alert{border-radius:4px;margin-bottom:1.5rem;padding:1rem}.alert-error{background-color:#fee;border:1px solid #fcc;color:#c33}.alert-success{background-color:#efe;border:1px solid #cfc;color:#3c3}.btn{border-radius:4px;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.btn-primary{background-color:#007bff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-sm{font-size:.875rem;padding:.4rem .8rem}.btn-edit{background-color:#28a745;color:#fff}.btn-edit:hover{background-color:#218838}.btn-edit:disabled{background-color:#94d3a2;cursor:not-allowed}.btn-delete{background-color:#dc3545;color:#fff}.btn-delete:hover{background-color:#c82333}.btn-delete:disabled{background-color:#f5b7bd;cursor:not-allowed}.task-controls{background:#fff;border:1px solid #e2e8f0;border-radius:8px;gap:.75rem;justify-content:space-between;margin-bottom:1.25rem;padding:8px 12px}.task-controls,.task-filters{align-items:center;display:flex;flex-wrap:wrap}.task-filters{flex:1 1;gap:8px}.filter-search{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#2d3748;font-family:inherit;font-size:.875rem;min-width:180px;padding:6px 12px;transition:border-color .15s,box-shadow .15s}.filter-search:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1f;outline:none}.filter-search::placeholder{color:#a0aec0}.filter-select{background:#f8fafc;border:1px solid #e2e8f0;color:#4a5568;font-family:inherit;font-size:.82rem;min-width:150px;padding:6px 10px;transition:border-color .15s}.filter-select:focus{border-color:#667eea;outline:none}.view-toggle{background:#f1f5f9;border-radius:7px;display:flex;gap:2px;padding:3px}.view-btn{align-items:center;background:#0000;border:none;border-radius:5px;color:#718096;cursor:pointer;display:flex;font-family:inherit;font-size:.82rem;font-weight:500;gap:5px;padding:5px 14px;transition:all .15s}.view-btn:hover{background:#e2e8f0;color:#2d3748}.view-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#667eea;font-weight:600}.task-list{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:2rem}.task-list h2{color:#333;font-size:1.3rem;margin:0 0 1.5rem}.table-container{overflow-x:auto}.task-table{border-collapse:collapse;font-size:.95rem;width:100%}.task-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.task-table th{color:#495057;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.task-table td{border-bottom:1px solid #dee2e6;padding:1rem;vertical-align:top}.task-table tbody tr:hover{background-color:#f8f9fa}.task-key{color:#007bff;font-family:Courier New,monospace;font-size:.9rem;font-weight:600}.task-title{max-width:400px;min-width:250px}.task-title>div:first-child{font-weight:500;margin-bottom:.25rem}.task-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.85rem;max-height:2.4em;overflow:hidden;text-overflow:ellipsis}.task-project{color:#666;font-family:Courier New,monospace;font-size:.9rem}.task-type-badge{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.type-task{background-color:#d1ecf1;color:#0c5460}.type-bug{background-color:#f8d7da;color:#721c24}.type-story{background-color:#d4edda;color:#155724}.type-subtask{background-color:#e2e3e5;color:#383d41}.priority-badge{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.priority-critical{background-color:#721c24;color:#fff}.priority-high{background-color:#f8d7da;color:#721c24}.priority-medium{background-color:#fff3cd;color:#856404}.priority-low{background-color:#e2e3e5;color:#383d41}.status-badge{border:none;border-radius:4px;cursor:pointer;font-size:.85rem;padding:.35rem .75rem;text-transform:capitalize}.status-badge:disabled{cursor:not-allowed;opacity:.7}.status-todo{background-color:#e2e3e5;color:#383d41}.status-inprogress{background-color:#cce5ff;color:#004085}.status-review{background-color:#fff3cd;color:#856404}.status-done{background-color:#d4edda;color:#155724}.actions{display:flex;gap:.5rem;white-space:nowrap}.loading,.no-data{color:#666;font-style:italic;padding:2rem;text-align:center}@media (max-width:768px){.task-management{padding:1rem}.header{align-items:flex-start;flex-direction:column;gap:1rem}.task-controls{align-items:stretch;flex-direction:column}.task-filters{flex-direction:column;width:100%}.filter-select,.view-toggle{width:100%}.view-btn{flex:1 1;justify-content:center}.form-row{grid-template-columns:1fr}.task-table{font-size:.85rem}.task-table td,.task-table th{padding:.75rem .5rem}.actions{flex-direction:column}}.im-page{margin:0 auto;max-width:1400px;padding:2rem}.im-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.im-spinner{animation:im-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes im-spin{to{transform:rotate(1turn)}}.im-alert{align-items:center;border-radius:.75rem;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.625rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.im-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.im-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.im-alert-close{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;margin-left:auto;opacity:.6;padding:0}.im-alert-close:hover{opacity:1}.im-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.im-header-left{flex:1 1}.im-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.im-breadcrumb-parent{color:#64748b}.im-breadcrumb-sep{color:#94a3b8}.im-breadcrumb-active{color:#6366f1;font-weight:500}.im-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.im-subtitle{color:#64748b;margin:0}.im-add-btn,.im-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.im-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.im-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.im-add-btn:active{transform:translateY(0)}.im-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.im-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.im-stat,.im-stat-icon{align-items:center;display:flex}.im-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.im-stat-icon--blue{background:#eff6ff;color:#2563eb}.im-stat-icon--green{background:#f0fdf4;color:#16a34a}.im-stat-icon--yellow{background:#fefce8;color:#ca8a04}.im-stat-icon--red{background:#fff1f2;color:#e11d48}.im-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.im-stat-label,.im-stat-value{font-family:Plus Jakarta Sans,sans-serif}.im-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.im-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.im-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.im-filters,.im-toolbar{display:flex;flex-wrap:wrap}.im-filters{gap:.25rem}.im-filter-btn{background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s;white-space:nowrap}.im-filter-btn:hover{background:#f8fafc;color:#334155}.im-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.im-toolbar-right{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.im-search-wrap{align-items:center;display:flex;position:relative}.im-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.im-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.im-search-input:focus{background:#fff;border-color:#6366f1}.im-client-select{-webkit-appearance:none;appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:2.25rem;outline:none;padding:0 .75rem;transition:border-color .15s}.im-client-select:focus{background:#fff;border-color:#6366f1}.im-date-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;outline:none;padding:.5rem .75rem;transition:border-color .15s}.im-date-input:focus{background:#fff;border-color:#6366f1}.im-table-wrap{overflow-x:auto}.im-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.im-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.im-table thead th:last-child{text-align:right}.im-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.im-table tbody tr:last-child{border-bottom:none}.im-clickable-row{cursor:pointer}.im-clickable-row:hover{background:#fafbff}.im-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.im-inv-cell{gap:.75rem}.im-avatar,.im-inv-cell{align-items:center;display:flex}.im-avatar{background:#ccfbf1;border-radius:.5rem;color:#0d9488;flex-shrink:0;height:36px;justify-content:center;width:36px}.im-inv-number{color:#0f172a;font-size:.875rem;font-weight:700}.im-inv-client{color:#94a3b8;font-size:.75rem;margin-top:1px}.im-amount{color:#16a34a;font-size:.9375rem;font-weight:700}.im-balance{font-weight:600}.im-balance--due{color:#ca8a04}.im-balance--settled{color:#94a3b8}.im-muted{color:#94a3b8!important}.im-dash{color:#cbd5e1}.im-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .625rem;white-space:nowrap}.im-status-dot{background:currentColor;border-radius:50%;flex-shrink:0;height:6px;width:6px}.im-status--draft{background:#f1f5f9;color:#64748b}.im-status--sent{background:#eff6ff;color:#2563eb}.im-status--viewed{background:#f5f3ff;color:#7c3aed}.im-status--paid{background:#f0fdf4;color:#16a34a}.im-status--overdue{background:#fff1f2;color:#e11d48}.im-status--cancelled{background:#f8fafc;color:#94a3b8}.im-row-actions{align-items:center;display:flex;gap:.375rem;justify-content:flex-end}.im-delete-btn,.im-edit-btn,.im-send-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.im-send-btn{color:#16a34a}.im-send-btn:hover{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.im-edit-btn{color:#475569}.im-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.im-delete-btn{color:#94a3b8}.im-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.im-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.im-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.im-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.im-count strong{color:#0f172a}.im-pagination{display:flex;gap:.25rem}.im-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.im-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.im-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.im-page-btn:disabled{cursor:not-allowed;opacity:.4}.im-modal-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:500;z-index:var(--z-modal,500)}.im-modal{background:#fff;border-radius:1rem;box-shadow:0 20px 60px #00000026;max-width:480px;overflow:hidden;width:100%}.im-modal-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.im-modal-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;margin:0}.im-modal-close{align-items:center;background:#f8fafc;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,color .15s;width:32px}.im-modal-close:hover{background:#f1f5f9;color:#0f172a}.im-modal-body{gap:1.25rem;padding:1.5rem}.im-modal-body,.im-modal-field{display:flex;flex-direction:column}.im-modal-field{gap:.375rem}.im-modal-label{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.im-modal-input,.im-modal-select{-webkit-appearance:none;appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;height:2.75rem;padding:0 1rem;transition:border-color .15s,box-shadow .15s;width:100%}.im-modal-input:focus,.im-modal-select:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.im-modal-hint{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem}.im-modal-footer{align-items:center;background:#fafafa;border-top:1px solid #f1f5f9;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.im-modal-cancel-btn{background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:background .15s,border-color .15s}.im-modal-cancel-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.im-modal-cancel-btn:disabled{cursor:not-allowed;opacity:.5}.im-modal-send-btn{align-items:center;background:#6366f1;border:none;border-radius:.5rem;box-shadow:0 4px 6px -1px #6366f14d;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:700;gap:.375rem;padding:.625rem 1.5rem;transition:background .15s,transform .15s}.im-modal-send-btn:hover:not(:disabled){background:#4f46e5;transform:translateY(-1px)}.im-modal-send-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.of-input:disabled{background:#f1f5f9;opacity:.6}.of-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.of-section-title{color:#0f172a;font-size:.9375rem;font-weight:700;margin:0}.of-section-add-btn,.of-section-title{font-family:Plus Jakarta Sans,sans-serif}.of-section-add-btn{align-items:center;background:#fff;border:1.5px dashed #c7d2fe;border-radius:.5rem;color:#6366f1;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:600;gap:.375rem;padding:.5rem 1rem;transition:background .15s,border-color .15s}.of-section-add-btn:hover{background:#ede9fe;border-color:#a5b4fc}.im-line-items-wrap{margin-top:.25rem;overflow-x:auto}.im-line-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;width:100%}.im-line-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.625rem;font-weight:700;letter-spacing:.07em;padding:.625rem .75rem;text-align:left;text-transform:uppercase;white-space:nowrap}.im-line-table thead th:last-child{text-align:center;width:44px}.im-line-table tbody tr{border-bottom:1px solid #f8fafc}.im-line-table tbody tr:last-child{border-bottom:none}.im-line-table td{padding:.5rem .75rem;vertical-align:middle}.im-line-input{-webkit-appearance:none;appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:2.25rem;padding:0 .75rem;transition:border-color .15s;width:100%}.im-line-input:focus{background:#fff;border-color:#6366f1;outline:none}.im-line-total{color:#0f172a;font-weight:700;text-align:right;white-space:nowrap}.im-line-hint{color:#94a3b8;display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.6875rem;margin-top:.2rem}.im-remove-btn{align-items:center;background:#fff;border:1px solid #fecaca;border-radius:.375rem;color:#ef4444;cursor:pointer;display:flex;height:30px;justify-content:center;margin:0 auto;transition:background .15s;width:30px}.im-remove-btn:hover:not(:disabled){background:#fef2f2;color:#e11d48}.im-remove-btn:disabled{cursor:not-allowed;opacity:.3}.im-line-add-btn{align-items:center;background:#fff;border:1.5px dashed #c7d2fe;border-radius:.5rem;color:#6366f1;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:600;gap:.375rem;margin-top:1rem;padding:.5rem 1rem;transition:background .15s,border-color .15s}.im-line-add-btn:hover{background:#ede9fe;border-color:#a5b4fc}.im-totals{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-left:auto;margin-top:1.75rem;max-width:380px;padding:1.25rem 1.5rem}.im-totals-row{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;justify-content:space-between;padding:.375rem 0}.im-totals-row+.im-totals-row{border-top:1px solid #f1f5f9}.im-totals-row span{color:#64748b}.im-totals-row strong{color:#0f172a}.im-totals-row--discount strong{color:#e11d48}.im-totals-divider{border:none;border-top:2px solid #e2e8f0;margin:.5rem 0}.im-grand-total{margin-top:.25rem;padding-top:.75rem}.im-grand-total span{color:#0f172a;font-size:.9375rem;font-weight:700}.im-grand-total strong{color:#6366f1;font-size:1.125rem}.im-totals-row--advance strong{color:#16a34a}.im-balance-due{margin-top:.25rem;padding-top:.75rem}.im-balance-due span{color:#0f172a;font-size:.9375rem;font-weight:700}.im-balance-due strong{color:#16a34a;font-size:1.125rem}.of-field-hint{color:#94a3b8;display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;margin-top:.25rem}.of-email-status-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.25rem 1.5rem}.of-email-status-row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.of-email-status-info{color:#475569;display:flex;flex-direction:column;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.375rem}.of-email-status-info strong{color:#0f172a}.of-email-status-error{color:#dc2626;font-size:.8125rem}.of-email-status-empty{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-style:italic}.of-send-email-btn{align-items:center;background:#6366f1;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;font-weight:600;gap:.375rem;margin-top:.75rem;padding:.5rem 1rem;transition:background .15s}.of-send-email-btn:hover{background:#4f46e5}.of-form-actions{flex-wrap:wrap;gap:.75rem}.of-actions-left{align-items:center;display:flex;gap:.75rem}.of-delete-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#fff;border:1.5px solid #fecaca;border-radius:.5rem;color:#dc2626;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.375rem;padding:.625rem 1.25rem;transition:background .15s,border-color .15s}.of-delete-btn:hover{background:#fef2f2;border-color:#dc2626}.of-draft-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.375rem;padding:.625rem 1.25rem;transition:background .15s,border-color .15s}.of-draft-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.of-draft-btn:disabled{cursor:not-allowed;opacity:.5}.of-save-btn:hover:not(:disabled){background:#4f46e5;box-shadow:0 8px 12px -2px #6366f159;transform:translateY(-1px)}.of-save-btn:disabled{opacity:.5}@media (max-width:1024px){.im-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.im-page,.of-page{padding:1rem}.im-header{align-items:flex-start;flex-direction:column}.im-stats{grid-template-columns:repeat(2,1fr)}.im-toolbar{align-items:flex-start;flex-direction:column}.im-search-input,.im-toolbar-right{width:100%}.im-table td.im-col-hide,.im-table thead th.im-col-hide{display:none}.of-form-body{padding:1.25rem}.of-form-grid{grid-template-columns:1fr}.of-span-2{grid-column:span 1}.of-tabs-nav{padding:0 1rem}.of-tab{font-size:.8125rem;padding:.75rem .875rem}.of-form-actions{padding:1rem 1.25rem}.of-card-header{padding:1.25rem}.im-totals{margin-left:0;max-width:100%}.im-modal{max-width:calc(100% - 2rem)}}.im-proj-helper{align-items:center;background:linear-gradient(135deg,#eef2ff,#f0fdf4);border:1px solid #c7d2fe;border-radius:8px;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.im-proj-helper-info{display:flex;flex-direction:column;gap:.2rem}.im-proj-helper-label{color:#6366f1;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.im-proj-helper-figures{color:var(--gray-600);font-size:.8125rem}.im-proj-remaining{color:#16a34a}.im-proj-over{color:#dc2626}.im-proj-helper-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.625rem}.im-proj-btn{background:#6366f1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;padding:.375rem .75rem;white-space:nowrap}.im-proj-btn:hover{background:#4f46e5}.im-proj-btn:disabled{cursor:default;opacity:.45}.im-proj-pct{align-items:center;display:flex;gap:.375rem}.im-proj-pct-input{border:1px solid #c7d2fe;border-radius:6px;font-family:inherit;font-size:.8125rem;padding:.375rem .5rem;text-align:center;width:4rem}.im-proj-pct-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f133;outline:none}.im-sub-helper{background:linear-gradient(135deg,#fdf4ff,#eff6ff);border:1px solid #e9d5ff;border-radius:8px;display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem;padding:.75rem 1rem}.im-sub-helper-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.im-sub-helper-title{color:#7c3aed;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.im-sub-helper-hint{color:var(--gray-400);font-size:.75rem}.im-sub-helper-list{display:flex;flex-wrap:wrap;gap:.5rem}.im-sub-chip{align-items:center;background:#fff;border:1px solid #d8b4fe;border-radius:20px;cursor:pointer;display:flex;font-family:inherit;font-size:.8125rem;gap:.5rem;padding:.375rem .75rem;transition:background .15s,border-color .15s,box-shadow .15s}.im-sub-chip:hover{background:#faf5ff;border-color:#a855f7;box-shadow:0 1px 4px #a855f726}.im-sub-chip--added{background:#f0fdf4;border-color:#86efac;cursor:default}.im-sub-chip-name{color:var(--gray-700);font-weight:600}.im-sub-chip-plan{color:var(--gray-400);font-size:.75rem;font-weight:400}.im-sub-chip-amount{align-items:baseline;color:#7c3aed;display:flex;font-weight:700;gap:.1rem}.im-sub-chip-cycle{color:#a78bfa;font-size:.6875rem;font-weight:400}.im-sub-chip-tick{color:#16a34a;font-size:.75rem;font-weight:700}.im-inv-type-badge{border-radius:4px;display:inline-block;font-size:.6875rem;font-weight:600;letter-spacing:.02em;line-height:1.4;margin-left:.375rem;padding:.125rem .4rem;vertical-align:middle}.im-inv-type--advance{background:#fff3cd;color:#92650a}.im-inv-type--milestone{background:#e0e7ff;color:#3730a3}.im-inv-type--final{background:#d1fae5;color:#065f46}.im-proj-pay-summary{margin-left:auto;margin-top:1.25rem;max-width:380px;padding:.75rem 0 0}.im-proj-pay-summary-title{color:#6366f1;font-family:Plus Jakarta Sans,sans-serif;font-size:.6875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.625rem;text-transform:uppercase}.im-proj-pay-summary-row{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;justify-content:space-between;padding:.3125rem 0}.im-proj-pay-summary-row+.im-proj-pay-summary-row{border-top:1px solid #e0e7ff}.im-proj-pay-summary-row span{color:#475569}.im-proj-pay-summary-row strong{color:#1e293b}.im-proj-pay-summary-row--paid strong{color:#16a34a}@media (prefers-reduced-motion:reduce){.im-spinner{animation:none}.im-add-btn,.of-back-link svg,.of-save-btn{transition:none}.im-add-btn:hover,.of-save-btn:hover{transform:none}}.sc-page{font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1400px;padding:2rem}.sc-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.75rem}.sc-title{color:#0f172a;font-size:1.75rem;font-weight:800;letter-spacing:-.03em;margin:0 0 .25rem}.sc-subtitle{color:#64748b;font-size:.875rem;margin:0}.sc-add-btn{align-items:center;background:#6366f1;border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:background .15s,box-shadow .15s;white-space:nowrap}.sc-add-btn:hover{background:#4f46e5;box-shadow:0 4px 12px #6366f14d}.sc-alert{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#991b1b;font-size:.875rem;gap:1rem;justify-content:space-between;margin-bottom:1.25rem;padding:.75rem 1rem}.sc-alert,.sc-alert button{align-items:center;display:flex}.sc-alert button{background:none;border:none;color:inherit;cursor:pointer;padding:0}.sc-stats{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.sc-stat{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;min-width:100px;padding:.875rem 1.5rem}.sc-stat-num{color:#0f172a;font-size:1.5rem;font-weight:800;line-height:1}.sc-stat-num--green{color:#16a34a}.sc-stat-num--blue{color:#2563eb}.sc-stat-num--indigo{color:#6366f1}.sc-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}.sc-filters{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.sc-filters,.sc-search-wrap{align-items:center;display:flex}.sc-search-wrap{position:relative}.sc-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.sc-search{border:1px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:.875rem;min-width:200px;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s}.sc-search:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.sc-search-clear{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:0;position:absolute;right:.5rem}.sc-filter-chips{display:flex;gap:.375rem}.sc-chip{background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#64748b;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;padding:.375rem .75rem;transition:all .15s;white-space:nowrap}.sc-chip:hover{border-color:#a5b4fc;color:#4f46e5}.sc-chip--active{background:#6366f1;border-color:#6366f1;color:#fff}.sc-cat-select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;font-family:inherit;font-size:.8125rem;outline:none;padding:.375rem .75rem}.sc-cat-select:focus{border-color:#6366f1}.sc-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr))}.sc-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;display:flex;flex-direction:column;gap:.625rem;padding:1.25rem;transition:border-color .15s,box-shadow .15s}.sc-card:hover{border-color:#a5b4fc;box-shadow:0 4px 16px #6366f11a}.sc-card--add{align-items:center;background:#f8f7ff;border:2px dashed #c7d2fe;color:#6366f1;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;min-height:160px;transition:background .15s,border-color .15s}.sc-card--add:hover{background:#eef2ff;border-color:#6366f1}.sc-card-top{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between}.sc-card-badges{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.sc-card-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.sc-cat--blue{background:#dbeafe;color:#2563eb}.sc-cat--orange{background:#ffedd5;color:#ea580c}.sc-cat--green{background:#dcfce7;color:#16a34a}.sc-cat--pink{background:#fce7f3;color:#db2777}.sc-cat--cyan{background:#cffafe;color:#0891b2}.sc-cat--purple{background:#f3e8ff;color:#9333ea}.sc-cat--indigo{background:#e0e7ff;color:#4338ca}.sc-cat--amber{background:#fef3c7;color:#d97706}.sc-cat--teal{background:#ccfbf1;color:#0f766e}.sc-cat--rose{background:#ffe4e6;color:#e11d48}.sc-cat--gray{background:#f1f5f9;color:#64748b}.sc-bt-badge{border-radius:20px;display:inline-block;font-size:.6875rem;font-weight:700;letter-spacing:.02em;padding:.15rem .5rem;white-space:nowrap}.sc-bt--one{background:#dbeafe;color:#1d4ed8}.sc-bt--rec{background:#ede9fe;color:#6d28d9}.sc-bt--both{background:#d1fae5;color:#065f46}.sc-status{align-items:center;display:inline-flex;font-size:.6875rem;font-weight:600;gap:.3rem}.sc-status-dot{background:#16a34a;border-radius:50%;display:inline-block;height:6px;width:6px}.sc-status--active{color:#16a34a}.sc-status--inactive{color:#94a3b8}.sc-card-name{color:#0f172a;font-size:1rem;font-weight:700;line-height:1.3}.sc-card-cat{color:#64748b;font-size:.75rem;font-weight:500}.sc-card-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#94a3b8;display:-webkit-box;font-size:.8125rem;line-height:1.4;margin:0;overflow:hidden}.sc-card-pricing{align-items:baseline;display:flex;gap:.3rem;margin-top:.25rem}.sc-card-price{color:#0f172a;font-size:1.125rem;font-weight:800}.sc-card-unit{color:#94a3b8;font-size:.75rem}.sc-card-tax{background:#fef3c7;border-radius:4px;color:#d97706;font-size:.6875rem;margin-left:.25rem;padding:.1rem .375rem}.sc-card-used{align-items:center;color:#16a34a;display:flex;font-size:.75rem;gap:.3rem}.sc-card-actions{border-top:1px solid #f1f5f9;display:flex;gap:.5rem;margin-top:auto;padding-top:.5rem}.sc-card-btn{align-items:center;border:1px solid;border-radius:7px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8125rem;font-weight:500;gap:.3rem;padding:.375rem .75rem;transition:all .15s}.sc-card-btn--edit{background:#fff;border-color:#e2e8f0;color:#475569;flex:1 1;justify-content:center}.sc-card-btn--edit:hover{background:#f5f3ff;border-color:#6366f1;color:#6366f1}.sc-card-btn--del{background:#fff;border-color:#fee2e2;color:#ef4444;padding:.375rem .6rem}.sc-card-btn--del:hover{background:#fef2f2;border-color:#ef4444}.sc-loading{align-items:center;display:flex;justify-content:center;min-height:300px}.sc-spinner{animation:sc-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes sc-spin{to{transform:rotate(1turn)}}.sc-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:1rem;padding:4rem 2rem;text-align:center}.sc-empty p{font-size:.9375rem;margin:0}.sc-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:500}.sc-modal{border-radius:16px;box-shadow:0 20px 60px #0003;flex-direction:column;max-height:90vh;max-width:680px;overflow-y:auto;width:100%}.sc-modal,.sc-modal-header{background:#fff;display:flex}.sc-modal-header{align-items:center;border-bottom:1px solid #f1f5f9;border-radius:16px 16px 0 0;justify-content:space-between;padding:1.25rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:1}.sc-modal-title{color:#0f172a;font-size:1.125rem;font-weight:700;margin:0}.sc-modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;padding:.25rem}.sc-modal-close:hover{background:#f1f5f9;color:#475569}.sc-modal-body{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.sc-modal-footer{border-top:1px solid #f1f5f9;display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem;padding-top:1rem}.sc-form-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:.875rem;padding:.75rem 1rem}.sc-form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}@media (min-width:480px){.sc-form-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.sc-form-field{display:flex;flex-direction:column;gap:.35rem}.sc-form-field--grow{flex:2 1}.sc-form-label{color:#64748b;font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sc-req{color:#ef4444}.sc-form-input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-family:inherit;font-size:.875rem;outline:none;padding:.5rem .75rem;transition:border-color .15s,box-shadow .15s;width:100%}.sc-form-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.sc-form-textarea{min-height:64px;resize:vertical}.sc-form-select-wrap{position:relative}.sc-form-select-wrap select{-webkit-appearance:none;appearance:none;padding-right:2rem}.sc-form-chevron{color:#94a3b8;pointer-events:none;position:absolute;right:.625rem;top:50%;transform:translateY(-50%)}.sc-form-hint,.sc-form-section-label{color:#94a3b8;font-size:.6875rem}.sc-form-section-label{border-bottom:1px solid #f1f5f9;font-weight:700;letter-spacing:.06em;padding-bottom:.375rem;text-transform:uppercase}.sc-form-preview{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-wrap:wrap;font-size:.875rem;gap:.75rem;padding:.625rem 1rem}.sc-form-preview-label{color:#94a3b8;font-size:.6875rem;font-weight:700;text-transform:uppercase;white-space:nowrap}.sc-form-preview-val{color:#0f172a;font-weight:600}.sc-btn{align-items:center;border:1px solid;border-radius:9px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .15s}.sc-btn--primary{background:#6366f1;border-color:#6366f1;color:#fff}.sc-btn--primary:hover:not(:disabled){background:#4f46e5}.sc-btn--primary:disabled{cursor:default;opacity:.6}.sc-btn--ghost{background:#fff;border-color:#e2e8f0;color:#64748b}.sc-btn--ghost:hover{border-color:#c7d2fe;color:#4f46e5}@media (max-width:768px){.sc-page{padding:1rem}.sc-stats{gap:.5rem}.sc-stat{min-width:80px;padding:.625rem 1rem}.sc-filters{gap:.5rem}.sc-search{min-width:150px}}.pm-page{margin:0 auto;max-width:1400px;padding:2rem}.pm-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.pm-spinner{animation:pm-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes pm-spin{to{transform:rotate(1turn)}}.pm-alert{border-radius:.75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.pm-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.pm-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.pm-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.pm-header-left{flex:1 1}.pm-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.pm-breadcrumb-parent{color:#64748b}.pm-breadcrumb-sep{color:#94a3b8}.pm-breadcrumb-active{color:#6366f1;font-weight:500}.pm-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.pm-subtitle{color:#64748b;margin:0}.pm-add-btn,.pm-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.pm-add-btn{align-items:center;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.pm-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.pm-add-btn:active{transform:translateY(0)}.pm-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.pm-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.pm-stat,.pm-stat-icon{align-items:center;display:flex}.pm-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.pm-stat-icon--blue{background:#eff6ff;color:#2563eb}.pm-stat-icon--green{background:#f0fdf4;color:#16a34a}.pm-stat-icon--indigo{background:#eef2ff;color:#6366f1}.pm-stat-icon--yellow{background:#fefce8;color:#ca8a04}.pm-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.pm-stat-label,.pm-stat-value{font-family:Plus Jakarta Sans,sans-serif}.pm-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.pm-stat-value--sm{font-size:1.25rem}.pm-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.pm-toolbar{border-bottom:1px solid #f1f5f9;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.pm-toolbar,.pm-toolbar-left{align-items:center;display:flex;flex-wrap:wrap}.pm-toolbar-left{gap:.75rem}.pm-toolbar-right{align-items:center;display:flex;gap:.5rem}.pm-search-wrap{align-items:center;display:flex;position:relative}.pm-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.pm-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.pm-search-input:focus{background:#fff;border-color:#6366f1}.pm-filter-select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem;transition:border-color .15s}.pm-filter-select:focus{background:#fff;border-color:#6366f1}.pm-date-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;outline:none;padding:.5rem .625rem;transition:border-color .15s}.pm-date-input:focus{background:#fff;border-color:#6366f1}.pm-date-sep{color:#94a3b8;font-size:.875rem}.pm-table-wrap{overflow-x:auto}.pm-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.pm-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.pm-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.pm-table tbody tr:last-child{border-bottom:none}.pm-clickable-row{cursor:pointer}.pm-clickable-row:hover{background:#fafbff}.pm-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.pm-pay-cell{gap:.75rem}.pm-avatar,.pm-pay-cell{align-items:center;display:flex}.pm-avatar{background:#dbeafe;border-radius:.5rem;color:#1d4ed8;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.pm-pay-ref{color:#0f172a;font-size:.875rem;font-weight:600}.pm-pay-client{color:#94a3b8;font-size:.75rem;margin-top:1px}.pm-inv-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;padding:.2rem .5rem}.pm-amount{color:#16a34a;font-size:.9375rem;font-weight:700}.pm-dash{color:#cbd5e1}.pm-source{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.3rem;padding:.25rem .625rem}.pm-source--manual{background:#f1f5f9;color:#475569}.pm-source--gateway{background:#eef2ff;color:#6366f1}.pm-row-actions{align-items:center;display:flex;gap:.375rem}.pm-delete-btn,.pm-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.pm-edit-btn{color:#475569}.pm-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.pm-delete-btn{color:#94a3b8}.pm-delete-btn:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.pm-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;padding:3rem 1rem!important;text-align:center}.pm-no-data>*{display:block}.pm-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.pm-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.pm-count strong{color:#0f172a}.pm-pagination{display:flex;gap:.25rem}.pm-page-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#64748b;cursor:pointer;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.pm-page-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1;color:#0f172a}.pm-page-btn:disabled{cursor:default;opacity:.4}.pm-page-btn--active{background:#6366f1;border-color:#6366f1;color:#fff;font-weight:700}.pm-page-btn--active:hover{background:#4f46e5}.of-page{max-width:860px}.of-back-link{margin-bottom:1.25rem}.of-alert{border-radius:.75rem;padding:.875rem 1.25rem}.of-card{border-radius:.875rem;box-shadow:0 1px 3px #0000000a}.of-card-header{padding:1.5rem 1.75rem}.of-card-title-row{align-items:flex-start}.of-card-icon{background:#eef2ff;border-radius:.625rem;color:#6366f1}.of-card-title{font-weight:800;letter-spacing:-.02em;margin:0 0 .2rem}.of-card-subtitle{font-size:.875rem}.of-form-body{display:flex;flex-direction:column;gap:1.5rem;padding:1.75rem}.of-section-label{border-bottom:1px solid #f1f5f9;color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.6875rem;font-weight:700;letter-spacing:.09em;padding-bottom:.5rem;text-transform:uppercase}.of-form-grid{grid-gap:1.25rem 1.5rem;gap:1.25rem 1.5rem}.of-span-2{grid-column:1/-1}.of-label{color:#374151;font-size:.8125rem;font-weight:600}.of-required{margin-left:.1rem}.of-input{background:#fff;border:1.5px solid #e2e8f0;outline:none;padding:.625rem .875rem;transition:border-color .15s,box-shadow .15s}.of-input:focus{box-shadow:0 0 0 3px #6366f114}.of-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}textarea.of-input{min-height:80px}.of-form-actions{border-top:1px solid #f1f5f9;padding:1.25rem 1.75rem}.of-save-btn{box-shadow:0 4px 6px -1px #6366f140;gap:.5rem;transition:background .15s}.pm-balance-due{color:#dc2626!important;font-weight:600}.pm-hint{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;margin-top:.1rem}@media (max-width:1024px){.pm-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.pm-page{padding:1rem}.pm-header{align-items:flex-start;flex-direction:column}.pm-stats{grid-template-columns:repeat(2,1fr)}.pm-toolbar{align-items:flex-start;flex-direction:column}.pm-toolbar-right{width:100%}.of-page{padding:1rem}.of-form-grid{grid-template-columns:1fr}.of-span-2{grid-column:1}}@media (prefers-reduced-motion:reduce){.pm-spinner{animation:none}}.sub-page{margin:0 auto;max-width:1400px;padding:2rem}.sub-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.sub-spinner{animation:sub-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes sub-spin{to{transform:rotate(1turn)}}.sub-alert{border-radius:.75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.sub-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.sub-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.sub-header{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.sub-header-left{flex:1 1}.sub-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.sub-breadcrumb-parent{color:#64748b}.sub-breadcrumb-sep{color:#94a3b8}.sub-breadcrumb-active{color:#6366f1;font-weight:500}.sub-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.sub-subtitle{color:#64748b;margin:0}.sub-add-btn,.sub-subtitle{font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.sub-add-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.5rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.sub-add-btn:hover{background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.sub-add-btn:active{transform:translateY(0)}.sub-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.sub-stat{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000000a;gap:1rem;padding:1.25rem 1.5rem}.sub-stat,.sub-stat-icon{align-items:center;display:flex}.sub-stat-icon{border-radius:.625rem;flex-shrink:0;height:48px;justify-content:center;width:48px}.sub-stat-icon--blue{background:#eff6ff;color:#2563eb}.sub-stat-icon--green{background:#f0fdf4;color:#16a34a}.sub-stat-icon--yellow{background:#fefce8;color:#ca8a04}.sub-stat-icon--red{background:#fff1f2;color:#e11d48}.sub-stat-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.sub-stat-label,.sub-stat-value{font-family:Plus Jakarta Sans,sans-serif}.sub-stat-value{color:#0f172a;font-size:1.875rem;font-weight:800;line-height:1}.sub-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.sub-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.sub-filters{display:flex;gap:.25rem}.sub-filter-btn{background:#0000;border:none;border-radius:.5rem;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .15s,color .15s}.sub-filter-btn:hover{background:#f8fafc;color:#334155}.sub-filter-btn--active{background:#f1f5f9;color:#0f172a;font-weight:700}.sub-toolbar-right{align-items:center;display:flex;gap:.75rem}.sub-search-wrap{align-items:center;display:flex;position:relative}.sub-search-icon{color:#94a3b8;left:.75rem;pointer-events:none;position:absolute}.sub-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:border-color .15s;width:220px}.sub-search-input:focus{background:#fff;border-color:#6366f1}.sub-table-wrap{overflow-x:auto}.sub-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.sub-table thead th{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.sub-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}.sub-table tbody tr:last-child{border-bottom:none}.sub-clickable-row{cursor:pointer}.sub-clickable-row:hover{background:#f8fafc}.sub-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.2rem .5rem}.sub-manager{align-items:center;color:#374151;display:flex;font-size:.83rem;gap:8px}.sub-manager-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.72rem;font-weight:700;height:28px;justify-content:center;width:28px}.sub-table td{color:#334155;padding:.875rem 1rem;vertical-align:middle}.sub-client-cell{gap:.75rem}.sub-avatar,.sub-client-cell{align-items:center;display:flex}.sub-avatar{background:#fef3c7;border-radius:.5rem;color:#d97706;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.sub-client-name{color:#0f172a;font-weight:600}.sub-client-sub{align-items:center;color:#94a3b8;display:flex;font-size:.75rem;gap:.375rem;margin-top:2px}.sub-cycle-badge{align-items:center;background:#e0e7ff;border-radius:999px;color:#4338ca;display:inline-flex;font-size:.6875rem;font-weight:600;padding:.125rem .5rem}.sub-billing-cycle{color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:.72rem;font-weight:500;margin-left:1px}.sub-muted{color:#94a3b8!important}.sub-dash{color:#cbd5e1}.sub-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .625rem}.sub-status-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.sub-status--active{background:#f0fdf4;color:#16a34a}.sub-status--paused{background:#fefce8;color:#ca8a04}.sub-status--cancelled{background:#fef2f2;color:#dc2626}.sub-row-actions{align-items:center;display:flex;gap:.375rem}.sub-delete-btn,.sub-edit-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s,border-color .15s,color .15s;width:32px}.sub-edit-btn{color:#475569}.sub-edit-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#6366f1}.sub-delete-btn{color:#94a3b8}.sub-delete-btn:hover{background:#fff1f2;border-color:#fecaca;color:#e11d48}.sub-no-data{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:3rem;text-align:center}.sub-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.sub-count{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem}.sub-count strong{color:#0f172a}.sub-pagination{display:flex;gap:.25rem}.sub-page-btn{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.8125rem;height:36px;min-width:36px;padding:0 .75rem;transition:all .15s}.sub-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#6366f1;color:#6366f1}.sub-page-btn--active{background:#6366f1!important;border-color:#6366f1!important;color:#fff!important;font-weight:700}.sub-page-btn:disabled{cursor:not-allowed;opacity:.4}.of-page{margin:0 auto;max-width:1400px;padding:2rem}.of-back-link{align-items:center;-webkit-appearance:none;appearance:none;background:none;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.375rem;margin-bottom:1.5rem;padding:0;transition:color .15s}.of-back-link:hover{color:#6366f1}.of-back-link svg{transition:transform .15s}.of-back-link:hover svg{transform:translateX(-3px)}.of-alert{align-items:center;border-radius:10px;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1.25rem;padding:.875rem 1.125rem}.of-alert--error{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #dc2626;color:#991b1b}.of-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;border-left:4px solid #16a34a;color:#166534}.of-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 1px 3px #0000000f;margin-bottom:1.5rem;overflow:hidden}.of-card-header{border-bottom:1px solid #f1f5f9;padding:1.5rem 2rem}.of-card-title-row{align-items:center;display:flex;gap:1rem}.of-card-icon{align-items:center;background:#ede9fe;border-radius:.75rem;color:#7c3aed;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.of-card-title{color:#0f172a;font-size:1.125rem;font-weight:700;margin:0 0 .125rem}.of-card-subtitle,.of-card-title{font-family:Plus Jakarta Sans,sans-serif}.of-card-subtitle{color:#64748b;font-size:.8125rem;margin:0}.of-tabs-nav{border-bottom:1px solid #e2e8f0;display:flex;overflow-x:auto;padding:0 2rem}.of-tab{-webkit-appearance:none;appearance:none;background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:500;margin-bottom:-1px;outline:none;padding:1rem 1.5rem;transition:color .15s,border-color .15s;white-space:nowrap}.of-tab:hover{border-bottom-color:#cbd5e1;color:#334155}.of-tab--active{border-bottom-color:#6366f1;color:#6366f1;font-weight:600}.of-form-body{padding:2rem}.of-form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.of-field{display:flex;flex-direction:column;gap:.375rem}.of-span-2{grid-column:span 2}.of-label{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.of-required{color:#ef4444}.of-input{-webkit-appearance:none;appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;height:2.75rem;padding:0 1rem;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}.of-input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.of-input::placeholder{color:#c4cad4}textarea.of-input{height:auto;padding:.75rem 1rem;resize:vertical}.of-hint{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.73rem}.of-form-actions{align-items:center;background:#fafafa;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.25rem 2rem}.of-actions-right{align-items:center;display:flex;gap:.75rem}.of-cancel-btn{-webkit-appearance:none;appearance:none;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;color:#475569;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:background .15s,border-color .15s}.of-cancel-btn:hover{background:#f8fafc;border-color:#cbd5e1}.of-save-btn{align-items:center;-webkit-appearance:none;appearance:none;background:#6366f1;border:none;border-radius:.5rem;box-shadow:0 4px 6px -1px #6366f14d;color:#fff;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:700;gap:.375rem;padding:.625rem 1.5rem;transition:background .15s,box-shadow .15s,transform .15s}.of-save-btn:hover{background:#4f46e5;box-shadow:0 8px 12px -2px #6366f159;transform:translateY(-1px)}.of-save-btn:active{transform:translateY(0)}.of-save-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:1024px){.sub-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.of-page,.sub-page{padding:1rem}.sub-header{align-items:flex-start;flex-direction:column}.sub-stats{grid-template-columns:repeat(2,1fr)}.sub-toolbar{align-items:flex-start;flex-direction:column}.of-form-body{padding:1.25rem}.of-form-grid{grid-template-columns:1fr}.of-span-2{grid-column:span 1}.of-tabs-nav{padding:0 1rem}.of-tab{font-size:.8125rem;padding:.75rem .875rem}.of-form-actions{flex-wrap:wrap;padding:1rem 1.25rem}.of-card-header{padding:1.25rem}}@media (prefers-reduced-motion:reduce){.sub-spinner{animation:none}}.email-template-management{padding:20px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.page-header h2{color:#1a1a1a;font-size:24px;margin:0}.btn-primary{align-items:center;background:#4f46e5;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:background .2s}.btn-primary:hover{background:#4338ca}.btn-secondary{align-items:center;border:1px solid #4f46e5;border-radius:6px;color:#4f46e5;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.btn-secondary:hover{background:#eef2ff}.btn-back{align-items:center;background:#fff;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 14px;transition:all .2s}.btn-back:hover{background:#f5f5f5}.templates-list{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.templates-table{border-collapse:collapse;width:100%}.templates-table thead{background:#f9fafb;border-bottom:1px solid #e5e7eb}.templates-table th{color:#374151;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.templates-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.templates-table tbody tr:hover{background:#f9fafb}.templates-table td{color:#1f2937;font-size:14px;padding:14px 16px}.subject-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-type{background:#e0e7ff;color:#4f46e5;padding:4px 10px}.status-badge,.template-type{border-radius:12px;display:inline-block;font-size:12px;font-weight:500}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.default-badge{align-items:center;background:#fef3c7;border-radius:12px;color:#92400e;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px}.action-buttons{display:flex;gap:8px}.btn-icon{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.btn-icon:hover{background:#f3f4f6;border-color:#d1d5db;color:#374151}.btn-icon.btn-danger:hover{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.template-form-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:24px}.template-form{max-width:1200px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-group{display:flex;flex-direction:column;margin-bottom:20px}.form-group label{color:#374151;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-group textarea{font-family:Courier New,monospace;line-height:1.5;resize:vertical}.checkbox-group label{align-items:center;cursor:pointer;flex-direction:row;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer;margin:0;width:auto}.html-editor-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 300px}.html-editor-container textarea{font-family:Courier New,monospace;font-size:13px;min-height:400px}.variable-helper{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;max-height:500px;overflow-y:auto;padding:16px}.variable-helper h4{color:#374151;font-size:14px;margin:0 0 8px}.helper-text{color:#6b7280;font-size:12px;margin-bottom:12px}.variable-list{display:flex;flex-direction:column;gap:6px}.variable-button{background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#4f46e5;cursor:pointer;font-family:Courier New,monospace;font-size:12px;padding:8px 10px;text-align:left;transition:all .2s}.variable-button:hover{background:#eef2ff;border-color:#4f46e5}.helper-note{align-items:flex-start;background:#fef3c7;border-radius:4px;color:#92400e;display:flex;font-size:11px;gap:8px;line-height:1.4;margin-top:12px;padding:8px}.helper-note svg{flex-shrink:0;margin-top:1px}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.modal-content{overflow:hidden}.modal-content.preview-modal{max-width:800px}.modal-header{border-bottom:1px solid #e5e7eb}.modal-header h3{color:#1f2937}.btn-close{align-items:center;background:#0000;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:color .2s}.btn-close:hover{color:#1f2937}.modal-body p{color:#374151;line-height:1.6;margin:0 0 16px}.delete-confirmation-input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-top:8px;padding:10px 12px;width:100%}.delete-confirmation-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.btn-danger{align-items:center;background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:background .2s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{cursor:not-allowed;opacity:.5}.preview-subject{background:#f9fafb;border-radius:6px;color:#374151;font-size:14px;padding:12px 16px}.preview-divider{background:#e5e7eb;height:1px;margin:16px 0}.preview-html{background:#fff;border:1px solid #e5e7eb;border-radius:6px;overflow-x:auto;padding:20px}.empty-state p{margin-bottom:20px}.empty-state p,.loading{color:#6b7280;font-size:16px}@media (max-width:1024px){.html-editor-container{grid-template-columns:1fr}.variable-helper{max-height:300px}}@media (max-width:768px){.form-row{grid-template-columns:1fr}.templates-table{font-size:13px}.templates-table td,.templates-table th{padding:10px 12px}.subject-cell{max-width:200px}}.weekly-timesheet{margin:0 auto;max-width:1400px;padding:20px}.weekly-timesheet-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.weekly-timesheet-header h1{color:#1e293b;font-size:24px;font-weight:600;margin:0}.week-nav-button:disabled{cursor:not-allowed;opacity:.5}.timesheet-status{align-items:center;border-radius:6px;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px}.timesheet-status.draft{background:#f1f5f9;color:#64748b}.timesheet-status.submitted{background:#dbeafe;color:#1e40af}.timesheet-status.approved{background:#d1fae5;color:#065f46}.timesheet-status.rejected{background:#fee2e2;color:#991b1b}.timesheet-grid{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;overflow:hidden}.grid-table{border-collapse:collapse;width:100%}.grid-table thead th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 8px;text-align:left;text-transform:uppercase}.grid-table thead th.day-header{min-width:80px;text-align:center}.grid-table tbody td{border-bottom:1px solid #f1f5f9;padding:8px}.grid-table tbody tr:hover{background:#fafafa}.grid-table tbody tr.empty-row{background:#0000}.hour-cell-container{align-items:center;display:flex;gap:4px;position:relative}.grid-select{background:#fff;border:1px solid #e2e8f0;border-radius:4px;font-size:14px;padding:8px;width:100%}.grid-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.hour-input{border:1px solid #e2e8f0;border-radius:4px;font-size:14px;padding:8px 4px;text-align:center;width:70px}.hour-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.hour-input:disabled{background:#f8fafc;cursor:not-allowed}.hour-input.future-date{background:#ebebeb;border-color:#ddd;color:#ebebeb;cursor:not-allowed}.hour-input.future-date::placeholder{color:#ebebeb}.comment-icon-button{align-items:center;background:#0000;border:1px solid #e2e8f0;border-radius:4px;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .2s}.comment-icon-button:hover:not(:disabled){background:#f0f9ff;border-color:#3b82f6;color:#3b82f6}.comment-icon-button.has-comment{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.comment-icon-button:disabled{cursor:not-allowed;opacity:.3}.row-total{color:#1e293b;font-weight:600;text-align:center}.grid-table tfoot td{background:#f8fafc;border-top:2px solid #e2e8f0;font-weight:600;padding:12px 8px}.grid-table tfoot .total-label{color:#475569}.grid-table tfoot .total-value{color:#1e293b;text-align:center}.delete-row-button{align-items:center;background:#0000;border:none;border-radius:4px;color:#ef4444;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s}.delete-row-button:hover{background:#fee2e2}.delete-row-button:disabled{cursor:not-allowed;opacity:.3}.icon-button{align-items:center;background:#0000;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s}.icon-button:hover:not(:disabled){background:#dbeafe}.icon-button:disabled{cursor:not-allowed;opacity:.3}.grid-actions{display:flex;gap:12px;margin-top:12px}.add-row-button{align-items:center;background:#fff;border:2px dashed #e2e8f0;border-radius:6px;color:#3b82f6;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:12px;transition:all .2s}.add-row-button:hover{background:#f0f9ff;border-color:#3b82f6}.copy-previous-button{align-items:center;background:#fff;border:2px dashed #e2e8f0;border-radius:6px;color:#8b5cf6;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:12px;transition:all .2s}.copy-previous-button:hover{background:#f5f3ff;border-color:#8b5cf6}.actions-bar{background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;padding:16px}.actions-bar,.weekly-summary{align-items:center;display:flex}.weekly-summary{gap:20px}.summary-item{display:flex;flex-direction:column;gap:4px}.summary-label{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.summary-value{color:#1e293b;font-size:20px;font-weight:600}.actions-buttons{display:flex;gap:12px}.btn{padding:10px 20px}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.alert{align-items:center;border-radius:6px;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 16px}.alert-info{background:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.alert-warning{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.alert-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.modal-content{border-radius:8px;max-width:500px;width:90%}.modal-header h3{color:#1e293b;font-size:18px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;display:flex;font-size:28px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:28px}.modal-close:hover{background:#f1f5f9;color:#475569}.comment-textarea{border:1px solid #e2e8f0;border-radius:6px;font-family:inherit;font-size:14px;min-height:100px;padding:12px;resize:vertical;width:100%}.comment-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.comment-textarea[readonly]{background-color:#f8fafc;color:#475569;cursor:default}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}@media (max-width:1200px){.timesheet-grid{overflow-x:auto}.grid-table{min-width:1000px}}.team-timesheets{margin:0 auto;max-width:1600px;padding:20px}.team-timesheets-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.week-selector{align-items:center;display:flex;gap:12px}.week-nav-button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;font-size:14px;gap:4px;padding:8px 12px;transition:all .2s}.week-nav-button:hover{background:#f8fafc;border-color:#cbd5e1}.week-display{color:#475569;font-size:14px;font-weight:500;min-width:200px;text-align:center}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-card{gap:12px;padding:16px}.summary-card-icon{border-radius:8px;height:48px;width:48px}.summary-card-icon.employees{background:linear-gradient(135deg,#3b82f6,#2563eb)}.summary-card-icon.hours{background:linear-gradient(135deg,#10b981,#059669)}.summary-card-icon.pending{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-card-icon.missing{background:linear-gradient(135deg,#ef4444,#dc2626)}.summary-card-value{line-height:1}.filters-panel{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.filter-group{min-width:200px}.filter-group select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;padding:8px 12px}.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.timesheets-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.timesheets-table{border-collapse:collapse;width:100%}.timesheets-table thead th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.timesheets-table tbody td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;padding:12px 16px}.timesheets-table tbody tr:hover{background:#fafafa}.timesheets-table tbody tr:last-child td{border-bottom:none}.no-data{color:#94a3b8!important;padding:40px!important;text-align:center!important}.employee-cell{display:flex;flex-direction:column;gap:2px}.employee-name{color:#1e293b;font-weight:500}.employee-email{color:#64748b;font-size:12px}.projects-cell{display:flex;flex-direction:column;gap:4px}.project-item{align-items:center;background:#f8fafc;border-radius:4px;display:flex;gap:8px;justify-content:space-between;padding:4px 8px}.project-name{color:#475569;flex:1 1;font-size:13px}.project-hours{color:#1e293b;font-size:12px;font-weight:600}.text-muted{font-size:13px}.hours-cell{color:#1e293b;text-align:right}.status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.status-badge.status-draft{background:#f1f5f9;color:#64748b}.status-badge.status-submitted{background:#dbeafe;color:#1e40af}.status-badge.status-approved{background:#d1fae5;color:#065f46}.status-badge.status-rejected{background:#fee2e2;color:#991b1b}.status-icon{flex-shrink:0}.status-icon-draft{color:#64748b}.status-icon-submitted{color:#1e40af}.status-icon-approved{color:#065f46}.status-icon-rejected{color:#991b1b}.actions-cell{display:flex;gap:6px;justify-content:flex-end}.icon-btn{align-items:center;background:#0000;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.icon-btn.approve{color:#10b981}.icon-btn.approve:hover{background:#d1fae5;border-color:#10b981}.icon-btn.reject{color:#ef4444}.icon-btn.reject:hover{background:#fee2e2;border-color:#ef4444}.icon-btn.disabled{cursor:not-allowed;opacity:.35;pointer-events:none}.ts-confirm-modal{animation:ts-modal-in .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000002e;max-width:calc(100vw - 32px);padding:2rem;text-align:center;width:440px}@keyframes ts-modal-in{0%{opacity:0;transform:scale(.94) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.ts-confirm-icon{align-items:center;border-radius:50%;display:flex;height:64px;justify-content:center;margin:0 auto 1.25rem;width:64px}.ts-confirm-icon--approve{background:#dcfce7;color:#16a34a}.ts-confirm-icon--reject{background:#fee2e2;color:#dc2626}.ts-confirm-title{color:#0f172a;font-size:1.2rem;font-weight:700;margin:0 0 .6rem}.ts-confirm-body{color:#64748b;font-size:.9rem;line-height:1.6;margin:0 0 1.5rem}.ts-confirm-body strong{color:#1e293b}.ts-reject-reason{margin-bottom:1.5rem;text-align:left}.ts-reject-label{color:#374151;display:block;font-size:.85rem;font-weight:600;margin-bottom:.5rem}.ts-reject-label span{color:#ef4444;margin-left:2px}.ts-reject-textarea{border:1.5px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#1e293b;font-family:inherit;font-size:.875rem;outline:none;padding:.65rem .75rem;resize:vertical;transition:border-color .15s;width:100%}.ts-reject-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.ts-reject-hint{color:#ef4444;display:block;font-size:.78rem;margin-top:4px}.ts-confirm-actions{display:flex;gap:.75rem;justify-content:center}.ts-confirm-actions .btn{align-items:center;display:flex;flex:1 1;gap:.4rem;justify-content:center}.ts-btn-approve{background:#16a34a;border:none;color:#fff}.ts-btn-approve:hover:not(:disabled){background:#15803d}.ts-btn-reject{background:#dc2626;border:none;color:#fff}.ts-btn-reject:hover:not(:disabled){background:#b91c1c}.ts-btn-reject:disabled{background:#fca5a5;cursor:not-allowed}.btn-secondary:hover{background:#f8fafc}@media (max-width:1200px){.timesheets-table-container{overflow-x:auto}.timesheets-table{min-width:1000px}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.team-timesheets-header{align-items:stretch;flex-direction:column}.week-selector{flex-wrap:wrap}.summary-cards{grid-template-columns:1fr}}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:90%}.timesheet-detail-modal{max-width:95%;width:1200px}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#1e293b;font-size:20px;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:background .2s}.close-btn:hover{background:#f1f5f9}.modal-body{overflow-y:auto;padding:24px}.timesheet-details{display:flex;flex-direction:column;gap:24px}.detail-header{background:#f8fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:24px;padding:16px}.detail-info{align-items:center;display:flex;gap:8px}.detail-info strong{color:#64748b;font-weight:500}.detail-table-wrapper{overflow-x:auto}.detail-table{border-collapse:collapse;font-size:14px;width:100%}.detail-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.detail-table th{color:#475569;font-weight:600;padding:12px 16px;text-align:left;white-space:nowrap}.detail-table td{border-bottom:1px solid #f1f5f9;padding:12px 16px;text-align:center}.detail-table .project-name-col{color:#1e293b;font-weight:500;max-width:200px;text-align:left}.detail-table tbody tr:hover{background:#f8fafc}.detail-table tbody tr:last-child td{border-bottom:none}.time-tracking-reports{margin:0 auto;max-width:1600px;padding:20px}.reports-header{flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.header-title,.reports-header{align-items:center;display:flex}.header-title{gap:12px}.header-title h1{color:#1e293b;font-size:24px;font-weight:600;margin:0}.header-title svg{color:#3b82f6}.filter-toggle-button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.filter-toggle-button.active,.filter-toggle-button:hover{background:#f0f9ff;border-color:#3b82f6;color:#3b82f6}.filters-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:20px}.filters-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px}.filter-group{display:flex;flex-direction:column;gap:6px;min-width:150px}.filter-group label{color:#475569;font-size:13px;font-weight:500}.filter-group input,.filter-group select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;padding:8px 12px}.filter-group input:focus,.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.quick-ranges{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:8px;padding-top:12px}.quick-ranges-label{color:#64748b;font-size:13px;font-weight:500}.quick-range-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s}.quick-range-btn:hover{background:#f0f9ff;border-color:#3b82f6;color:#3b82f6}.summary-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}.summary-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:16px;padding:20px}.summary-card-icon{align-items:center;border-radius:10px;color:#fff;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.summary-card-icon.hours{background:linear-gradient(135deg,#3b82f6,#2563eb)}.summary-card-icon.groups{background:linear-gradient(135deg,#10b981,#059669)}.summary-card-icon.average{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-card-icon.period{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.summary-card-content{flex:1 1}.summary-card-value{color:#1e293b;font-size:24px;font-weight:700;line-height:1.2;margin-bottom:4px}.summary-card-label{color:#64748b;font-size:13px;font-weight:500}.chart-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}.chart-container,.chart-header{margin-bottom:24px}.chart-header h2{color:#1e293b;font-size:18px;font-weight:600;margin:0 0 4px}.chart-subtitle{color:#64748b;font-size:13px}.bar-chart{display:flex;flex-direction:column;gap:12px}.bar-row{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:200px 1fr}.bar-label{align-items:center;display:flex;gap:8px}.bar-rank{color:#94a3b8;font-size:12px;font-weight:600;min-width:24px}.bar-name{color:#334155;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-container{background:#f1f5f9;border-radius:6px;height:32px;overflow:hidden;position:relative}.bar-fill{align-items:center;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:6px;display:flex;height:100%;justify-content:flex-end;min-width:60px;padding-right:12px;transition:width .3s ease}.bar-value{color:#fff;font-size:13px;font-weight:600}.data-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.table-header{border-bottom:1px solid #e2e8f0;padding:20px 24px}.table-header h2{color:#1e293b;font-size:18px;font-weight:600;margin:0}.data-table{border-collapse:collapse;width:100%}.data-table thead th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.data-table tbody td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;padding:12px 16px}.data-table tbody tr:hover{background:#fafafa}.data-table tbody tr:last-child td{border-bottom:none}.name-cell{color:#1e293b;font-weight:500}.number-cell{text-align:center}.hours-cell{color:#3b82f6;font-weight:600}.date-cell{color:#64748b;font-size:13px}.projects-cell{max-width:300px}.projects-list{display:flex;flex-wrap:wrap;gap:6px}.project-tag{background:#f0f9ff;border:1px solid #bfdbfe;border-radius:4px;color:#1e40af;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px}.project-tag.more{background:#f1f5f9;border-color:#e2e8f0;color:#64748b}.no-data-cell{color:#94a3b8!important;padding:40px!important;text-align:center!important}.text-muted{color:#94a3b8}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#fff;border:1px solid #e2e8f0;color:#475569}.btn-secondary:hover:not(:disabled){background:#f8fafc}.no-data{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.no-data svg{margin-bottom:16px;opacity:.5}.no-data p{font-size:16px;margin:0}.loading{color:#64748b;padding:40px;text-align:center}@media (max-width:1200px){.bar-row{grid-template-columns:150px 1fr}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.reports-header{align-items:stretch}.filters-row,.reports-header{flex-direction:column}.filter-group{width:100%}.bar-row{gap:8px;grid-template-columns:100px 1fr}.bar-name{font-size:12px}.summary-cards{grid-template-columns:1fr}.data-table-container{overflow-x:auto}.data-table{min-width:700px}}.ml-page{background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1280px;min-height:100vh;padding:28px 32px}.ml-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.ml-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 4px}.ml-subtitle{color:#64748b;font-size:.875rem;margin:0}.ml-btn-primary{align-items:center;background:#6366f1;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 20px;transition:background .18s,box-shadow .18s}.ml-btn-primary:hover:not(:disabled){background:#4f46e5;box-shadow:0 4px 16px #6366f140}.ml-btn-primary:disabled{cursor:not-allowed;opacity:.55}.ml-btn-secondary{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:9px;color:#374151;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:8px;min-height:44px;padding:10px 18px;transition:background .15s}.ml-btn-secondary:hover:not(:disabled){background:#f1f5f9}.ml-btn-secondary:disabled{cursor:not-allowed;opacity:.55}.ml-btn-danger{align-items:center;background:#ef4444;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 18px;transition:background .18s}.ml-btn-danger:hover:not(:disabled){background:#dc2626}.ml-btn-danger:disabled{cursor:not-allowed;opacity:.55}.ml-toast{align-items:center;animation:ml-slide-in .25s ease;border-radius:10px;box-shadow:0 8px 24px #0000001f;display:flex;font-size:.875rem;font-weight:500;gap:10px;max-width:380px;padding:14px 18px;position:fixed;right:24px;top:20px;z-index:9999}@keyframes ml-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.ml-toast-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.ml-toast-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.ml-toast button{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;padding:0}.ml-alert-error{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;display:flex;font-size:.875rem;gap:10px;margin-bottom:20px;padding:12px 16px}.ml-alert-error,.ml-retry-btn{align-items:center;color:#b91c1c}.ml-retry-btn{background:none;border:1px solid #fca5a5;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.8125rem;gap:6px;margin-left:auto;padding:4px 10px}.ml-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:28px}.ml-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:6px;padding:20px;transition:box-shadow .18s}.ml-stat-card:hover{box-shadow:0 4px 16px #6366f11a}.ml-stat-value{font-size:2rem;font-weight:700;line-height:1}.ml-stat-label{color:#64748b;font-size:.8125rem;font-weight:500}.ml-section{margin-bottom:32px}.ml-section-title{color:#0f172a;font-size:1rem;font-weight:700;margin:0 0 16px}.ml-empty-text{color:#94a3b8;font-size:.875rem}.ml-balance-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr))}.ml-balance-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;padding:20px;transition:box-shadow .18s}.ml-balance-card:hover{box-shadow:0 4px 16px #6366f11a}.ml-balance-card-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.ml-balance-name{color:#0f172a;font-size:.9375rem;font-weight:700;margin:0 0 6px}.ml-code-badge{background:#ede9fe;border-radius:20px;color:#5b21b6;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.4px;padding:2px 10px}.ml-balance-badges{align-items:flex-end;display:flex;flex-direction:column;gap:6px}.ml-feature-badge{background:#f0fdf4;border-radius:20px;color:#15803d;display:inline-block;font-size:.6875rem;font-weight:600;padding:2px 8px}.ml-balance-nums{display:flex;justify-content:space-between;margin-bottom:14px}.ml-balance-num{align-items:center;display:flex;flex-direction:column;gap:4px}.ml-balance-num-mid{border-left:1px solid #e2e8f0;border-right:1px solid #e2e8f0;padding:0 16px}.ml-num-val{color:#ef4444;font-size:1.375rem;font-weight:700;line-height:1}.ml-num-lbl{color:#94a3b8;font-size:.75rem;font-weight:500}.ml-progress-wrap{align-items:center;display:flex;gap:10px;margin-bottom:10px}.ml-progress-bg{background:#f1f5f9;border-radius:99px;flex:1 1;height:6px;overflow:hidden}.ml-progress-fill{border-radius:99px;height:100%;transition:width .4s ease}.ml-progress-pct{color:#64748b;font-size:.75rem;font-weight:600;min-width:32px;text-align:right}.ml-carry-fwd{color:#6366f1;font-size:.75rem;font-weight:500;margin:4px 0 0}.ml-holiday-row{display:flex;flex-wrap:wrap;gap:12px}.ml-holiday-chip{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;display:inline-flex;font-size:.875rem;gap:8px;padding:10px 16px}.ml-holiday-icon{color:#6366f1;flex-shrink:0}.ml-holiday-name{color:#0f172a;font-weight:600}.ml-holiday-date{color:#64748b;font-size:.8125rem}.ml-optional-badge{background:#ede9fe;border-radius:20px;color:#5b21b6;font-size:.6875rem;font-weight:600;padding:2px 8px}.ml-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;overflow:hidden;overflow-x:auto}.ml-table{border-collapse:collapse;min-width:680px;width:100%}.ml-table thead{background:#f8fafc}.ml-table th{border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.ml-table td{border-bottom:1px solid #f1f5f9;color:#374151;font-size:.875rem;padding:14px 16px;vertical-align:middle}.ml-table tbody tr:last-child td{border-bottom:none}.ml-table tbody tr:hover{background:#fafbff}.ml-req-type{color:#0f172a;font-weight:600}.ml-half-badge{background:#fef3c7;border-radius:20px;color:#92400e;display:inline-block;font-size:.6875rem;font-weight:600;margin-left:8px;padding:2px 8px}.ml-period{align-items:center;color:#374151;display:flex;gap:4px;white-space:nowrap}.ml-period svg{color:#94a3b8}.ml-status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.75rem;font-weight:700;gap:5px;padding:4px 12px;white-space:nowrap}.ml-status-pending{background:#fef3c7;color:#92400e}.ml-status-approved{background:#dcfce7;color:#15803d}.ml-status-rejected{background:#fee2e2;color:#991b1b}.ml-status-cancelled{background:#f1f5f9;color:#64748b}.ml-actions{display:flex;gap:8px}.ml-action-view{background:none;border:1px solid #e2e8f0;border-radius:7px;color:#6366f1;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:600;padding:5px 12px;transition:background .15s}.ml-action-view:hover{background:#eef2ff}.ml-action-cancel{background:none;border:1px solid #fca5a5;border-radius:7px;color:#ef4444;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:600;padding:5px 12px;transition:background .15s}.ml-action-cancel:hover{background:#fef2f2}.ml-empty-state{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;color:#94a3b8;display:flex;flex-direction:column;gap:16px;padding:60px 20px;text-align:center}.ml-empty-state p{color:#64748b;font-size:1rem;margin:0}.ml-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:.9375rem;gap:16px;justify-content:center;min-height:60vh}.ml-spinner{animation:ml-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes ml-spin{to{transform:rotate(1turn)}}.ml-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.ml-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0000002e;max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.ml-modal-sm{max-width:400px}.ml-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.ml-modal-header h2{color:#0f172a;font-size:1.0625rem;font-weight:700;margin:0}.ml-modal-close{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:4px;transition:color .15s}.ml-modal-close:hover{color:#0f172a}.ml-modal-body{padding:24px}.ml-modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.ml-form-group{margin-bottom:18px}.ml-form-group label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.ml-form-group input,.ml-form-group select,.ml-form-group textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:10px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.ml-form-group input:focus,.ml-form-group select:focus,.ml-form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.ml-form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.ml-form-check label{display:block;margin-bottom:4px}.ml-check-label{align-items:center;cursor:pointer;display:flex!important;gap:10px}.ml-check-label input[type=checkbox]{accent-color:#6366f1;cursor:pointer;flex-shrink:0;height:16px;width:16px}.ml-form-group small{color:#94a3b8;display:block;font-size:.75rem;margin-top:4px}.ml-balance-hint{align-items:center;background:#f0fdf4;border:1px solid #bbf7d0;color:#374151;display:flex;gap:8px;padding:10px 14px}.ml-balance-hint,.ml-days-preview{border-radius:8px;font-size:.875rem;margin-bottom:18px}.ml-days-preview{background:#eef2ff;color:#4338ca;display:inline-block;font-weight:600;padding:8px 14px}.ml-form-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;display:flex;font-size:.875rem;gap:8px;margin-bottom:16px;padding:10px 14px}.ml-detail-body{padding:20px 24px}.ml-detail-row{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;gap:16px;justify-content:space-between;padding:12px 0}.ml-detail-row:last-child{border-bottom:none}.ml-detail-lbl{color:#64748b;font-size:.875rem;font-weight:600;white-space:nowrap}.ml-detail-val{color:#0f172a;font-size:.875rem;font-weight:500;text-align:right}.ml-rejection-reason{background:#fef2f2;border-left:3px solid #ef4444;border-radius:6px;color:#991b1b;font-size:.875rem;line-height:1.5;margin-top:12px;padding:12px 16px}.ml-confirm-text{color:#374151;font-size:.9375rem;line-height:1.6;margin:0}@media (max-width:1024px){.ml-stats-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.ml-page{padding:16px}.ml-header{flex-direction:column}.ml-stats-row{gap:12px;grid-template-columns:repeat(2,1fr)}.ml-stat-value{font-size:1.5rem}.ml-form-row{grid-template-columns:1fr}.ml-modal{max-width:calc(100% - 32px)}.ml-holiday-row{flex-direction:column}.ml-holiday-chip{width:100%}}@media (prefers-reduced-motion:reduce){.ml-spinner,.ml-toast{animation:none}}.tlr-page{background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1440px;min-height:100vh;padding:28px 32px}.tlr-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.tlr-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 4px}.tlr-subtitle{color:#64748b;font-size:.875rem;margin:0}.tlr-refresh-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:9px;color:#64748b;cursor:pointer;display:flex;justify-content:center;min-height:44px;min-width:44px;padding:10px;transition:background .15s,color .15s}.tlr-refresh-btn:hover{background:#f1f5f9;color:#0f172a}.tlr-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.tlr-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:6px;padding:20px}.tlr-stat-pending{background:#fffbeb;border-color:#fde68a}.tlr-stat-num{color:#d97706;font-size:2rem;font-weight:700;line-height:1}.tlr-stat-lbl{color:#64748b;font-size:.8125rem;font-weight:500}.tlr-alert-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;font-size:.875rem;gap:10px;margin-bottom:20px;padding:12px 16px}.tlr-retry-btn{background:none;border:1px solid #fca5a5;border-radius:7px;color:#b91c1c;cursor:pointer;font-family:inherit;font-size:.8125rem;margin-left:auto;padding:4px 12px}.tlr-toast{align-items:center;animation:tlr-slide-in .25s ease;border-radius:10px;box-shadow:0 8px 24px #0000001f;display:flex;font-size:.875rem;font-weight:500;gap:10px;max-width:380px;padding:14px 18px;position:fixed;right:24px;top:20px;z-index:9999}@keyframes tlr-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.tlr-toast-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.tlr-toast-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.tlr-toast button{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;padding:0}.tlr-filter-bar{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000f;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px;padding:8px 16px}.tlr-tabs{display:flex;gap:4px}.tlr-tab{align-items:center;background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:8px;padding:8px 16px;transition:background .15s,color .15s}.tlr-tab:hover{background:#f1f5f9;color:#0f172a}.tlr-tab-active{background:#eef2ff;color:#4338ca;font-weight:700}.tlr-badge{background:#ef4444;border-radius:20px;color:#fff;font-size:.6875rem;font-weight:700;padding:2px 7px}.tlr-search-box{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:8px;min-width:220px;padding:8px 12px}.tlr-search-icon{color:#94a3b8;flex-shrink:0}.tlr-search-box input{background:#0000;border:none;color:#0f172a;flex:1 1;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none}.tlr-search-clear{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:0}.tlr-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:40vh}.tlr-spinner{animation:tlr-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes tlr-spin{to{transform:rotate(1turn)}}.tlr-empty{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;color:#94a3b8;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.tlr-empty p{color:#64748b;font-size:1rem;margin:0}.tlr-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;overflow:hidden;overflow-x:auto}.tlr-table{border-collapse:collapse;min-width:900px;width:100%}.tlr-table thead{background:#f8fafc}.tlr-table th{border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:12px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.tlr-table td{border-bottom:1px solid #f1f5f9;color:#374151;font-size:.875rem;padding:14px;vertical-align:middle}.tlr-table tbody tr:last-child td{border-bottom:none}.tlr-table tbody tr:hover{background:#fafbff}.tlr-emp-cell{display:flex;flex-direction:column;gap:3px}.tlr-emp-cell strong{color:#0f172a;font-size:.875rem;font-weight:700}.tlr-emp-cell span{color:#94a3b8;font-size:.75rem}.tlr-type-name{color:#0f172a;font-weight:600}.tlr-half-badge{background:#fef3c7;border-radius:20px;color:#92400e;display:inline-block;font-size:.6875rem;font-weight:600;margin-left:6px;padding:2px 7px}.tlr-period{display:flex;flex-direction:column;font-size:.8125rem;gap:2px}.tlr-to{color:#94a3b8}.tlr-reason-truncate{color:#64748b;cursor:default;display:block;font-size:.8125rem;max-width:180px}.tlr-status-badge{border-radius:20px;display:inline-block;font-size:.75rem;font-weight:700;padding:4px 12px;white-space:nowrap}.tlr-status-pending{background:#fef3c7;color:#92400e}.tlr-status-approved{background:#dcfce7;color:#15803d}.tlr-status-rejected{background:#fee2e2;color:#991b1b}.tlr-status-cancelled{background:#f1f5f9;color:#64748b}.tlr-action-btns{display:flex;gap:6px}.tlr-btn-view{align-items:center;background:none;border:1px solid #e2e8f0;border-radius:7px;color:#6366f1;cursor:pointer;display:flex;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:background .15s}.tlr-btn-view:hover{background:#eef2ff}.tlr-btn-approve{align-items:center;background:none;border:1px solid #bbf7d0;border-radius:7px;color:#16a34a;cursor:pointer;display:flex;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:background .15s}.tlr-btn-approve:hover:not(:disabled){background:#dcfce7}.tlr-btn-approve:disabled{cursor:not-allowed;opacity:.5}.tlr-btn-reject{align-items:center;background:none;border:1px solid #fecaca;border-radius:7px;color:#ef4444;cursor:pointer;display:flex;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:background .15s}.tlr-btn-reject:hover{background:#fef2f2}.tlr-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.tlr-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0000002e;max-height:90vh;max-width:520px;overflow-y:auto;width:100%}.tlr-modal-lg{max-width:840px}.tlr-modal-sm{max-width:440px}.tlr-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.tlr-modal-header h2{color:#0f172a;font-size:1.0625rem;font-weight:700;margin:0}.tlr-modal-close{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:4px;transition:color .15s}.tlr-modal-close:hover{color:#0f172a}.tlr-modal-body{padding:24px}.tlr-modal-footer{border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;padding:16px 24px}.tlr-details-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.tlr-detail-section{background:#f8fafc;border-radius:10px;padding:16px}.tlr-full{grid-column:1/-1}.tlr-detail-section h4{color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.8px;margin:0 0 12px;text-transform:uppercase}.tlr-detail-row{border-bottom:1px solid #e2e8f0;display:flex;font-size:.875rem;gap:12px;justify-content:space-between;padding:8px 0}.tlr-detail-row:last-child{border-bottom:none}.tlr-detail-row span:first-child{color:#64748b;font-weight:500}.tlr-detail-row span:last-child{color:#0f172a;font-weight:600;text-align:right}.tlr-reason-text{color:#374151;font-size:.875rem;line-height:1.6;margin:0}.tlr-status-info{display:flex;flex-direction:column;gap:10px}.tlr-status-detail{color:#64748b;font-size:.8125rem;margin:0}.tlr-rejection-block{background:#fef2f2;border-left:3px solid #ef4444;border-radius:6px;color:#991b1b;font-size:.875rem;line-height:1.5;padding:10px 14px}.tlr-loading-text,.tlr-no-balance{color:#94a3b8;font-size:.875rem;margin:0}.tlr-balance-snapshot{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr))}.tlr-balance-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px}.tlr-balance-type{color:#0f172a;font-size:.8125rem;font-weight:700;margin:0 0 8px}.tlr-balance-nums{color:#64748b;display:flex;flex-wrap:wrap;font-size:.75rem;gap:4px;justify-content:space-between;margin-bottom:8px}.tlr-balance-nums strong{color:#0f172a}.tlr-used{color:#ef4444!important}.tlr-avail{color:#16a34a!important}.tlr-mini-progress{background:#f1f5f9;border-radius:99px;height:5px;overflow:hidden}.tlr-mini-fill{border-radius:99px;height:100%;transition:width .4s}.tlr-form-group{margin-bottom:4px}.tlr-form-group label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.tlr-form-group textarea{border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:10px 12px;resize:vertical;transition:border-color .15s,box-shadow .15s;width:100%}.tlr-form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.tlr-btn-secondary{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:9px;color:#374151;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:8px;min-height:44px;padding:10px 18px;transition:background .15s}.tlr-btn-secondary:hover:not(:disabled){background:#f1f5f9}.tlr-btn-secondary:disabled{cursor:not-allowed;opacity:.55}.tlr-btn-approve-full{align-items:center;background:#16a34a;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 20px;transition:background .18s}.tlr-btn-approve-full:hover:not(:disabled){background:#15803d}.tlr-btn-approve-full:disabled{cursor:not-allowed;opacity:.55}.tlr-btn-reject-full{align-items:center;background:#ef4444;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 18px;transition:background .18s}.tlr-btn-reject-full:hover:not(:disabled){background:#dc2626}.tlr-btn-reject-full:disabled{cursor:not-allowed;opacity:.55}@media (max-width:1024px){.tlr-stats-row{grid-template-columns:repeat(3,1fr)}.tlr-details-grid{grid-template-columns:1fr}.tlr-balance-snapshot{grid-template-columns:1fr 1fr}}@media (max-width:768px){.tlr-page{padding:16px}.tlr-stats-row{grid-template-columns:1fr 1fr}.tlr-filter-bar{align-items:stretch;flex-direction:column}.tlr-tabs{overflow-x:auto}.tlr-search-box{width:100%}.tlr-modal,.tlr-modal-lg{max-width:calc(100% - 32px)}.tlr-balance-snapshot{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.tlr-spinner,.tlr-toast{animation:none}}.lp-page{background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1280px;min-height:100vh;padding:28px 32px}.lp-header{flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.lp-header,.lp-header-left{align-items:center;display:flex}.lp-header-left{gap:14px}.lp-header-icon{color:#6366f1;flex-shrink:0}.lp-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 4px}.lp-subtitle{color:#64748b;font-size:.875rem;margin:0}.lp-btn-primary{align-items:center;background:#6366f1;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 20px;transition:background .18s,box-shadow .18s}.lp-btn-primary:hover:not(:disabled){background:#4f46e5;box-shadow:0 4px 16px #6366f140}.lp-btn-primary:disabled{cursor:not-allowed;opacity:.55}.lp-btn-secondary{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:9px;color:#374151;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:8px;min-height:44px;padding:10px 18px;transition:background .15s}.lp-btn-secondary:hover:not(:disabled){background:#f1f5f9}.lp-btn-secondary:disabled{cursor:not-allowed;opacity:.55}.lp-btn-danger{align-items:center;background:#ef4444;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 18px;transition:background .18s}.lp-btn-danger:hover:not(:disabled){background:#dc2626}.lp-btn-danger:disabled{cursor:not-allowed;opacity:.55}.lp-toast{align-items:center;animation:lp-slide-in .25s ease;border-radius:10px;box-shadow:0 8px 24px #0000001f;display:flex;font-size:.875rem;font-weight:500;gap:10px;max-width:380px;padding:14px 18px;position:fixed;right:24px;top:20px;z-index:9999}@keyframes lp-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.lp-toast-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.lp-toast-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.lp-toast button{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;padding:0}.lp-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:28px}.lp-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:6px;padding:20px}.lp-stat-val{font-size:2rem;font-weight:700;line-height:1}.lp-stat-lbl{color:#64748b;font-size:.8125rem;font-weight:500}.lp-alert-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;font-size:.875rem;gap:10px;margin-bottom:20px;padding:12px 16px}.lp-retry-btn{background:none;border:1px solid #fca5a5;border-radius:7px;color:#b91c1c;cursor:pointer;font-family:inherit;font-size:.8125rem;margin-left:auto;padding:4px 12px}.lp-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:40vh}.lp-spinner{animation:lp-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes lp-spin{to{transform:rotate(1turn)}}.lp-empty{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;color:#94a3b8;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.lp-empty h3{color:#374151;font-size:1.125rem;font-weight:700;margin:0}.lp-empty p{color:#64748b;font-size:.875rem;margin:0}.lp-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr))}.lp-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;padding:22px;transition:box-shadow .18s,transform .18s}.lp-card:hover{box-shadow:0 4px 16px #6366f11a;transform:translateY(-2px)}.lp-card-inactive{border-color:#f1f5f9;opacity:.65}.lp-card-header{margin-bottom:14px}.lp-card-title-row{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.lp-type-name{color:#0f172a;font-size:1rem;font-weight:700;margin:0 0 8px}.lp-type-badges{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.lp-code-badge{background:#ede9fe;color:#5b21b6}.lp-code-badge,.lp-paid-badge{border-radius:20px;display:inline-block;font-size:.6875rem;font-weight:700;padding:2px 10px}.lp-paid{background:#dcfce7;color:#15803d}.lp-unpaid{background:#fef3c7;color:#92400e}.lp-inactive-badge{background:#f1f5f9;border-radius:20px;color:#64748b;display:inline-block;font-size:.6875rem;font-weight:700;padding:2px 10px}.lp-card-actions{display:flex;flex-shrink:0;gap:6px}.lp-btn-icon{align-items:center;background:none;border:1px solid #e2e8f0;border-radius:7px;color:#64748b;cursor:pointer;display:flex;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:background .15s,color .15s}.lp-btn-icon:hover{background:#eef2ff;color:#6366f1}.lp-btn-icon-danger:hover{background:#fef2f2;border-color:#fecaca;color:#ef4444}.lp-type-desc{color:#64748b;font-size:.8125rem;line-height:1.5;margin:0 0 14px}.lp-metrics{border-bottom:1px solid #f1f5f9;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:14px;padding:12px 0}.lp-metric{align-items:center;display:flex;flex-direction:column;min-width:60px}.lp-metric-val{color:#0f172a;font-size:1.25rem;font-weight:700;line-height:1;margin-bottom:4px}.lp-metric-lbl{color:#94a3b8;font-size:.6875rem;font-weight:500;text-align:center}.lp-rule-badges{display:flex;flex-wrap:wrap;gap:6px}.lp-rule-badge{background:#f1f5f9;border-radius:20px;color:#475569;display:inline-block;font-size:.6875rem;font-weight:600;padding:3px 10px}.lp-rule-approval{background:#ede9fe;color:#5b21b6}.lp-rule-carry{background:#fef3c7;color:#92400e}.lp-rule-accrual{background:#dbeafe;color:#1e40af}.lp-rule-weekend{background:#fce7f3;color:#9d174d}.lp-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.lp-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0000002e;max-height:90vh;max-width:580px;overflow-y:auto;width:100%}.lp-modal-sm{max-width:420px}.lp-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.lp-modal-header h2{color:#0f172a;font-size:1.0625rem;font-weight:700;margin:0}.lp-modal-close{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:4px;transition:color .15s}.lp-modal-close:hover{color:#0f172a}.lp-modal-tabs{background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;padding:0 24px}.lp-modal-tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;margin-bottom:-1px;padding:12px 16px;transition:color .15s,border-color .15s}.lp-modal-tab:hover{color:#0f172a}.lp-modal-tab-active{border-bottom-color:#6366f1;color:#6366f1;font-weight:700}.lp-modal-body{padding:24px}.lp-modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.lp-tab-content{display:flex;flex-direction:column;gap:0}.lp-form-group{margin-bottom:18px}.lp-form-group label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.lp-form-group input[type=number],.lp-form-group input[type=text],.lp-form-group select,.lp-form-group textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:10px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.lp-form-group input:focus,.lp-form-group select:focus,.lp-form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.lp-form-group small{color:#94a3b8;display:block;font-size:.75rem;margin-top:5px}.lp-form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-bottom:18px}.lp-form-group-check{display:flex;flex-direction:column;gap:14px;justify-content:center;margin-bottom:0}.lp-form-group-check label{margin-bottom:0}.lp-check-label{align-items:center;color:#374151;cursor:pointer;display:flex!important;font-size:.875rem;font-weight:500;gap:10px;margin-bottom:0!important}.lp-check-label input[type=checkbox]{accent-color:#6366f1;cursor:pointer;flex-shrink:0;height:16px;width:16px}.lp-check-block{align-items:flex-start;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;gap:12px;margin-bottom:16px;padding:14px}.lp-check-block input{margin-top:2px}.lp-check-block>div{display:flex;flex-direction:column;gap:4px}.lp-check-block span{font-size:.875rem;font-weight:600}.lp-check-block small{color:#94a3b8;font-size:.75rem;font-weight:400}.lp-indent{background:#f8fafc;border-left:3px solid #e2e8f0;border-radius:0 8px 8px 0;margin-bottom:16px;margin-left:28px;padding:14px}.lp-toggle-list{display:flex;flex-direction:column;gap:2px}.lp-toggle-row{align-items:center;background:#f8fafc;border-radius:9px;color:#374151;display:flex;font-size:.875rem;font-weight:500;justify-content:space-between;margin-bottom:6px;padding:12px 16px}.lp-toggle-btn{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:0;transition:color .15s}.lp-toggle-on{color:#6366f1}.lp-form-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;display:flex;font-size:.875rem;gap:8px;margin-bottom:16px;padding:10px 14px}.lp-confirm-text{color:#374151;font-size:.9375rem;line-height:1.6;margin:0}@media (max-width:1024px){.lp-stats-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.lp-page{padding:16px}.lp-header{align-items:flex-start;flex-direction:column}.lp-stats-row{gap:12px;grid-template-columns:repeat(2,1fr)}.lp-form-row,.lp-grid{grid-template-columns:1fr}.lp-modal{max-width:calc(100% - 32px)}.lp-modal-tabs{overflow-x:auto;padding:0 12px}}@media (prefers-reduced-motion:reduce){.lp-spinner,.lp-toast{animation:none}.lp-card{transition:none}}.hl-page{background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1280px;min-height:100vh;padding:28px 32px}.hl-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.hl-header-left{align-items:center;display:flex;gap:14px}.hl-header-icon{color:#6366f1;flex-shrink:0}.hl-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 4px}.hl-subtitle{color:#64748b;font-size:.875rem;margin:0}.hl-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.hl-year-nav{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;gap:8px;padding:6px 10px}.hl-year-btn,.hl-year-nav{align-items:center;display:flex}.hl-year-btn{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;justify-content:center;min-height:32px;min-width:32px;padding:4px 6px;transition:background .15s,color .15s}.hl-year-btn:hover{background:#f1f5f9;color:#0f172a}.hl-year-label{color:#0f172a;font-size:.9375rem;font-weight:700;min-width:48px;text-align:center}.hl-btn-primary{align-items:center;background:#6366f1;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 20px;transition:background .18s,box-shadow .18s}.hl-btn-primary:hover:not(:disabled){background:#4f46e5;box-shadow:0 4px 16px #6366f140}.hl-btn-primary:disabled{cursor:not-allowed;opacity:.55}.hl-btn-secondary{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:9px;color:#374151;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:8px;min-height:44px;padding:10px 18px;transition:background .15s}.hl-btn-secondary:hover:not(:disabled){background:#f1f5f9}.hl-btn-secondary:disabled{cursor:not-allowed;opacity:.55}.hl-btn-danger{align-items:center;background:#ef4444;border:none;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 18px;transition:background .18s}.hl-btn-danger:hover:not(:disabled){background:#dc2626}.hl-btn-danger:disabled{cursor:not-allowed;opacity:.55}.hl-toast{align-items:center;animation:hl-slide-in .25s ease;border-radius:10px;box-shadow:0 8px 24px #0000001f;display:flex;font-size:.875rem;font-weight:500;gap:10px;max-width:380px;padding:14px 18px;position:fixed;right:24px;top:20px;z-index:9999}@keyframes hl-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.hl-toast-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.hl-toast-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.hl-toast button{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;padding:0}.hl-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:28px}.hl-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:6px;padding:20px}.hl-stat-val{font-size:2rem;font-weight:700;line-height:1}.hl-stat-lbl{color:#64748b;font-size:.8125rem;font-weight:500}.hl-alert-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;font-size:.875rem;gap:10px;margin-bottom:20px;padding:12px 16px}.hl-retry-btn{background:none;border:1px solid #fca5a5;border-radius:7px;color:#b91c1c;cursor:pointer;font-family:inherit;font-size:.8125rem;margin-left:auto;padding:4px 12px}.hl-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:40vh}.hl-spinner{animation:hl-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes hl-spin{to{transform:rotate(1turn)}}.hl-empty{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;color:#94a3b8;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.hl-empty h3{color:#374151;font-size:1.125rem;font-weight:700;margin:0}.hl-empty p{color:#64748b;font-size:.875rem;margin:0}.hl-months{display:flex;flex-direction:column;gap:28px}.hl-month-title{border-left:4px solid #6366f1;color:#0f172a;font-size:1.0625rem;font-weight:700;margin:0 0 14px;padding-left:12px}.hl-holiday-grid{display:flex;flex-direction:column;gap:8px}.hl-holiday-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;gap:16px;padding:16px 20px;transition:box-shadow .15s}.hl-holiday-card:hover{box-shadow:0 4px 12px #6366f114}.hl-holiday-date-col{align-items:center;background:#f1f5f9;border-radius:10px;display:flex;flex-direction:column;min-width:52px;padding:8px}.hl-day-num{color:#6366f1;font-size:1.5rem;font-weight:800;line-height:1}.hl-day-name{color:#94a3b8;font-size:.6875rem;font-weight:600;margin-top:2px;text-transform:uppercase}.hl-holiday-info{flex:1 1}.hl-holiday-name{color:#0f172a;font-size:.9375rem;font-weight:700;margin:0 0 4px}.hl-holiday-desc{color:#64748b;font-size:.8125rem;line-height:1.4;margin:0 0 8px}.hl-holiday-tags{display:flex;gap:6px}.hl-tag{border-radius:20px;display:inline-block;font-size:.6875rem;font-weight:700;padding:3px 10px}.hl-tag-public{background:#dbeafe;color:#1e40af}.hl-tag-optional{background:#ede9fe;color:#5b21b6}.hl-holiday-actions{display:flex;flex-shrink:0;gap:6px}.hl-btn-icon{align-items:center;background:none;border:1px solid #e2e8f0;border-radius:7px;color:#64748b;cursor:pointer;display:flex;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:background .15s,color .15s}.hl-btn-icon:hover{background:#eef2ff;color:#6366f1}.hl-btn-icon-danger:hover{background:#fef2f2;border-color:#fecaca;color:#ef4444}.hl-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.hl-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0000002e;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.hl-modal-sm{max-width:400px}.hl-modal-lg{max-width:720px}.hl-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.hl-modal-header h2{color:#0f172a;font-size:1.0625rem;font-weight:700;margin:0}.hl-modal-close{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:4px;transition:color .15s}.hl-modal-close:hover{color:#0f172a}.hl-modal-body{padding:24px}.hl-modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.hl-form-group{margin-bottom:18px}.hl-form-group label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.hl-form-group input,.hl-form-group textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;padding:10px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.hl-form-group input:focus,.hl-form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.hl-form-group small{color:#94a3b8;display:block;font-size:.75rem;margin-top:5px}.hl-check-label{align-items:center;cursor:pointer;display:flex!important;gap:10px}.hl-check-label input[type=checkbox]{accent-color:#6366f1;cursor:pointer;flex-shrink:0;height:16px;width:16px}.hl-form-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;display:flex;font-size:.875rem;gap:8px;margin-bottom:16px;padding:10px 14px}.hl-confirm-text{color:#374151;font-size:.9375rem;line-height:1.6;margin:0}.hl-bulk-textarea{border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-family:monospace;font-size:.8125rem;padding:10px 12px;resize:vertical;transition:border-color .15s;width:100%}.hl-bulk-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.hl-preview-section{border:1px solid #e2e8f0;border-radius:10px;margin-top:20px;overflow:hidden}.hl-preview-title{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#0f172a;font-size:.875rem;font-weight:700;margin:0;padding:12px 16px}.hl-preview-table-wrap{max-height:280px;overflow-x:auto;overflow-y:auto}.hl-preview-table{border-collapse:collapse;font-size:.8125rem;width:100%}.hl-preview-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.6875rem;font-weight:700;padding:10px 14px;text-align:left;text-transform:uppercase}.hl-preview-table td{border-bottom:1px solid #f1f5f9;color:#374151;padding:10px 14px}.hl-preview-table tbody tr:last-child td{border-bottom:none}.hl-dup-row{background:#fef9f0}.hl-dup-badge{background:#fef3c7;color:#92400e}.hl-dup-badge,.hl-new-badge{border-radius:20px;display:inline-block;font-size:.6875rem;font-weight:700;padding:2px 8px}.hl-new-badge{background:#dcfce7;color:#15803d}.hl-import-results{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;margin-top:16px;padding:16px}.hl-import-results h4{color:#15803d;font-size:.875rem;font-weight:700;margin:0 0 12px}.hl-import-stats{display:flex;flex-wrap:wrap;gap:12px}.hl-import-stat{border-radius:8px;display:inline-block;font-size:.875rem;font-weight:700;padding:6px 14px}.hl-import-ok{background:#dcfce7;color:#15803d}.hl-import-dup{background:#fef3c7;color:#92400e}.hl-import-err{background:#fee2e2;color:#991b1b}.hl-error-list{color:#991b1b;font-size:.8125rem;margin:12px 0 0;padding-left:20px}.hl-error-list li{margin-bottom:4px}@media (max-width:768px){.hl-page{padding:16px}.hl-header{align-items:flex-start;flex-direction:column}.hl-stats-row{grid-template-columns:1fr 1fr}.hl-holiday-card{flex-wrap:wrap}.hl-modal,.hl-modal-lg{max-width:calc(100% - 32px)}}@media (prefers-reduced-motion:reduce){.hl-spinner,.hl-toast{animation:none}}.bulk-import-modal{max-width:800px;width:90%}.bulk-import-modal .modal-body{max-height:70vh;overflow-y:auto}.year-input{border:1px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:14px;padding:10px;width:100%}.year-input::-webkit-inner-spin-button,.year-input::-webkit-outer-spin-button{opacity:1}.help-text{color:#666;font-size:12px;margin-bottom:8px;margin-top:4px}.import-textarea{font-family:Courier New,monospace;font-size:13px;line-height:1.5}.preview-section{background:#f8f9fa;border-radius:8px;margin-top:24px;padding:16px}.preview-section h3{font-size:16px;font-weight:600;margin-bottom:12px}.preview-table-container{border:1px solid #dee2e6;border-radius:6px;max-height:300px;overflow-y:auto}.preview-table{background:#fff;border-collapse:collapse;width:100%}.preview-table thead{background:#f1f3f5;position:-webkit-sticky;position:sticky;top:0;z-index:1}.preview-table td,.preview-table th{border-bottom:1px solid #dee2e6;padding:10px 12px;text-align:left}.preview-table th{color:#495057;font-size:13px;font-weight:600}.preview-table td{font-size:14px}.preview-table tr.duplicate-row{background-color:#fff3cd}.badge{font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 8px;text-transform:uppercase}.badge-success{background-color:#d4edda;color:#155724}.badge-warning{background-color:#fff3cd;color:#856404}.import-results{background:#e8f5e9;border:1px solid #c3e6cb;border-radius:8px;margin-top:24px;padding:16px}.import-results h3{color:#155724;font-size:16px;font-weight:600;margin-bottom:12px}.results-summary{display:flex;gap:16px;margin-bottom:16px}.result-item{border-radius:6px;flex:1 1;padding:12px;text-align:center}.result-item.success{background:#d4edda;color:#155724}.result-item.warning{background:#fff3cd;color:#856404}.result-item.error{background:#f8d7da;color:#721c24}.result-item strong{display:block;font-size:24px;margin-bottom:4px}.error-details{background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;margin-top:12px;padding:12px}.error-details h4{color:#721c24;font-size:14px;font-weight:600;margin-bottom:8px}.error-details ul{color:#721c24;font-size:13px;margin:0;padding-left:20px}.error-details li{margin-bottom:4px}@media (max-width:768px){padding:16px;.page-header{align-items:flex-start;flex-direction:column;gap:12px}.holiday-filters{flex-direction:column;gap:8px}.holidays-table{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:480px){.holiday-actions{flex-direction:column;gap:6px}.holiday-actions button{width:100%}}.balance-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-top:24px}.balance-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;transition:all .2s}.balance-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.balance-header{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.balance-header h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 4px}.leave-code{background:#f3f4f6;border-radius:4px;color:#6b7280;display:inline-block;padding:2px 8px}.badge,.leave-code{font-size:12px;font-weight:500}.badge{align-items:center;border-radius:12px;display:inline-flex;gap:4px;padding:4px 12px}.badge-info{background:#dbeafe;color:#1e40af}.balance-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.stat-item{gap:12px}.stat-icon,.stat-item{align-items:center;display:flex}.stat-icon{border-radius:8px;flex-shrink:0;height:40px;justify-content:center;width:40px}.stat-details{display:flex;flex-direction:column;gap:2px}.stat-label{color:#6b7280;font-size:12px;font-weight:500}.stat-value{color:#111827;font-size:16px;font-weight:600}.carry-forward-info{background:#fef3c7;border:1px solid #fde047;border-radius:8px;color:#92400e;font-size:13px;font-weight:500;margin-bottom:16px;padding:8px 12px}.progress-section{margin-top:16px}.progress-header{color:#6b7280;display:flex;font-size:13px;font-weight:500;justify-content:space-between;margin-bottom:8px}.progress-bar{background:#f3f4f6;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .3s ease}.progress-legend{color:#9ca3af;display:flex;font-size:12px;justify-content:space-between}.year-selector{align-items:center;display:flex;gap:8px}.year-selector label{color:#6b7280;font-size:14px;font-weight:500}.year-selector select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px;transition:border-color .2s}.year-selector select:hover{border-color:#3b82f6}.year-selector select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.empty-state{background:#fff;border:2px dashed #e5e7eb;border-radius:12px;padding:60px 20px;text-align:center}.empty-state h3{color:#374151;font-size:18px;margin:16px 0 8px}.empty-state p{color:#9ca3af;font-size:14px;margin:0}@media (max-width:768px){.balance-grid,.balance-stats{grid-template-columns:1fr}.page-header{align-items:flex-start;flex-direction:column;gap:16px}}.header-actions{align-items:center;display:flex;gap:12px}.filters-bar{background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px}.search-box{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;flex:1 1;gap:8px;padding:8px 12px}.search-box input{background:#0000;border:none;flex:1 1;font-size:14px;outline:none}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;min-width:180px;padding:8px 12px}.team-balance-list{display:flex;flex-direction:column;gap:20px}.employee-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.employee-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px}.employee-info h3{font-size:18px;font-weight:600;margin:0 0 4px}.employee-meta{font-size:13px;opacity:.9}.leave-types-table{overflow-x:auto}.leave-types-table table{border-collapse:collapse;width:100%}.leave-types-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.leave-types-table th{color:#6b7280;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.leave-types-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:16px}.leave-types-table tbody tr:last-child td{border-bottom:none}.leave-types-table tbody tr:hover{background:#f9fafb}.leave-type-cell{display:flex;flex-direction:column;gap:2px}.leave-type-name{color:#111827;font-weight:500}.leave-type-code{color:#6b7280;font-size:12px}.accrued-badge{background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-block;font-size:13px;font-weight:500;padding:2px 8px}.used-days{color:#dc2626;font-weight:500}.available-days{color:#059669;font-weight:600}.carry-forward-badge{background:#fef3c7;border-radius:4px;color:#92400e;display:inline-block;font-size:13px;font-weight:500;padding:2px 8px}.text-muted{color:#9ca3af}.usage-indicator{align-items:center;display:flex;gap:8px}.mini-progress{background:#f3f4f6;border-radius:3px;flex:1 1;height:6px;min-width:60px;overflow:hidden}.mini-progress-fill{border-radius:3px;height:100%;transition:width .3s ease}.usage-text{color:#6b7280;font-size:12px;font-weight:500;min-width:35px}@media (max-width:1024px){.filters-bar{flex-direction:column}.filter-select,.search-box{width:100%}.header-actions{flex-direction:column;width:100%}.leave-types-table{font-size:12px}.leave-types-table td,.leave-types-table th{padding:10px 8px}}.lb-page{background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1280px;min-height:100vh;padding:28px 32px}.lb-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.lb-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 4px}.lb-subtitle{color:#64748b;font-size:.875rem;margin:0}.lb-year-nav{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;gap:8px;padding:6px 10px}.lb-year-btn,.lb-year-nav{align-items:center;display:flex}.lb-year-btn{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;justify-content:center;min-height:32px;min-width:32px;padding:4px 6px;transition:background .15s,color .15s}.lb-year-btn:hover{background:#f1f5f9;color:#0f172a}.lb-year-label{color:#0f172a;font-size:.9375rem;font-weight:700;min-width:48px;text-align:center}.lb-alert-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;font-size:.875rem;gap:10px;margin-bottom:20px;padding:12px 16px}.lb-retry-btn{background:none;border:1px solid #fca5a5;border-radius:7px;color:#b91c1c;cursor:pointer;font-family:inherit;font-size:.8125rem;margin-left:auto;padding:4px 12px}.lb-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:50vh}.lb-spinner{animation:lb-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes lb-spin{to{transform:rotate(1turn)}}.lb-empty-state{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;color:#94a3b8;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.lb-empty-state h3{color:#374151;font-size:1.125rem;font-weight:700;margin:0}.lb-empty-state p{color:#64748b;font-size:.875rem;margin:0;max-width:360px}.lb-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr))}.lb-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;padding:22px;transition:box-shadow .18s,transform .18s}.lb-card:hover{box-shadow:0 4px 16px #6366f11a;transform:translateY(-2px)}.lb-card-header{margin-bottom:18px}.lb-card-title-row{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.lb-type-name{color:#0f172a;font-size:1rem;font-weight:700;margin:0 0 6px}.lb-code-badge{background:#ede9fe;color:#5b21b6;display:inline-block;letter-spacing:.5px;padding:2px 10px}.lb-accrual-badge,.lb-code-badge{border-radius:20px;font-size:.6875rem;font-weight:700}.lb-accrual-badge{align-items:center;background:#e0f2fe;color:#0369a1;display:inline-flex;gap:5px;padding:4px 10px;white-space:nowrap}.lb-stats{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.lb-stat-item{gap:12px}.lb-stat-icon,.lb-stat-item{align-items:center;display:flex}.lb-stat-icon{border-radius:9px;flex-shrink:0;height:36px;justify-content:center;width:36px}.lb-stat-lbl{color:#94a3b8;font-size:.75rem;font-weight:500;margin:0 0 2px}.lb-stat-val{color:#0f172a;font-size:.9375rem;font-weight:700;margin:0}.lb-val-used{color:#ef4444}.lb-val-avail{color:#16a34a}.lb-carry-row{align-items:center;background:#eef2ff;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:14px;padding:8px 12px}.lb-carry-label{color:#4338ca;font-size:.8125rem;font-weight:500}.lb-carry-val{color:#4338ca;font-size:.875rem;font-weight:700}.lb-progress-header{display:flex;justify-content:space-between;margin-bottom:8px}.lb-progress-lbl{color:#64748b;font-size:.8125rem;font-weight:600}.lb-progress-pct{font-size:.8125rem;font-weight:700}.lb-progress-bg{background:#f1f5f9;border-radius:99px;height:8px;margin-bottom:8px;overflow:hidden}.lb-progress-fill{border-radius:99px;height:100%;transition:width .5s ease}.lb-progress-footer{color:#94a3b8;display:flex;font-size:.75rem;justify-content:space-between}@media (max-width:768px){.lb-page{padding:16px}.lb-header{align-items:flex-start;flex-direction:column}.lb-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.lb-spinner{animation:none}.lb-card{transition:none}}.tlb-page{background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif;margin:0 auto;max-width:1440px;min-height:100vh;padding:28px 32px}.tlb-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.tlb-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 4px}.tlb-subtitle{color:#64748b;font-size:.875rem;margin:0}.tlb-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.tlb-year-nav{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;gap:8px;padding:6px 10px}.tlb-year-btn,.tlb-year-nav{align-items:center;display:flex}.tlb-year-btn{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;justify-content:center;min-height:32px;min-width:32px;padding:4px 6px;transition:background .15s,color .15s}.tlb-year-btn:hover{background:#f1f5f9;color:#0f172a}.tlb-year-label{color:#0f172a;font-size:.9375rem;font-weight:700;min-width:48px;text-align:center}.tlb-export-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:9px;color:#374151;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:8px;min-height:44px;padding:10px 18px;transition:background .15s}.tlb-export-btn:hover:not(:disabled){background:#f1f5f9}.tlb-export-btn:disabled{cursor:not-allowed;opacity:.45}.tlb-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.tlb-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:6px;padding:20px}.tlb-stat-val{font-size:2rem;font-weight:700;line-height:1}.tlb-stat-lbl{color:#64748b;font-size:.8125rem;font-weight:500}.tlb-alert-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;font-size:.875rem;gap:10px;margin-bottom:20px;padding:12px 16px}.tlb-retry-btn{background:none;border:1px solid #fca5a5;border-radius:7px;color:#b91c1c;cursor:pointer;font-family:inherit;font-size:.8125rem;margin-left:auto;padding:4px 12px}.tlb-filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.tlb-search-box{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;display:flex;flex:1 1;gap:8px;min-width:220px;padding:10px 14px}.tlb-search-icon{color:#94a3b8;flex-shrink:0}.tlb-search-box input{background:#0000;border:none;color:#0f172a;flex:1 1;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;outline:none}.tlb-clear-btn{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:0}.tlb-type-filter{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;color:#374151;cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;min-width:200px;outline:none;padding:10px 14px}.tlb-type-filter:focus{border-color:#6366f1}.tlb-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:40vh}.tlb-spinner{animation:tlb-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes tlb-spin{to{transform:rotate(1turn)}}.tlb-empty{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;color:#94a3b8;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.tlb-empty h3{color:#374151;font-size:1.125rem;font-weight:700;margin:0}.tlb-empty p{color:#64748b;font-size:.875rem;margin:0}.tlb-list{display:flex;flex-direction:column;gap:20px}.tlb-emp-section{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.tlb-emp-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:16px;padding:18px 22px}.tlb-emp-avatar{align-items:center;background:#ffffff40;border-radius:50%;display:flex;flex-shrink:0;font-size:1.125rem;font-weight:800;height:44px;justify-content:center;width:44px}.tlb-emp-info h3{font-size:1rem;font-weight:700;margin:0 0 2px}.tlb-emp-info span{font-size:.8125rem;opacity:.85}.tlb-table-wrap{overflow-x:auto}.tlb-table{border-collapse:collapse;min-width:700px;width:100%}.tlb-table thead{background:#f8fafc}.tlb-table th{border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.6875rem;font-weight:700;letter-spacing:.5px;padding:11px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.tlb-table td{border-bottom:1px solid #f1f5f9;color:#374151;font-size:.875rem;padding:13px 14px;vertical-align:middle}.tlb-table tbody tr:last-child td{border-bottom:none}.tlb-table tbody tr:hover{background:#fafbff}.tlb-type-cell{display:flex;flex-direction:column;gap:2px}.tlb-type-name{color:#0f172a;font-weight:600}.tlb-type-code{color:#94a3b8;font-size:.75rem}.tlb-accrued{background:#dbeafe;border-radius:6px;color:#1e40af;display:inline-block;font-size:.8125rem;font-weight:600;padding:2px 8px}.tlb-used{color:#ef4444;font-weight:600}.tlb-avail{color:#16a34a;font-size:.9375rem;font-weight:700}.tlb-muted{color:#94a3b8}.tlb-carry{background:#fef3c7;border-radius:6px;color:#92400e;display:inline-block;font-size:.8125rem;font-weight:600;padding:2px 8px}.tlb-usage-cell{align-items:center;display:flex;gap:8px}.tlb-mini-bar{background:#f1f5f9;border-radius:99px;flex:1 1;height:6px;min-width:60px;overflow:hidden}.tlb-mini-fill{border-radius:99px;height:100%;transition:width .4s ease}.tlb-pct-text{color:#64748b;font-size:.75rem;font-weight:600;min-width:34px;text-align:right}@media (max-width:1024px){.tlb-stats-row{grid-template-columns:1fr 1fr}}@media (max-width:768px){.tlb-page{padding:16px}.tlb-header{flex-direction:column}.tlb-header-actions{flex-wrap:wrap}.tlb-stats-row{gap:12px;grid-template-columns:1fr 1fr}.tlb-filter-bar{flex-direction:column}.tlb-search-box,.tlb-type-filter{width:100%}}@media (prefers-reduced-motion:reduce){.tlb-spinner{animation:none}}.pr-page{margin:0 auto;max-width:1400px;padding:2rem}.pr-loading-center{align-items:center;display:flex;justify-content:center;min-height:300px}.pr-spinner{animation:pr-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes pr-spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.pr-spinner{animation:none;border-top-color:#6366f1}}.pr-alert{align-items:center;border-radius:.75rem;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.625rem;margin-bottom:1.5rem;padding:.875rem 1.25rem}.pr-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.pr-alert--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.pr-alert-close{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;margin-left:auto;opacity:.6;padding:0}.pr-alert-close:hover{opacity:1}.pr-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.pr-header-left{flex:1 1;min-width:0}.pr-breadcrumb{align-items:center;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;gap:.25rem;margin-bottom:.5rem}.pr-breadcrumb-parent{color:#64748b;cursor:pointer}.pr-breadcrumb-parent:hover{color:#6366f1;text-decoration:underline}.pr-breadcrumb-sep{color:#94a3b8}.pr-breadcrumb-active{color:#6366f1;font-weight:500}.pr-title{color:#0f172a;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .25rem}.pr-subtitle,.pr-title{font-family:Plus Jakarta Sans,sans-serif}.pr-subtitle{color:#64748b;font-size:.875rem;margin:0}.pr-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.pr-btn{align-items:center;-webkit-appearance:none;appearance:none;border:none;border-radius:.75rem;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;font-weight:600;gap:.5rem;min-height:44px;padding:.75rem 1.25rem;transition:background .15s,transform .15s,box-shadow .15s;white-space:nowrap}.pr-btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.pr-btn-primary{background:#6366f1;box-shadow:0 10px 15px -3px #6366f140,0 4px 6px -4px #6366f126;color:#fff}.pr-btn-primary:hover:not(:disabled){background:#4f46e5;box-shadow:0 14px 20px -3px #6366f159;transform:translateY(-1px)}.pr-btn-secondary{background:#fff;border:1px solid #e2e8f0;box-shadow:0 1px 2px #0000000d;color:#374151}.pr-btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.pr-btn-warning{background:#f59e0b;box-shadow:0 4px 8px -2px #f59e0b4d;color:#fff}.pr-btn-warning:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.pr-btn-success{background:#10b981;box-shadow:0 4px 8px -2px #10b9814d;color:#fff}.pr-btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.pr-btn-danger{background:#ef4444;box-shadow:0 4px 8px -2px #ef44444d;color:#fff}.pr-btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.pr-btn-ghost{background:#0000;border:none;color:#64748b;padding:.5rem .75rem}.pr-btn-ghost:hover:not(:disabled){background:#f1f5f9;color:#374151}.pr-btn-sm{border-radius:.5rem;font-size:.8125rem;min-height:36px;padding:.4rem .875rem}.pr-filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.pr-filter-label{color:#64748b;font-size:.8125rem;font-weight:600;white-space:nowrap}.pr-filter-label,.pr-filter-select{font-family:Plus Jakarta Sans,sans-serif}.pr-filter-select{background:#fff;border:1px solid #e2e8f0;border-radius:.625rem;color:#374151;cursor:pointer;font-size:.875rem;min-height:40px;outline:none;padding:.5rem .875rem;transition:border-color .15s}.pr-filter-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.pr-badge{align-items:center;border-radius:9999px;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;gap:.375rem;padding:.25rem .75rem;text-transform:capitalize;white-space:nowrap}.pr-badge-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.pr-badge--draft{background:#f1f5f9;color:#475569}.pr-badge--draft .pr-badge-dot{background:#94a3b8}.pr-badge--processing{background:#fefce8;color:#92400e}.pr-badge--processing .pr-badge-dot{background:#f59e0b}.pr-badge--finalized{background:#f0fdf4;color:#166534}.pr-badge--finalized .pr-badge-dot{background:#22c55e}.pr-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;overflow:hidden}.pr-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,minmax(min(200px,100%),1fr));margin-bottom:1.5rem}.pr-summary-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;box-shadow:0 1px 3px #0000000a;display:flex;gap:1rem;padding:1.25rem 1.5rem}.pr-summary-icon{align-items:center;border-radius:.75rem;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.pr-summary-icon--indigo{background:#eef2ff;color:#6366f1}.pr-summary-icon--green{background:#f0fdf4;color:#16a34a}.pr-summary-icon--red{background:#fff1f2;color:#e11d48}.pr-summary-icon--blue{background:#eff6ff;color:#2563eb}.pr-summary-icon--yellow{background:#fefce8;color:#ca8a04}.pr-summary-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.08em;margin-bottom:.25rem;text-transform:uppercase}.pr-summary-label,.pr-summary-value{font-family:Plus Jakarta Sans,sans-serif}.pr-summary-value{color:#0f172a;font-size:1.5rem;font-weight:800;line-height:1.1}.pr-summary-sub{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;margin-top:.125rem}.pr-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.pr-table{border-collapse:collapse;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;width:100%}.pr-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.08em;padding:.875rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.pr-table td{border-bottom:1px solid #f1f5f9;color:#374151;padding:1rem;vertical-align:middle}.pr-table tr:last-child td{border-bottom:none}.pr-table tr:hover td{background:#fafbff}.pr-table-row-clickable{cursor:pointer}.pr-emp-cell{display:flex;flex-direction:column;gap:.125rem}.pr-emp-name{color:#0f172a;font-weight:600}.pr-emp-code,.pr-emp-meta{color:#94a3b8;font-size:.75rem}.pr-emp-code{font-family:monospace}.pr-amount{font-feature-settings:"tnum";color:#0f172a;font-variant-numeric:tabular-nums;font-weight:600}.pr-amount--deduction{color:#dc2626}.pr-amount--net{color:#059669}.pr-hours{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.pr-actions-cell{align-items:center;display:flex;gap:.375rem}.pr-empty{color:#94a3b8;flex-direction:column;padding:4rem 2rem;text-align:center}.pr-empty,.pr-empty-icon{align-items:center;display:flex;justify-content:center}.pr-empty-icon{background:#f1f5f9;border-radius:50%;color:#cbd5e1;height:56px;margin-bottom:1rem;width:56px}.pr-empty-title{color:#475569;font-size:1rem;font-weight:700;margin-bottom:.375rem}.pr-empty-text,.pr-empty-title{font-family:Plus Jakarta Sans,sans-serif}.pr-empty-text{color:#94a3b8;font-size:.875rem;max-width:320px}.pr-cycle-info{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.875rem;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.pr-cycle-info-item{display:flex;flex-direction:column;gap:.125rem}.pr-cycle-info-label{color:#94a3b8;font-family:Plus Jakarta Sans,sans-serif;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.pr-cycle-info-value{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:.9375rem;font-weight:700}.pr-cycle-info-actions{align-items:center;display:flex;gap:.5rem;margin-left:auto}.pr-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:400;z-index:var(--z-overlay,400)}.pr-modal{animation:pr-modal-in .2s ease-out;background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-width:480px;width:calc(100% - 32px);z-index:500;z-index:var(--z-modal,500)}@keyframes pr-modal-in{0%{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media (prefers-reduced-motion:reduce){.pr-modal{animation:none}}.pr-modal-header{align-items:center;display:flex;justify-content:space-between;padding:1.5rem 1.5rem 0}.pr-modal-title{color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;font-size:1.125rem;font-weight:800;margin:0}.pr-modal-close{align-items:center;background:none;border:none;border-radius:.375rem;color:#94a3b8;cursor:pointer;display:flex;padding:.25rem;transition:color .15s,background .15s}.pr-modal-close:hover{background:#f1f5f9;color:#374151}.pr-modal-body{padding:1.5rem}.pr-modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:0 1.5rem 1.5rem}.pr-form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:0}.pr-form-group{display:flex;flex-direction:column;gap:.375rem}.pr-form-label{font-size:.8125rem;font-weight:600}.pr-form-label,.pr-form-select{color:#374151;font-family:Plus Jakarta Sans,sans-serif}.pr-form-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;border:1px solid #e2e8f0;border-radius:.625rem;font-size:.875rem;min-height:44px;outline:none;padding:.625rem 2.25rem .625rem .875rem;transition:border-color .15s,box-shadow .15s}.pr-form-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.pr-confirm-icon{align-items:center;border-radius:50%;display:flex;height:48px;justify-content:center;margin:0 auto 1rem;width:48px}.pr-confirm-icon--warning{background:#fef3c7;color:#d97706}.pr-confirm-icon--success{background:#d1fae5;color:#059669}.pr-confirm-icon--danger{background:#fee2e2;color:#dc2626}.pr-confirm-text{color:#64748b;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;line-height:1.6;text-align:center}.pr-toolbar{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.pr-toolbar-title{color:#0f172a;font-size:.9375rem;font-weight:700}.pr-toolbar-meta,.pr-toolbar-title{font-family:Plus Jakarta Sans,sans-serif}.pr-toolbar-meta{color:#94a3b8;font-size:.8125rem;margin-top:.125rem}@media (max-width:768px){.pr-page{padding:1rem}.pr-summary-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.pr-summary-card{padding:1rem}.pr-summary-value{font-size:1.125rem}.pr-header{align-items:flex-start;flex-direction:column}.pr-header-actions{width:100%}.pr-cycle-info{gap:1rem}.pr-cycle-info-actions{margin-left:0;width:100%}.pr-form-row{grid-template-columns:1fr}.pr-title{font-size:1.375rem}}@media (max-width:480px){.pr-summary-grid{grid-template-columns:1fr}}.aw-page{font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font-family,"Plus Jakarta Sans",sans-serif);margin:0 auto;max-width:1400px;padding:28px 32px}.aw-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.aw-breadcrumb{align-items:center;color:#6b7280;color:var(--gray-500,#6b7280);display:flex;font-size:.72rem;font-weight:500;gap:6px;letter-spacing:.03em;margin-bottom:6px;text-transform:uppercase}.aw-breadcrumb svg{color:#6366f1;color:var(--primary,#6366f1)}.aw-breadcrumb-sep{color:#d1d5db;color:var(--gray-300,#d1d5db)}.aw-breadcrumb-active{color:#374151;color:var(--gray-700,#374151);font-weight:600;letter-spacing:0;text-transform:none}.aw-title{color:#111827;color:var(--gray-900,#111827);font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin:0 0 4px}.aw-subtitle{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.85rem;margin:0}.aw-btn-primary{align-items:center;background:#6366f1;background:var(--primary,#6366f1);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:7px;min-height:44px;padding:10px 18px;transition:background .15s,transform .1s;white-space:nowrap}.aw-btn-primary:hover{background:#4f46e5}.aw-btn-primary:active{transform:scale(.98)}.aw-alert{align-items:center;background:#fff1f2;border:1px solid #fecdd3;border-radius:10px;color:#be123c;display:flex;font-size:.85rem;gap:10px;margin-bottom:20px;padding:12px 16px}.aw-alert span{flex:1 1}.aw-alert button{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;padding:2px}.aw-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.aw-stat{background:#fff;border:1px solid #f3f4f6;border:1px solid var(--gray-100,#f3f4f6);border-radius:14px;box-shadow:0 1px 4px #0000000d;padding:20px 22px;transition:box-shadow .15s}.aw-stat:hover{box-shadow:0 4px 16px #00000014}.aw-stat-value{color:#111827;color:var(--gray-900,#111827);font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1;margin-bottom:6px}.aw-stat-value.aw-stat-blue{color:#6366f1}.aw-stat-value.aw-stat-purple{color:#7c3aed}.aw-stat-value.aw-stat-red{color:#dc2626}.aw-stat-label{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.78rem;font-weight:500;letter-spacing:.01em}.aw-filters{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.aw-search-wrap{flex:1 1;max-width:340px;min-width:200px;position:relative}.aw-search-icon{color:#9ca3af;color:var(--gray-400,#9ca3af);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.aw-search{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200,#e5e7eb);border-radius:10px;box-sizing:border-box;color:#111827;color:var(--gray-900,#111827);font-family:inherit;font-size:.85rem;min-height:40px;outline:none;padding:9px 36px;transition:border-color .15s,box-shadow .15s;width:100%}.aw-search:focus{border-color:#6366f1;border-color:var(--primary,#6366f1);box-shadow:0 0 0 3px #6366f11a}.aw-search-clear,.aw-search::placeholder{color:#9ca3af;color:var(--gray-400,#9ca3af)}.aw-search-clear{align-items:center;background:none;border:none;cursor:pointer;display:flex;padding:2px;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.aw-search-clear:hover{color:#374151;color:var(--gray-700,#374151)}.aw-filter-group{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:10px}.aw-chips{background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--gray-200,#e5e7eb);border-radius:10px;display:flex;gap:6px;padding:4px}.aw-chip{background:#0000;border:none;border-radius:7px;color:#4b5563;color:var(--gray-600,#4b5563);cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:500;padding:6px 14px;transition:background .12s,color .12s;white-space:nowrap}.aw-chip:hover{background:#f3f4f6;background:var(--gray-100,#f3f4f6)}.aw-chip.aw-chip-active{background:#fff;box-shadow:0 1px 4px #0000001a;color:#6366f1;color:var(--primary,#6366f1);font-weight:600}.aw-select-wrap{align-items:center;display:flex;position:relative}.aw-select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200,#e5e7eb);border-radius:10px;color:#374151;color:var(--gray-700,#374151);cursor:pointer;font-family:inherit;font-size:.82rem;min-height:38px;outline:none;padding:8px 34px 8px 12px;transition:border-color .15s}.aw-select:focus{border-color:#6366f1;border-color:var(--primary,#6366f1)}.aw-select-icon{color:#9ca3af;color:var(--gray-400,#9ca3af);pointer-events:none;position:absolute;right:10px}.aw-table-wrap{background:#fff;border:1px solid #f3f4f6;border:1px solid var(--gray-100,#f3f4f6);border-radius:16px;box-shadow:0 1px 6px #0000000f;overflow:hidden;overflow-x:auto}.aw-table{border-collapse:collapse;font-size:.85rem;width:100%}.aw-thead th{background:#f9fafb;background:var(--gray-50,#f9fafb);border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100,#f3f4f6);color:#6b7280;color:var(--gray-500,#6b7280);font-size:.72rem;font-weight:600;letter-spacing:.06em;padding:13px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.aw-tr{border-bottom:1px solid #f9fafb;border-bottom:1px solid var(--gray-50,#f9fafb);cursor:pointer;transition:background .1s}.aw-tr:last-child{border-bottom:none}.aw-tr:hover{background:#fafafe}.aw-td{color:#1f2937;color:var(--gray-800,#1f2937);padding:14px 16px;vertical-align:middle}.aw-td-name{min-width:220px}.aw-name-cell{gap:10px}.aw-name-cell,.aw-name-icon{align-items:center;display:flex}.aw-name-icon{border-radius:8px;flex-shrink:0;font-size:.8125rem;font-weight:700;height:36px;justify-content:center;width:36px}.aw-name-icon-blue{background:#ede9fe;color:#6366f1}.aw-name-icon-purple{background:#fef3c7;color:#d97706}.aw-name{color:#111827;color:var(--gray-900,#111827);font-size:.875rem;font-weight:600;line-height:1.3}.aw-name-sub{color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:.75rem;margin-top:2px}.aw-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.73rem;font-weight:600;gap:5px;padding:4px 10px;white-space:nowrap}.aw-badge-project{background:#eef2ff;color:#6366f1}.aw-badge-recurring{background:#f3e8ff;color:#7c3aed}.aw-badge-ongoing{background:#ecfdf5;color:#059669}.aw-status{align-items:center;border-radius:20px;display:inline-flex;font-size:.73rem;font-weight:600;padding:4px 10px;text-transform:capitalize}.aw-status-active{background:#dcfce7;color:#15803d}.aw-status-completed{background:#e0e7ff;color:#4338ca}.aw-status-hold{background:#fff7ed;color:#c2410c}.aw-status-archived{background:#f3f4f6;background:var(--gray-100,#f3f4f6);color:#6b7280;color:var(--gray-500,#6b7280)}.aw-td-owner{min-width:140px}.aw-owner{color:#374151;color:var(--gray-700,#374151);font-size:.83rem;gap:8px}.aw-avatar,.aw-owner{align-items:center;display:flex}.aw-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:.72rem;font-weight:700;height:28px;justify-content:center;width:28px}.aw-td-date{min-width:130px}.aw-date-cell{align-items:center;color:#4b5563;color:var(--gray-600,#4b5563);display:inline-flex;font-size:.82rem;gap:5px}.aw-date-cell svg{color:#9ca3af;color:var(--gray-400,#9ca3af)}.aw-date-overdue,.aw-date-overdue svg{color:#dc2626}.aw-td-billing{min-width:120px}.aw-billing-cell{align-items:center;color:#1f2937;color:var(--gray-800,#1f2937);display:inline-flex;font-size:.83rem;font-weight:600;gap:3px}.aw-billing-cell svg,.aw-billing-cycle{color:#9ca3af;color:var(--gray-400,#9ca3af)}.aw-billing-cycle{font-size:.72rem;font-weight:500;margin-left:1px}.aw-td-action{width:44px}.aw-action-btn{align-items:center;background:#fff;border:1px solid #f3f4f6;border:1px solid var(--gray-100,#f3f4f6);border-radius:8px;color:#6b7280;color:var(--gray-500,#6b7280);cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .1s,color .1s,border-color .1s;width:32px}.aw-action-btn:hover{background:#eef2ff;border-color:#c7d2fe;color:#6366f1;color:var(--primary,#6366f1)}.aw-muted{color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:.82rem}.aw-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;display:inline-block;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:.2rem .5rem}.aw-td-client{color:#374151;font-size:.83rem;min-width:120px}.aw-loading{align-items:center;color:#6b7280;color:var(--gray-500,#6b7280);display:flex;flex-direction:column;font-size:.9rem;gap:12px;padding:64px 24px}@keyframes aw-spin{to{transform:rotate(1turn)}}.aw-spin{animation:aw-spin .9s linear infinite}.aw-empty{flex-direction:column;gap:10px;padding:72px 24px;text-align:center}.aw-empty,.aw-empty-icon{align-items:center;display:flex}.aw-empty-icon{background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #f3f4f6;border:1px solid var(--gray-100,#f3f4f6);border-radius:18px;color:#d1d5db;color:var(--gray-300,#d1d5db);height:72px;justify-content:center;margin-bottom:4px;width:72px}.aw-empty-title{color:#1f2937;color:var(--gray-800,#1f2937);font-size:1rem;font-weight:600;margin:0}.aw-empty-sub{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.85rem;margin:0 0 8px}.aw-footer{color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:.78rem;padding:12px 4px;text-align:right}.aw-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:400;z-index:var(--z-overlay,400)}.aw-modal{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000002e;max-width:480px;padding:28px;width:100%;z-index:500;z-index:var(--z-modal,500)}.aw-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.aw-modal-title{color:#111827;color:var(--gray-900,#111827);font-size:1.2rem;font-weight:700;margin:0}.aw-modal-close{align-items:center;background:#fff;border:1px solid #f3f4f6;border:1px solid var(--gray-100,#f3f4f6);border-radius:8px;color:#6b7280;color:var(--gray-500,#6b7280);cursor:pointer;display:flex;height:34px;justify-content:center;transition:background .1s;width:34px}.aw-modal-close:hover{background:#f9fafb;background:var(--gray-50,#f9fafb)}.aw-modal-sub{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.85rem;margin:0 0 24px}.aw-modal-options{display:flex;flex-direction:column;gap:12px}.aw-modal-option{align-items:flex-start;background:#fff;border:2px solid #f3f4f6;border:2px solid var(--gray-100,#f3f4f6);border-radius:14px;cursor:pointer;display:flex;font-family:inherit;gap:16px;padding:18px 20px;text-align:left;transition:border-color .15s,background .15s,box-shadow .15s;width:100%}.aw-modal-option:hover{background:#fafafe;border-color:#6366f1;border-color:var(--primary,#6366f1);box-shadow:0 4px 12px #6366f11a}.aw-modal-option-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.aw-modal-option-blue{background:#eef2ff;color:#6366f1}.aw-modal-option-purple{background:#f3e8ff;color:#7c3aed}.aw-modal-option-text{flex:1 1}.aw-modal-option-title{color:#111827;color:var(--gray-900,#111827);font-size:.95rem;font-weight:600;margin-bottom:4px}.aw-modal-option-desc{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.8rem;line-height:1.5}@media (max-width:1024px){.aw-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.aw-page{padding:16px}.aw-stats{gap:12px;grid-template-columns:repeat(2,1fr)}.aw-filters{align-items:stretch;flex-direction:column}.aw-search-wrap{max-width:none}.aw-filter-group{gap:8px}.aw-td-billing,.aw-td-date,.aw-td-owner{display:none}}@media (prefers-reduced-motion:reduce){.aw-spin{animation:none}}.rp-page{font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font-family,"Plus Jakarta Sans",sans-serif);margin:0 auto;padding:28px 32px}.rp-loading{align-items:center;color:#6b7280;color:var(--gray-500,#6b7280);display:flex;flex-direction:column;font-size:.9rem;gap:12px;padding:80px 24px}@keyframes rp-spin{to{transform:rotate(1turn)}}.rp-spin{animation:rp-spin .9s linear infinite}.rp-error{align-items:center;background:#fff1f2;border:1px solid #fecdd3;border-radius:10px;color:#be123c;display:flex;font-size:.85rem;gap:10px;padding:14px 18px}.rp-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.rp-breadcrumb{align-items:center;color:#6b7280;color:var(--gray-500,#6b7280);display:flex;font-size:.72rem;font-weight:500;gap:6px;letter-spacing:.03em;margin-bottom:6px;text-transform:uppercase}.rp-breadcrumb svg{color:#6366f1;color:var(--primary,#6366f1)}.rp-sep{color:#d1d5db;color:var(--gray-300,#d1d5db)}.rp-breadcrumb-active{color:#374151;color:var(--gray-700,#374151);font-weight:600;letter-spacing:0;text-transform:none}.rp-title{color:#111827;color:var(--gray-900,#111827);font-size:1.6rem;letter-spacing:-.02em}.rp-subtitle{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.85rem}.rp-current-role{align-items:flex-end;display:flex;flex-direction:column;gap:6px}.rp-current-label{color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:.72rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.rp-current-badge{align-items:center;border-radius:20px;color:#fff;display:inline-flex;font-size:.8rem;font-weight:600;padding:6px 14px}.rp-role-cards{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.rp-role-card{align-items:flex-start;background:#fff;border:2px solid #f3f4f6;border:2px solid var(--gray-100,#f3f4f6);border-radius:14px;cursor:pointer;display:flex;font-family:inherit;gap:12px;padding:16px;text-align:left;transition:border-color .15s,box-shadow .15s,transform .1s;width:100%}.rp-role-card:hover{border-color:#e5e7eb;border-color:var(--gray-200,#e5e7eb);box-shadow:0 4px 16px #00000012}.rp-role-card:active{transform:scale(.99)}.rp-role-card-current{background:#f9fafb;background:var(--gray-50,#f9fafb);border-color:#e5e7eb;border-color:var(--gray-200,#e5e7eb)}.rp-role-card-active{transform:scale(1.01)}.rp-role-card-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.rp-role-card-body{flex:1 1;min-width:0}.rp-role-card-name{align-items:center;display:flex;font-size:.9rem;font-weight:700;gap:6px;margin-bottom:4px}.rp-you-badge{background:#6366f1;background:var(--primary,#6366f1);border-radius:10px;color:#fff;font-size:.65rem;font-weight:600;letter-spacing:.03em;padding:2px 7px;text-transform:uppercase}.rp-role-card-desc{color:#6b7280;color:var(--gray-500,#6b7280);font-size:.75rem;line-height:1.5}.rp-legend{flex-wrap:wrap;gap:18px;margin-bottom:14px}.rp-legend,.rp-legend-item{align-items:center;display:flex}.rp-legend-item{color:#4b5563;color:var(--gray-600,#4b5563);font-size:.78rem;gap:7px}.rp-legend-icon{pointer-events:none}.rp-legend-filter{align-items:center;color:#4b5563;color:var(--gray-600,#4b5563);display:flex;font-size:.78rem;gap:8px;margin-left:auto}.rp-legend-clear{background:none;border:none;color:#6366f1;color:var(--primary,#6366f1);cursor:pointer;font-family:inherit;font-size:.75rem;padding:0;text-decoration:underline}.rp-access-icon{align-items:center;border-radius:7px;display:inline-flex;font-size:.65rem;font-weight:700;gap:3px;height:28px;justify-content:center;width:28px}.rp-access-full{background:#dcfce7;color:#15803d}.rp-access-own{background:#dbeafe;border-radius:7px;color:#1d4ed8;padding:0 8px;width:auto}.rp-own-label{font-size:.6rem;font-weight:700;letter-spacing:.03em}.rp-access-none{background:#f3f4f6;background:var(--gray-100,#f3f4f6);color:#9ca3af;color:var(--gray-400,#9ca3af)}.rp-table-wrap{background:#fff;border:1px solid #f3f4f6;border:1px solid var(--gray-100,#f3f4f6);border-radius:16px;box-shadow:0 1px 6px #0000000d;margin-bottom:16px;overflow:hidden;overflow-x:auto}.rp-table{border-collapse:collapse;font-size:.85rem;width:100%}.rp-th{background:#f9fafb;background:var(--gray-50,#f9fafb);border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--gray-100,#f3f4f6);font-weight:600;padding:14px 20px;white-space:nowrap}.rp-th-label{color:#4b5563;color:var(--gray-600,#4b5563);font-size:.78rem;letter-spacing:.06em;min-width:220px;text-align:left;text-transform:uppercase}.rp-th-role{min-width:120px;text-align:center}.rp-th-current{background:#f5f5ff}.rp-th-inner{flex-direction:column;gap:6px}.rp-th-icon,.rp-th-inner{align-items:center;display:flex}.rp-th-icon{border-radius:9px;height:34px;justify-content:center;width:34px}.rp-group-row td{background:#f9fafb;background:var(--gray-50,#f9fafb);border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100,#f3f4f6);border-top:1px solid #f3f4f6;border-top:1px solid var(--gray-100,#f3f4f6);color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:10px 20px 6px;text-transform:uppercase}.rp-perm-row{border-bottom:1px solid #f9fafb;border-bottom:1px solid var(--gray-50,#f9fafb)}.rp-perm-row:last-child{border-bottom:none}.rp-perm-row-even{background:#fdfdff}.rp-perm-label{color:#374151;color:var(--gray-700,#374151);font-size:.85rem;padding:13px 20px}.rp-cell{padding:10px 16px;text-align:center;vertical-align:middle}.rp-cell-highlight{background:#f5f5ff}.rp-note{align-items:center;color:#9ca3af;color:var(--gray-400,#9ca3af);display:flex;font-size:.78rem;gap:7px;margin:0}.rp-note svg{flex-shrink:0}@media (max-width:1024px){.rp-role-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.rp-page{padding:16px}.rp-role-cards{gap:10px;grid-template-columns:1fr 1fr}.rp-current-role,.rp-role-card-desc{display:none}}@media (prefers-reduced-motion:reduce){.rp-spin{animation:none}}.ps-page{max-width:1100px;padding:24px}.ps-header{margin-bottom:28px}.ps-title{color:var(--gray-900);font-size:var(--text-2xl);font-weight:700;margin:0 0 4px}.ps-subtitle{color:var(--gray-500);font-size:var(--text-sm);margin:0}.ps-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:280px 1fr}@media (max-width:900px){.ps-layout{grid-template-columns:1fr}}.ps-card{background:#fff;border:1px solid var(--gray-200);border-radius:12px;overflow:hidden}.ps-identity-card{align-items:center;display:flex;flex-direction:column;gap:16px;padding:28px 20px}.ps-avatar-wrapper{flex-shrink:0;position:relative}.ps-avatar{align-items:center;background:var(--primary-gradient);border-radius:50%;display:flex;height:88px;justify-content:center;overflow:hidden;width:88px}.ps-avatar-img{height:100%;object-fit:cover;width:100%}.ps-avatar-initials{color:#fff;font-size:2rem;font-weight:700;letter-spacing:1px}.ps-avatar-edit{align-items:center;background:var(--primary);border:2px solid #fff;border-radius:50%;bottom:2px;color:#fff;cursor:pointer;display:flex;height:26px;justify-content:center;position:absolute;right:2px;transition:background .2s;width:26px}.ps-avatar-edit:hover{background:#4f46e5;background:var(--primary-dark,#4f46e5)}.ps-identity-info{text-align:center}.ps-identity-name{color:var(--gray-900);font-size:var(--text-lg);font-weight:700;margin:0 0 6px}.ps-role-badge{background:#6366f11a;border-radius:20px;color:var(--primary);display:inline-block;font-size:var(--text-xs);font-weight:600;letter-spacing:.5px;padding:3px 12px;text-transform:uppercase}.ps-identity-designation{color:var(--gray-600);font-size:var(--text-sm);margin:6px 0 0}.ps-identity-code{color:var(--gray-400);font-family:monospace;font-size:var(--text-xs);margin:4px 0 0}.ps-identity-meta{border-top:1px solid var(--gray-100);display:flex;flex-direction:column;gap:8px;padding-top:16px;width:100%}.ps-meta-row{align-items:center;display:flex;font-size:var(--text-sm);justify-content:space-between}.ps-meta-label{color:var(--gray-500);font-weight:500}.ps-meta-value{color:var(--gray-800);font-weight:500;max-width:60%;overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap}.ps-main-card{min-height:500px}.ps-tabs{border-bottom:1px solid var(--gray-200);display:flex;padding:0 20px}.ps-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--gray-500);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:500;gap:8px;margin-bottom:-1px;padding:14px 16px;transition:color .2s,border-color .2s}.ps-tab-active,.ps-tab:hover{color:var(--primary)}.ps-tab-active{border-bottom-color:var(--primary)}.ps-tab-content{gap:28px;padding:24px}.ps-section,.ps-tab-content{display:flex;flex-direction:column}.ps-section{gap:16px}.ps-section-header{align-items:center;color:var(--gray-700);display:flex;font-size:var(--text-sm);font-weight:600;gap:8px;letter-spacing:.5px;text-transform:uppercase}.ps-section-header h3{font-size:var(--text-sm);margin:0}.ps-section-desc{color:var(--gray-500);font-size:var(--text-sm);margin:-8px 0 0}.ps-grid-2{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.ps-grid-1{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr;max-width:480px}@media (max-width:600px){.ps-grid-2{grid-template-columns:1fr}}.ps-field{display:flex;flex-direction:column;gap:6px}.ps-field-full{grid-column:1/-1}.ps-field label{align-items:center;color:var(--gray-700);display:flex;font-size:var(--text-sm);font-weight:500;gap:5px}.ps-field input,.ps-field select{background:#fff;border:1px solid var(--gray-300);border-radius:8px;box-sizing:border-box;color:var(--gray-800);font-family:inherit;font-size:var(--text-sm);height:40px;padding:0 12px;transition:border-color .15s,box-shadow .15s;width:100%}.ps-field input:focus,.ps-field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.ps-input-error{border-color:#ef4444!important;border-color:var(--danger,#ef4444)!important}.ps-error{color:#ef4444;color:var(--danger,#ef4444);font-size:var(--text-xs)}.ps-input-wrap{position:relative}.ps-input-wrap input{padding-right:40px}.ps-eye{background:none;border:none;cursor:pointer;font-size:14px;line-height:1;padding:2px;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.ps-actions{border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;padding-top:8px}.rp-page{max-width:1200px;padding:24px}.rp-header{margin-bottom:24px}.rp-title{color:var(--gray-900);font-size:var(--text-2xl);font-weight:700;margin:0 0 4px}.rp-subtitle{color:var(--gray-500);font-size:var(--text-sm);margin:0}.rp-tabs{border-bottom:1px solid var(--gray-200);display:flex;gap:4px;margin-bottom:24px}.rp-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--gray-500);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:500;gap:6px;margin-bottom:-1px;padding:10px 16px;transition:color .2s,border-color .2s}.rp-tab-active,.rp-tab:hover{color:var(--primary)}.rp-tab-active{border-bottom-color:var(--primary)}.rp-content{display:flex;flex-direction:column;gap:20px}.rp-controls{align-items:center;display:flex;font-size:var(--text-sm);gap:10px}.rp-controls select{border:1px solid var(--gray-300);border-radius:6px;font-size:var(--text-sm);padding:4px 8px}.rp-stat-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.rp-stat{background:#fff;border:1px solid var(--gray-200);border-radius:10px;display:flex;flex-direction:column;gap:4px;padding:16px 20px}.rp-stat-label{color:var(--gray-500);font-size:var(--text-xs);font-weight:500;letter-spacing:.5px;text-transform:uppercase}.rp-stat-value{color:var(--gray-900);font-size:var(--text-xl);font-weight:700}.rp-green{color:#10b981!important}.rp-red{color:#ef4444!important}.rp-blue{color:#3b82f6!important}.rp-yellow{color:#f59e0b!important}.rp-card{background:#fff;border:1px solid var(--gray-200);border-radius:10px;padding:20px}.rp-card-title{color:var(--gray-800);font-size:var(--text-base);font-weight:600;margin:0 0 16px}.rp-grid-2{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:768px){.rp-grid-2{grid-template-columns:1fr}}.rp-progress-row{align-items:center;display:flex;gap:8px}.rp-progress-bar{background:var(--gray-100);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.rp-progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s}.rp-progress-label{color:var(--gray-700);font-size:var(--text-xs);font-weight:600;min-width:32px}.App{min-height:100vh}
/*# sourceMappingURL=main.c117317f.css.map*/