.modal-overlay[data-v-d67b1683]{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:1rem}.modal-container[data-v-d67b1683]{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-small[data-v-d67b1683]{width:400px}.modal-medium[data-v-d67b1683]{width:600px}.modal-large[data-v-d67b1683]{width:900px}.modal-header[data-v-d67b1683]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-title-wrapper[data-v-d67b1683]{display:flex;align-items:center;gap:.75rem}.modal-icon[data-v-d67b1683]{font-size:1.5rem;line-height:1}.modal-title[data-v-d67b1683]{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.modal-close[data-v-d67b1683]{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem}.modal-close[data-v-d67b1683]:hover{color:#111827;background-color:#f3f4f6}.modal-body[data-v-d67b1683]{padding:1.5rem;overflow-y:auto;flex:1}.modal-body p[data-v-d67b1683]{margin:0;color:#4b5563;line-height:1.6}.modal-footer[data-v-d67b1683]{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb;background-color:#f9fafb}.modal-danger .modal-icon[data-v-d67b1683],.modal-danger .modal-title[data-v-d67b1683]{color:#dc2626}.modal-warning .modal-icon[data-v-d67b1683],.modal-warning .modal-title[data-v-d67b1683]{color:#f59e0b}.modal-success .modal-icon[data-v-d67b1683],.modal-success .modal-title[data-v-d67b1683]{color:#10b981}.modal-info .modal-icon[data-v-d67b1683],.modal-info .modal-title[data-v-d67b1683]{color:#3b82f6}.btn-primary[data-v-d67b1683],.btn-secondary[data-v-d67b1683],.btn-danger[data-v-d67b1683],.btn-warning[data-v-d67b1683],.btn-success[data-v-d67b1683]{padding:.625rem 1.25rem;border-radius:.5rem;font-weight:500;border:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary[data-v-d67b1683]{background-color:#3b82f6;color:var(--color-white)}.btn-primary[data-v-d67b1683]:hover:not(:disabled){background-color:#2563eb}.btn-secondary[data-v-d67b1683]{background-color:var(--card-bg);color:#374151;border:1px solid #d1d5db}.btn-secondary[data-v-d67b1683]:hover:not(:disabled){background-color:#f9fafb}.btn-danger[data-v-d67b1683]{background-color:#dc2626;color:var(--color-white)}.btn-danger[data-v-d67b1683]:hover:not(:disabled){background-color:#b91c1c}.btn-warning[data-v-d67b1683]{background-color:#f59e0b;color:var(--color-white)}.btn-warning[data-v-d67b1683]:hover:not(:disabled){background-color:#d97706}.btn-success[data-v-d67b1683]{background-color:#10b981;color:var(--color-white)}.btn-success[data-v-d67b1683]:hover:not(:disabled){background-color:#059669}.btn-primary[data-v-d67b1683]:disabled,.btn-secondary[data-v-d67b1683]:disabled,.btn-danger[data-v-d67b1683]:disabled,.btn-warning[data-v-d67b1683]:disabled,.btn-success[data-v-d67b1683]:disabled{opacity:.6;cursor:not-allowed}.spinner[data-v-d67b1683]{width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white);border-radius:50%;animation:spin-d67b1683 .6s linear infinite}@keyframes spin-d67b1683{to{transform:rotate(360deg)}}.modal-enter-active[data-v-d67b1683],.modal-leave-active[data-v-d67b1683]{transition:opacity .3s ease}.modal-enter-active .modal-container[data-v-d67b1683],.modal-leave-active .modal-container[data-v-d67b1683]{transition:transform .3s ease}.modal-enter-from[data-v-d67b1683],.modal-leave-to[data-v-d67b1683]{opacity:0}.modal-enter-from .modal-container[data-v-d67b1683],.modal-leave-to .modal-container[data-v-d67b1683]{transform:scale(.9)}@media(max-width:640px){.modal-small[data-v-d67b1683],.modal-medium[data-v-d67b1683],.modal-large[data-v-d67b1683]{width:100%;max-width:100%}.modal-container[data-v-d67b1683]{border-radius:12px 12px 0 0;align-self:flex-end;max-height:85vh}}.modal-overlay[data-v-ecb51589]{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn-ecb51589 .2s ease}@keyframes fadeIn-ecb51589{0%{opacity:0}to{opacity:1}}.modal-content[data-v-ecb51589]{background:var(--card-bg);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;animation:slideUp-ecb51589 .3s ease}@keyframes slideUp-ecb51589{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header[data-v-ecb51589]{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.modal-header h2[data-v-ecb51589]{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.btn-close[data-v-ecb51589]{background:none;border:none;font-size:32px;cursor:pointer;color:var(--color-text-secondary);line-height:1;padding:0;width:32px;height:32px;transition:color .2s}.btn-close[data-v-ecb51589]:hover{color:var(--color-text-primary)}.modal-body[data-v-ecb51589]{padding:24px}.intro-text[data-v-ecb51589]{margin:0 0 24px;font-size:14px;color:var(--color-text-secondary);line-height:1.6}.form-group[data-v-ecb51589]{margin-bottom:20px}.form-group label[data-v-ecb51589]{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.form-group select[data-v-ecb51589],.form-group input[data-v-ecb51589],.form-group textarea[data-v-ecb51589]{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-family:inherit;background:var(--bg-primary);color:var(--color-text-primary);transition:border-color .2s}.form-group select[data-v-ecb51589]:focus,.form-group input[data-v-ecb51589]:focus,.form-group textarea[data-v-ecb51589]:focus{outline:none;border-color:var(--color-primary)}.form-group textarea[data-v-ecb51589]{resize:vertical;min-height:120px}.char-count[data-v-ecb51589]{text-align:right;font-size:12px;color:var(--color-text-secondary);margin-top:4px}.tips-box[data-v-ecb51589]{padding:16px;background:var(--bg-secondary);border-left:4px solid var(--color-primary);border-radius:6px;margin-bottom:20px}.tips-title[data-v-ecb51589]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.tips-box ul[data-v-ecb51589]{margin:0;padding-left:20px;font-size:13px;color:var(--color-text-secondary)}.tips-box li[data-v-ecb51589]{margin-bottom:4px;line-height:1.5}.error-message[data-v-ecb51589]{padding:12px;background:#fee2e2;color:#991b1b;border-radius:6px;margin-bottom:16px;font-size:14px}.modal-footer[data-v-ecb51589]{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border-color)}.btn-primary[data-v-ecb51589],.btn-secondary[data-v-ecb51589]{padding:12px 24px;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.btn-primary[data-v-ecb51589]{background:var(--color-primary);color:var(--color-white)}.btn-primary[data-v-ecb51589]:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.btn-primary[data-v-ecb51589]:disabled{opacity:.6;cursor:not-allowed}.btn-secondary[data-v-ecb51589]{background:var(--bg-secondary);color:var(--color-text-primary);border:1px solid var(--border-color)}.btn-secondary[data-v-ecb51589]:hover:not(:disabled){background:var(--border-color)}.btn-secondary[data-v-ecb51589]:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.modal-content[data-v-ecb51589]{max-height:95vh}.modal-header[data-v-ecb51589],.modal-body[data-v-ecb51589]{padding:16px}.modal-header h2[data-v-ecb51589]{font-size:20px}.modal-footer[data-v-ecb51589]{flex-direction:column-reverse}.btn-primary[data-v-ecb51589],.btn-secondary[data-v-ecb51589]{width:100%}}.impersonation-banner[data-v-1d37fceb]{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:8px 20px;display:flex;justify-content:center;align-items:center;gap:20px;font-size:14px;position:sticky;top:0;z-index:1001}.impersonation-text[data-v-1d37fceb]{display:flex;align-items:center;gap:8px}.impersonation-text strong[data-v-1d37fceb]{font-weight:600}.impersonation-text .org-name[data-v-1d37fceb]{opacity:.9}.return-btn[data-v-1d37fceb]{background:#fff3;border:1px solid rgba(255,255,255,.4);color:#fff;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.return-btn[data-v-1d37fceb]:hover{background:#ffffff4d;border-color:#fff9}.navbar[data-v-1d37fceb]{background:var(--navbar-bg);color:var(--color-white);box-shadow:var(--shadow-md)}.navbar-container[data-v-1d37fceb]{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:64px}.navbar-brand h1[data-v-1d37fceb]{font-size:24px;margin:0}.navbar-brand a[data-v-1d37fceb]{color:var(--color-white);text-decoration:none}.navbar-menu[data-v-1d37fceb]{display:flex;gap:24px;align-items:center}.nav-link[data-v-1d37fceb]{color:var(--color-white-alpha-90);text-decoration:none;font-weight:500;padding:8px 12px;border-radius:4px;transition:background-color .3s ease;display:flex;align-items:center;gap:6px}.nav-link[data-v-1d37fceb]:hover,.nav-link.router-link-active[data-v-1d37fceb]{background-color:var(--color-white-alpha-10)}.nav-icon[data-v-1d37fceb]{font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center}.nav-text[data-v-1d37fceb]{white-space:nowrap}.superadmin-link[data-v-1d37fceb]{background:var(--color-white-alpha-20);font-weight:600;border:1px solid var(--color-white-alpha-40)}.superadmin-link[data-v-1d37fceb]:hover{background:var(--color-white-alpha-30)}.navbar-user[data-v-1d37fceb]{display:flex;gap:16px;align-items:center}.feature-request-btn[data-v-1d37fceb],.theme-toggle-btn[data-v-1d37fceb]{padding:8px 12px;background:var(--color-white-alpha-10);border:1px solid var(--color-white-alpha-30);border-radius:8px;color:var(--color-white);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;width:44px;height:44px}.feature-request-btn[data-v-1d37fceb]:hover,.theme-toggle-btn[data-v-1d37fceb]:hover{background:var(--color-white-alpha-20);transform:scale(1.05)}.feature-request-btn[data-v-1d37fceb]{background:linear-gradient(135deg,#ffd70033,#ffa50033);border-color:#ffd70066}.feature-request-btn[data-v-1d37fceb]:hover{background:linear-gradient(135deg,#ffd7004d,#ffa5004d);border-color:#ffd70099}.language-select-input[data-v-1d37fceb]{padding:8px 12px;background:var(--color-white-alpha-10);border:1px solid var(--color-white-alpha-30);border-radius:8px;color:var(--color-white);cursor:pointer;font-size:14px;transition:background .3s ease,border-color .3s ease}.language-select-input[data-v-1d37fceb]:hover{background:var(--color-white-alpha-20)}.language-select-input[data-v-1d37fceb]:focus{outline:none;border-color:var(--color-white-alpha-60);box-shadow:0 0 0 2px var(--color-white-alpha-30)}.language-select-input option[data-v-1d37fceb]{color:var(--color-text-primary);background:var(--bg-primary)}.user-info[data-v-1d37fceb]{display:flex;flex-direction:column;align-items:flex-end;font-size:14px}.user-name[data-v-1d37fceb]{font-weight:600}.user-org[data-v-1d37fceb]{font-size:12px;opacity:.8}.user-menu[data-v-1d37fceb]{position:relative}.user-menu-btn[data-v-1d37fceb]{padding:8px 16px;background:var(--color-white-alpha-10);border:1px solid var(--color-white-alpha-30);border-radius:8px;color:var(--color-white);cursor:pointer;font-size:16px;display:flex;align-items:center;gap:8px;transition:all .3s ease}.user-menu-btn[data-v-1d37fceb]:hover{background:var(--color-white-alpha-20)}.dropdown-arrow[data-v-1d37fceb]{font-size:10px;transition:transform .3s ease}.user-dropdown[data-v-1d37fceb]{position:absolute;top:calc(100% + 8px);right:0;background:var(--card-bg);border-radius:8px;box-shadow:0 4px 12px var(--color-black-alpha-15);min-width:200px;z-index:1000;overflow:hidden;border:1px solid var(--border-color)}.dropdown-item[data-v-1d37fceb]{width:100%;padding:12px 16px;background:var(--card-bg);border:none;text-align:left;cursor:pointer;font-size:14px;color:var(--color-text-primary);transition:background .2s ease;display:flex;align-items:center;gap:8px;text-decoration:none}.dropdown-item[data-v-1d37fceb]:hover{background:var(--bg-tertiary)}.dropdown-item.logout[data-v-1d37fceb]{color:var(--color-danger)}.dropdown-item.logout[data-v-1d37fceb]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-1d37fceb]{margin:0;border:none;border-top:1px solid var(--border-color)}.password-form[data-v-1d37fceb]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-1d37fceb]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-1d37fceb]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-1d37fceb]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-1d37fceb]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-1d37fceb]{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-primary);color:var(--color-text-primary)}.field-hint[data-v-1d37fceb]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-1d37fceb]{padding:10px;background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:6px;color:var(--color-danger-dark);font-size:14px}.navbar-user .btn[data-v-1d37fceb]{color:var(--color-white);border-color:var(--color-white-alpha-50)}.navbar-user .btn[data-v-1d37fceb]:hover{background-color:var(--color-white-alpha-10)}@media(max-width:768px){.navbar[data-v-1d37fceb]{position:sticky;top:0;z-index:100}.navbar-container[data-v-1d37fceb]{flex-wrap:wrap;height:auto;padding:12px 16px}.navbar-brand[data-v-1d37fceb]{flex-shrink:0}.navbar-brand h1[data-v-1d37fceb]{font-size:20px}.navbar-menu[data-v-1d37fceb]{order:3;width:100%;margin-top:12px;gap:8px;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;padding-bottom:8px;scrollbar-width:thin;scrollbar-color:var(--color-white-alpha-30) transparent}.navbar-menu[data-v-1d37fceb]::-webkit-scrollbar{height:4px}.navbar-menu[data-v-1d37fceb]::-webkit-scrollbar-track{background:transparent}.navbar-menu[data-v-1d37fceb]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-30);border-radius:2px}.nav-link[data-v-1d37fceb]{flex-shrink:0;white-space:nowrap;font-size:14px;padding:6px 10px}.nav-icon[data-v-1d37fceb]{font-size:16px}.user-info[data-v-1d37fceb]{display:none}}.bottom-nav[data-v-bf7c0e5b]{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--card-bg);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;align-items:center;padding:0 8px;z-index:999;box-shadow:0 -2px 10px #0000001a}@media(min-width:1024px){.bottom-nav[data-v-bf7c0e5b]{display:none}}.bottom-nav-item[data-v-bf7c0e5b]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;text-decoration:none;color:var(--color-text-secondary);transition:all .2s ease;border-radius:8px;position:relative;min-width:60px;max-width:80px}.bottom-nav-item[data-v-bf7c0e5b]:active{transform:scale(.95)}.nav-item-icon[data-v-bf7c0e5b]{font-size:24px;line-height:1;transition:transform .2s ease}.nav-item-label[data-v-bf7c0e5b]{font-size:11px;font-weight:500;line-height:1;white-space:nowrap;transition:color .2s ease}.bottom-nav-item.active[data-v-bf7c0e5b]{color:var(--color-primary)}.bottom-nav-item.active .nav-item-icon[data-v-bf7c0e5b]{transform:scale(1.1)}.bottom-nav-item.active .nav-item-label[data-v-bf7c0e5b]{font-weight:600}.bottom-nav-item.active[data-v-bf7c0e5b]:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--color-primary);border-radius:0 0 3px 3px}@media(hover:hover){.bottom-nav-item[data-v-bf7c0e5b]:hover{background:var(--bg-tertiary)}}@media(prefers-color-scheme:dark){.bottom-nav[data-v-bf7c0e5b]{box-shadow:0 -2px 10px #0000004d}}.mobile-layout[data-v-e7238e68]{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.mobile-main[data-v-e7238e68]{flex:1;padding-bottom:80px;overflow-y:auto}@media(min-width:1024px){.mobile-layout[data-v-e7238e68]{display:none}}.desktop-sidebar[data-v-e4c9cceb]{position:fixed;left:0;top:0;bottom:0;width:260px;background:var(--sidebar-bg);color:var(--color-white);display:flex;flex-direction:column;box-shadow:2px 0 10px var(--color-black-alpha-10);transition:width .3s ease;z-index:1000}.desktop-sidebar.collapsed[data-v-e4c9cceb]{width:80px}@media(max-width:1023px){.desktop-sidebar[data-v-e4c9cceb]{display:none}}.sidebar-header[data-v-e4c9cceb]{padding:20px;border-bottom:1px solid var(--color-white-alpha-10)}.sidebar-brand[data-v-e4c9cceb]{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--color-white)}.brand-icon[data-v-e4c9cceb]{font-size:32px;line-height:1;flex-shrink:0}.brand-text h1[data-v-e4c9cceb]{font-size:20px;margin:0;font-weight:600;white-space:nowrap}.brand-subtitle[data-v-e4c9cceb]{font-size:12px;margin:0;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav[data-v-e4c9cceb]{flex:1;padding:20px 0;overflow-y:auto;overflow-x:hidden}.sidebar-link[data-v-e4c9cceb]{display:flex;align-items:center;gap:12px;padding:12px 20px;color:var(--color-white-alpha-90);text-decoration:none;transition:all .2s ease;position:relative}.sidebar-link[data-v-e4c9cceb]:hover{background:var(--color-white-alpha-10)}.sidebar-link.router-link-active[data-v-e4c9cceb]{background:var(--color-white-alpha-15);font-weight:600}.sidebar-link.router-link-active[data-v-e4c9cceb]:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--card-bg);border-radius:0 4px 4px 0}.link-icon[data-v-e4c9cceb]{font-size:20px;line-height:1;flex-shrink:0;width:24px;display:flex;align-items:center;justify-content:center}.link-text[data-v-e4c9cceb]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-link.superadmin[data-v-e4c9cceb]{background:var(--color-white-alpha-20);margin:8px 12px;border-radius:8px;border:1px solid var(--color-white-alpha-30)}.sidebar-link.superadmin[data-v-e4c9cceb]:hover{background:var(--color-white-alpha-30)}.sidebar-footer[data-v-e4c9cceb]{padding:16px;border-top:1px solid var(--color-white-alpha-10);display:flex;flex-direction:column;gap:12px}.sidebar-action-btn[data-v-e4c9cceb]{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-white-alpha-10);border:1px solid var(--color-white-alpha-20);border-radius:8px;color:var(--color-white);cursor:pointer;transition:all .2s ease;width:100%}.sidebar-action-btn[data-v-e4c9cceb]:hover{background:var(--color-white-alpha-20)}.action-icon[data-v-e4c9cceb]{font-size:18px;flex-shrink:0}.action-text[data-v-e4c9cceb]{white-space:nowrap}.user-section[data-v-e4c9cceb]{position:relative}.user-btn[data-v-e4c9cceb]{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-white-alpha-10);border:1px solid var(--color-white-alpha-20);border-radius:8px;color:var(--color-white);cursor:pointer;transition:all .2s ease}.user-btn[data-v-e4c9cceb]:hover{background:var(--color-white-alpha-20)}.user-avatar[data-v-e4c9cceb]{width:36px;height:36px;border-radius:50%;background:var(--color-white-alpha-30);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.user-details[data-v-e4c9cceb]{flex:1;text-align:left;overflow:hidden}.user-name[data-v-e4c9cceb]{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role[data-v-e4c9cceb]{font-size:11px;opacity:.8;text-transform:capitalize}.user-dropdown[data-v-e4c9cceb]{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:var(--card-bg);border-radius:8px;box-shadow:0 -4px 12px #00000026;overflow:hidden;border:1px solid var(--border-color)}.dropdown-item[data-v-e4c9cceb]{width:100%;padding:12px 16px;background:var(--card-bg);border:none;text-align:left;cursor:pointer;font-size:14px;color:var(--color-text-primary);transition:background .2s ease;display:flex;align-items:center;gap:8px;text-decoration:none}.dropdown-item[data-v-e4c9cceb]:hover{background:var(--bg-tertiary)}.dropdown-icon[data-v-e4c9cceb]{font-size:16px}.dropdown-item.logout[data-v-e4c9cceb]{color:var(--color-danger)}.dropdown-item.logout[data-v-e4c9cceb]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-e4c9cceb]{margin:0;border:none;border-top:1px solid var(--border-color)}.collapse-btn[data-v-e4c9cceb]{padding:8px;background:var(--color-white-alpha-10);border:1px solid var(--color-white-alpha-20);border-radius:6px;color:var(--color-white);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.collapse-btn[data-v-e4c9cceb]:hover{background:var(--color-white-alpha-20)}.collapse-icon[data-v-e4c9cceb]{font-size:16px;font-weight:700}.desktop-sidebar.collapsed .sidebar-link[data-v-e4c9cceb],.desktop-sidebar.collapsed .sidebar-action-btn[data-v-e4c9cceb],.desktop-sidebar.collapsed .user-btn[data-v-e4c9cceb]{justify-content:center;padding-left:12px;padding-right:12px}.desktop-sidebar.collapsed .sidebar-header[data-v-e4c9cceb]{display:flex;justify-content:center;padding:20px 10px}.desktop-sidebar.collapsed .brand-text[data-v-e4c9cceb]{display:none}.password-form[data-v-e4c9cceb]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-e4c9cceb]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-e4c9cceb]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-e4c9cceb]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-e4c9cceb]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-e4c9cceb]{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-primary);color:var(--color-text-primary)}.field-hint[data-v-e4c9cceb]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-e4c9cceb]{padding:10px;background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:6px;color:var(--color-danger-dark);font-size:14px}.sidebar-nav[data-v-e4c9cceb]::-webkit-scrollbar{width:6px}.sidebar-nav[data-v-e4c9cceb]::-webkit-scrollbar-track{background:var(--color-white-alpha-10)}.sidebar-nav[data-v-e4c9cceb]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-20);border-radius:3px}.sidebar-nav[data-v-e4c9cceb]::-webkit-scrollbar-thumb:hover{background:var(--color-white-alpha-30)}.desktop-layout[data-v-d07d0699]{display:none;min-height:100vh;background:var(--bg-secondary)}@media(min-width:1024px){.desktop-layout[data-v-d07d0699]{display:flex}}.desktop-content[data-v-d07d0699]{flex:1;margin-left:260px;display:flex;flex-direction:column;transition:margin-left .3s ease;min-height:100vh;background:var(--bg-secondary)}.desktop-sidebar.collapsed~.desktop-content[data-v-d07d0699]{margin-left:80px}.desktop-header[data-v-d07d0699]{background:var(--card-bg);border-bottom:1px solid var(--border-color);padding:20px 32px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.header-left[data-v-d07d0699]{flex:1}.page-title[data-v-d07d0699]{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.header-right[data-v-d07d0699]{display:flex;gap:12px;align-items:center}.desktop-main[data-v-d07d0699]{flex:1;padding:32px;overflow-y:auto;background:var(--bg-secondary)}.desktop-main.no-padding[data-v-d07d0699]{padding:0}@media(min-width:1440px){.desktop-main[data-v-d07d0699]{padding:40px;max-width:1600px;margin:0 auto;width:100%}.desktop-main.no-padding[data-v-d07d0699]{padding:0;max-width:none}}.pwa-install-prompt[data-v-8d52bc36]{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#1976d2,#1565c0);color:var(--color-white);padding:16px 20px;box-shadow:0 -4px 12px #0003;z-index:9999;animation:slideUp .3s ease-out}.prompt-content[data-v-8d52bc36]{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:16px}.prompt-icon[data-v-8d52bc36]{font-size:36px;flex-shrink:0}.prompt-text[data-v-8d52bc36]{flex:1}.prompt-text h3[data-v-8d52bc36]{margin:0 0 4px;font-size:16px;font-weight:600}.prompt-text p[data-v-8d52bc36]{margin:0;font-size:13px;opacity:.95;line-height:1.4}.prompt-actions[data-v-8d52bc36]{display:flex;gap:12px;align-items:center;flex-shrink:0}.btn-install[data-v-8d52bc36]{padding:10px 20px;background:var(--card-bg);color:#1976d2;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-install[data-v-8d52bc36]:hover{background:var(--bg-secondary);transform:translateY(-1px)}.btn-install[data-v-8d52bc36]:active{transform:translateY(0)}.btn-dismiss[data-v-8d52bc36]{padding:8px 12px;background:#fff3;color:var(--color-white);border:none;border-radius:6px;font-size:16px;cursor:pointer;transition:all .2s ease;line-height:1}.btn-dismiss[data-v-8d52bc36]:hover{background:#ffffff4d}.slide-up-enter-active[data-v-8d52bc36],.slide-up-leave-active[data-v-8d52bc36]{transition:transform .3s ease-out}.slide-up-enter-from[data-v-8d52bc36],.slide-up-leave-to[data-v-8d52bc36]{transform:translateY(100%)}@media(max-width:768px){.pwa-install-prompt[data-v-8d52bc36]{padding:12px 16px}.prompt-content[data-v-8d52bc36]{flex-wrap:wrap;gap:12px}.prompt-icon[data-v-8d52bc36]{font-size:28px}.prompt-text h3[data-v-8d52bc36]{font-size:15px}.prompt-text p[data-v-8d52bc36]{font-size:12px}.prompt-actions[data-v-8d52bc36]{width:100%;justify-content:stretch}.btn-install[data-v-8d52bc36]{flex:1;padding:12px}}.floating-timer[data-v-56fb79b3]{position:fixed;bottom:80px;right:16px;background:var(--gradient-brand);color:var(--color-white);border-radius:16px;padding:12px 16px;box-shadow:0 8px 24px #667eea66;z-index:10000;cursor:pointer;min-width:200px;-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:auto}.floating-timer[data-v-56fb79b3]:active{transform:scale(.95)}.floating-timer[data-v-56fb79b3]:hover{box-shadow:0 12px 32px #667eea80;transform:translateY(-2px)}.timer-content[data-v-56fb79b3]{display:flex;align-items:center;gap:12px}.timer-icon[data-v-56fb79b3]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff3;border-radius:50%;position:relative}.pulse-dot[data-v-56fb79b3]{width:12px;height:12px;background:#ff4757;border-radius:50%;animation:pulse-56fb79b3 2s ease-in-out infinite}@keyframes pulse-56fb79b3{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.pause-icon[data-v-56fb79b3]{font-size:16px}.timer-info[data-v-56fb79b3]{flex:1}.timer-project[data-v-56fb79b3]{font-size:12px;font-weight:500;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.timer-time[data-v-56fb79b3]{font-size:18px;font-weight:700;font-family:Courier New,monospace;letter-spacing:1px}.timer-hint[data-v-56fb79b3]{margin-top:6px;font-size:10px;text-align:center;opacity:.7}.fade-slide-enter-active[data-v-56fb79b3],.fade-slide-leave-active[data-v-56fb79b3]{transition:all .3s cubic-bezier(.4,0,.2,1)}.fade-slide-enter-from[data-v-56fb79b3],.fade-slide-leave-to[data-v-56fb79b3]{opacity:0;transform:translateY(20px)}@media(min-width:769px){.floating-timer[data-v-56fb79b3]{bottom:24px;right:24px}}@media(max-width:360px){.floating-timer[data-v-56fb79b3]{min-width:180px;padding:10px 12px}.timer-time[data-v-56fb79b3]{font-size:16px}.timer-project[data-v-56fb79b3]{font-size:11px;max-width:110px}}#app{min-height:100vh}:root{--color-primary: #3b82f6;--color-primary-light: #60a5fa;--color-primary-dark: #2563eb;--color-primary-darker: #1d4ed8;--color-secondary: #1976d2;--color-secondary-light: #42a5f5;--color-secondary-dark: #1565c0;--color-success: #10b981;--color-success-light: #34d399;--color-success-dark: #059669;--color-success-bg: #d1fae5;--color-success-border: #6ee7b7;--color-warning: #f59e0b;--color-warning-light: #fbbf24;--color-warning-dark: #d97706;--color-warning-bg: #fef3c7;--color-warning-border: #fcd34d;--color-danger: #ef4444;--color-danger-light: #f87171;--color-danger-dark: #dc2626;--color-danger-bg: #fee2e2;--color-danger-border: #fca5a5;--color-info: #06b6d4;--color-info-light: #22d3ee;--color-info-dark: #0891b2;--color-info-bg: #cffafe;--color-info-border: #67e8f9;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-inverse: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--bg-dark: #111827;--bg-overlay: rgba(0, 0, 0, .5);--border-color: #e5e7eb;--border-color-light: #f3f4f6;--border-color-dark: #d1d5db;--border-radius-sm: .375rem;--border-radius-md: .5rem;--border-radius-lg: .75rem;--border-radius-xl: 1rem;--border-radius-2xl: 1.5rem;--border-radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--btn-padding-sm: .5rem 1rem;--btn-padding-md: .75rem 1.5rem;--btn-padding-lg: 1rem 2rem;--input-height-sm: 2rem;--input-height-md: 2.5rem;--input-height-lg: 3rem;--input-border: 2px solid var(--border-color);--input-border-focus: 2px solid var(--color-primary);--card-padding: var(--spacing-lg);--card-bg: var(--bg-primary);--card-border: 1px solid var(--border-color);--card-shadow: var(--shadow-md);--navbar-height: 4rem;--navbar-bg: var(--gradient-brand);--navbar-border: var(--border-color);--sidebar-width: 16rem;--sidebar-width-collapsed: 5rem;--sidebar-bg: var(--gradient-brand);--desktop-sidebar-width: 260px;--desktop-sidebar-width-collapsed: 80px;--desktop-header-height: 72px;--desktop-content-max-width: 1600px;--desktop-content-padding: 32px;--mobile-header-height: 64px;--mobile-bottom-nav-height: 64px;--mobile-content-padding: 16px;--breakpoint-mobile: 768px;--breakpoint-tablet: 1024px;--breakpoint-desktop: 1280px;--status-active-bg: var(--color-success-bg);--status-active-text: var(--color-success-dark);--status-active-border: var(--color-success-border);--status-inactive-bg: var(--color-gray-100);--status-inactive-text: var(--color-gray-600);--status-inactive-border: var(--color-gray-300);--status-pending-bg: var(--color-warning-bg);--status-pending-text: var(--color-warning-dark);--status-pending-border: var(--color-warning-border);--status-error-bg: var(--color-danger-bg);--status-error-text: var(--color-danger-dark);--status-error-border: var(--color-danger-border);--color-primary-alpha-10: rgba(59, 130, 246, .1);--color-primary-alpha-30: rgba(59, 130, 246, .3);--color-success-alpha-10: rgba(16, 185, 129, .1);--color-warning-alpha-10: rgba(245, 158, 11, .1);--color-danger-alpha-10: rgba(239, 68, 68, .1);--color-white-alpha-10: rgba(255, 255, 255, .1);--color-white-alpha-15: rgba(255, 255, 255, .15);--color-white-alpha-20: rgba(255, 255, 255, .2);--color-white-alpha-25: rgba(255, 255, 255, .25);--color-white-alpha-30: rgba(255, 255, 255, .3);--color-white-alpha-40: rgba(255, 255, 255, .4);--color-white-alpha-50: rgba(255, 255, 255, .5);--color-white-alpha-60: rgba(255, 255, 255, .6);--color-white-alpha-80: rgba(255, 255, 255, .8);--color-white-alpha-90: rgba(255, 255, 255, .9);--color-white: #ffffff;--color-black-alpha-10: rgba(0, 0, 0, .1);--color-black-alpha-15: rgba(0, 0, 0, .15);--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);--gradient-secondary: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-secondary-dark) 100%);--gradient-success: linear-gradient(135deg, var(--color-success) 0%, var(--color-success-dark) 100%);--gradient-warning: linear-gradient(135deg, var(--color-warning) 0%, var(--color-warning-dark) 100%);--gradient-brand: linear-gradient(135deg, #1976d2 0%, #1565c0 100%);--header-bg: var(--gradient-primary);--header-text-color: var(--color-white);--auth-page-bg: var(--gradient-brand);--auth-card-shadow: 0 8px 32px var(--color-black-alpha-15)}:root.dark{--bg-primary: #1f2937;--bg-secondary: #111827;--bg-tertiary: #374151;--bg-dark: #000000;--bg-overlay: rgba(0, 0, 0, .75);--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-text-inverse: #111827;--border-color: #374151;--border-color-light: #4b5563;--border-color-dark: #1f2937;--card-bg: #1f2937;--navbar-bg: #111827;--sidebar-bg: #1f2937;--color-gray-50: #1f2937;--color-gray-100: #374151;--color-gray-200: #4b5563;--color-gray-300: #6b7280;--color-gray-400: #9ca3af;--color-gray-500: #d1d5db;--color-gray-600: #e5e7eb;--color-gray-700: #f3f4f6;--color-gray-800: #f9fafb;--color-gray-900: #ffffff;--status-active-bg: rgba(16, 185, 129, .2);--status-active-text: #34d399;--status-active-border: #10b981;--status-inactive-bg: rgba(107, 114, 128, .2);--status-inactive-text: #9ca3af;--status-inactive-border: #6b7280;--status-pending-bg: rgba(245, 158, 11, .2);--status-pending-text: #fbbf24;--status-pending-border: #f59e0b;--status-error-bg: rgba(239, 68, 68, .2);--status-error-text: #f87171;--status-error-border: #ef4444;--color-success-bg: rgba(16, 185, 129, .15);--color-success-border: #10b981;--color-success-dark: #34d399;--color-warning-bg: rgba(245, 158, 11, .15);--color-warning-border: #f59e0b;--color-warning-dark: #fbbf24;--color-danger-bg: rgba(239, 68, 68, .15);--color-danger-border: #ef4444;--color-danger-dark: #f87171;--color-info-bg: rgba(6, 182, 212, .15);--color-info-border: #06b6d4;--color-info-dark: #22d3ee;--color-primary-alpha-10: rgba(96, 165, 250, .15);--color-primary-alpha-30: rgba(96, 165, 250, .3);--color-success-alpha-10: rgba(16, 185, 129, .15);--color-warning-alpha-10: rgba(245, 158, 11, .15);--color-danger-alpha-10: rgba(239, 68, 68, .15);--color-white-alpha-10: rgba(55, 65, 81, .1);--color-white-alpha-15: rgba(55, 65, 81, .15);--color-white-alpha-20: rgba(55, 65, 81, .2);--color-white-alpha-25: rgba(55, 65, 81, .25);--color-white-alpha-30: rgba(55, 65, 81, .3);--color-white-alpha-40: rgba(55, 65, 81, .4);--color-white-alpha-50: rgba(55, 65, 81, .5);--color-white-alpha-60: rgba(55, 65, 81, .6);--color-white-alpha-80: rgba(31, 41, 55, .8);--color-white-alpha-90: rgba(249, 250, 251, .9);--color-white: #f9fafb;--color-black-alpha-10: rgba(0, 0, 0, .4);--color-black-alpha-15: rgba(0, 0, 0, .5);--header-bg: var(--card-bg);--header-text-color: var(--color-text-primary);--auth-page-bg: var(--bg-secondary);--auth-card-shadow: 0 8px 32px rgba(0, 0, 0, .6);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .7)}:root.dark ::-webkit-scrollbar-track{background-color:#1f2937}:root.dark ::-webkit-scrollbar-thumb{background-color:#4b5563}:root.dark ::-webkit-scrollbar-thumb:hover{background-color:#6b7280}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-info{color:var(--color-info)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.bg-success{background-color:var(--color-success)}.bg-warning{background-color:var(--color-warning)}.bg-danger{background-color:var(--color-danger)}.bg-info{background-color:var(--color-info)}.gradient-primary{background:var(--gradient-primary)}.gradient-secondary{background:var(--gradient-secondary)}.gradient-brand{background:var(--gradient-brand)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-2xl{box-shadow:var(--shadow-2xl)}.rounded-sm{border-radius:var(--border-radius-sm)}.rounded-md{border-radius:var(--border-radius-md)}.rounded-lg{border-radius:var(--border-radius-lg)}.rounded-xl{border-radius:var(--border-radius-xl)}.rounded-2xl{border-radius:var(--border-radius-2xl)}.rounded-full{border-radius:var(--border-radius-full)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--btn-padding-md);border:none;border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-sm{padding:var(--btn-padding-sm);font-size:var(--font-size-sm)}.btn-lg{padding:var(--btn-padding-lg);font-size:var(--font-size-lg)}.btn-full{width:100%}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-300)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark)}.btn-warning{background-color:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background-color:var(--color-warning-dark)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--color-danger-dark)}.btn-outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-text-primary)}.card{background-color:var(--card-bg);border:var(--card-border);border-radius:var(--border-radius-lg);box-shadow:var(--card-shadow);overflow:hidden}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.card-title{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.card-subtitle{margin:var(--spacing-xs) 0 0 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.card-hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);transition:all var(--transition-base)}.card-success{border-left:4px solid var(--color-success)}.card-warning{border-left:4px solid var(--color-warning)}.card-danger{border-left:4px solid var(--color-danger)}.card-info{border-left:4px solid var(--color-info)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-input,.form-select,.form-textarea{width:100%;height:var(--input-height-md);padding:0 var(--spacing-md);border:var(--input-border);border-radius:var(--border-radius-md);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--bg-primary);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border:var(--input-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha-10)}.form-input-error,.form-select-error,.form-textarea-error{border-color:var(--color-danger)}.form-input-error:focus,.form-select-error:focus,.form-textarea-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-alpha-10)}.form-textarea{height:auto;padding:var(--spacing-md);min-height:100px;resize:vertical}.form-error{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-danger)}.form-help{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.form-checkbox,.form-radio{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.form-checkbox input[type=checkbox],.form-radio input[type=radio]{width:1.25rem;height:1.25rem;cursor:pointer}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.25rem .75rem;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1}.badge-primary{background-color:var(--color-primary-alpha-10);color:var(--color-primary-dark)}.badge-success{background-color:var(--status-active-bg);color:var(--status-active-text)}.badge-warning{background-color:var(--status-pending-bg);color:var(--status-pending-text)}.badge-danger{background-color:var(--status-error-bg);color:var(--status-error-text)}.badge-info{background-color:var(--color-info-bg);color:var(--color-info-dark)}.badge-secondary{background-color:var(--status-inactive-bg);color:var(--status-inactive-text)}.alert{padding:var(--spacing-md);border-radius:var(--border-radius-md);border-left:4px solid;background-color:var(--bg-secondary)}.alert-success{border-color:var(--color-success);background-color:var(--color-success-bg);color:var(--color-success-dark)}.alert-warning{border-color:var(--color-warning);background-color:var(--color-warning-bg);color:var(--color-warning-dark)}.alert-danger,.alert-error{border-color:var(--color-danger);background-color:var(--color-danger-bg);color:var(--color-danger-dark)}.alert-info{border-color:var(--color-info);background-color:var(--color-info-bg);color:var(--color-info-dark)}.table{width:100%;border-collapse:collapse;background-color:var(--bg-primary);border-radius:var(--border-radius-lg);overflow:hidden}.table thead{background-color:var(--bg-secondary)}.table th{padding:var(--spacing-md);text-align:left;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.table td{padding:var(--spacing-md);border-top:1px solid var(--border-color);font-size:var(--font-size-sm);color:var(--color-text-primary)}.table tbody tr:hover{background-color:var(--bg-secondary)}.modal-overlay{position:fixed;inset:0;background-color:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-md)}.modal{background-color:var(--bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-2xl);max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-title{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-close{background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-text-secondary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.spinner{width:1.25rem;height:1.25rem;border:3px solid var(--color-white-alpha-30);border-top-color:var(--color-white);border-radius:var(--border-radius-full);animation:spin .6s linear infinite}.spinner-primary{border-color:var(--color-primary-alpha-30);border-top-color:var(--color-primary)}.spinner-lg{width:2.5rem;height:2.5rem;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:absolute;inset:0;background-color:var(--color-white-alpha-80);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.stat-card{background:var(--card-bg);border:var(--card-border);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);box-shadow:var(--card-shadow)}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.stat-card-icon{width:3rem;height:3rem;border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl)}.stat-card-icon-primary{background-color:var(--color-primary-alpha-10);color:var(--color-primary)}.stat-card-icon-success{background-color:var(--color-success-alpha-10);color:var(--color-success)}.stat-card-icon-warning{background-color:var(--color-warning-alpha-10);color:var(--color-warning)}.stat-card-icon-danger{background-color:var(--color-danger-alpha-10);color:var(--color-danger)}.stat-card-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0 0}.empty-state{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl)}.empty-state-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.3}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.empty-state-text{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0 0 var(--spacing-lg) 0}@media(max-width:768px){.modal{border-radius:var(--border-radius-xl) var(--border-radius-xl) 0 0;align-self:flex-end;max-height:85vh}.form-row{grid-template-columns:1fr}.btn-full-mobile{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background-color:var(--bg-secondary);color:var(--color-text-primary);line-height:var(--line-height-normal);overflow-x:hidden;width:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;overflow-x:hidden;width:100%}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md);line-height:var(--line-height-relaxed)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}code{font-family:var(--font-mono);font-size:.875em;padding:.125rem .25rem;background-color:var(--color-gray-100);border-radius:var(--border-radius-sm)}pre{font-family:var(--font-mono);padding:var(--spacing-md);background-color:var(--color-gray-900);color:var(--color-gray-100);border-radius:var(--border-radius-md);overflow-x:auto}pre code{background-color:transparent;padding:0}.container{max-width:1200px;margin:0 auto;padding:var(--spacing-xl);width:100%}.container-fluid{padding:var(--spacing-xl);width:100%}.section{margin-bottom:var(--spacing-3xl)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-center{display:flex;justify-content:center;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-start{display:flex;justify-content:flex-start;align-items:center}.flex-end{display:flex;justify-content:flex-end;align-items:center}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.grid{display:grid}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}@media(max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-medium{font-weight:var(--font-weight-medium)}.font-normal{font-weight:var(--font-weight-normal)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.m-0{margin:0}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.ml-xs{margin-left:var(--spacing-xs)}.ml-sm{margin-left:var(--spacing-sm)}.ml-md{margin-left:var(--spacing-md)}.ml-lg{margin-left:var(--spacing-lg)}.mr-xs{margin-right:var(--spacing-xs)}.mr-sm{margin-right:var(--spacing-sm)}.mr-md{margin-right:var(--spacing-md)}.mr-lg{margin-right:var(--spacing-lg)}.p-0{padding:0}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.hidden{display:none!important}.visible{display:block!important}@media(max-width:768px){.hidden-mobile{display:none!important}}@media(min-width:769px){.visible-mobile{display:none!important}}.transition{transition:all var(--transition-base)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background-color:var(--color-gray-100)}::-webkit-scrollbar-thumb{background-color:var(--color-gray-400);border-radius:var(--border-radius-full)}::-webkit-scrollbar-thumb:hover{background-color:var(--color-gray-500)}@media(max-width:1280px){.container{padding:var(--spacing-lg)}}@media(max-width:768px){.container,.container-fluid{padding:var(--spacing-md)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}}@media print{body{background-color:#fff}.no-print{display:none!important}}@media(min-width:1024px){.customers-table{font-size:14px}.customers-table th,.customers-table td{padding:16px}.customers-page{max-width:none}}@media(min-width:1024px){.time-entries-grid{grid-template-columns:repeat(3,1fr)!important;gap:20px!important}.time-entry-card{min-height:180px}}@media(min-width:1440px){.time-entries-grid{grid-template-columns:repeat(4,1fr)!important}}@media(min-width:1024px){.assignments-grid{grid-template-columns:repeat(3,1fr)!important;gap:20px!important}}@media(min-width:1440px){.assignments-grid{grid-template-columns:repeat(4,1fr)!important}}@media(min-width:1024px){.settings-page{max-width:1400px;margin:0 auto}.settings-sections{display:grid;grid-template-columns:300px 1fr;gap:32px}.settings-nav{position:sticky;top:100px;height:fit-content}}@media(min-width:1024px){.users-table{font-size:14px}.users-table th,.users-table td{padding:16px}}@media(min-width:1024px){.card-grid,.grid-container{grid-template-columns:repeat(3,1fr);gap:24px}}@media(min-width:1440px){.card-grid,.grid-container{grid-template-columns:repeat(4,1fr)}}@media(min-width:1024px){table{border-collapse:separate;border-spacing:0}table thead{position:sticky;top:0;z-index:10;background:var(--bg-tertiary)}table th{font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:12px}table tbody tr:hover{background:var(--bg-secondary);cursor:pointer}}@media(min-width:1024px){.modal-overlay{padding:40px}.modal-content,.modal{max-width:800px;max-height:85vh}.modal-content.large,.modal.large{max-width:1200px}}@media(min-width:1024px){.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-row.triple{grid-template-columns:repeat(3,1fr)}.form-group.full-width{grid-column:1 / -1}}@media(min-width:1024px){.page-container,.content-wrapper{max-width:1600px;margin:0 auto;padding:32px}}@media(min-width:1440px){.page-container,.content-wrapper{padding:40px}}@media(min-width:1024px){.with-sidebar{display:grid;grid-template-columns:280px 1fr;gap:32px}.sidebar{position:sticky;top:100px;height:fit-content}}@media(min-width:1024px){.page-header{margin-bottom:32px}.section+.section{margin-top:48px}.card{padding:24px}}@media(hover:hover){.clickable-row:hover,.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}button:hover,.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}}@media(min-width:1024px){h1{font-size:32px}h2{font-size:24px}h3{font-size:20px}.page-title{font-size:28px}}
