.modal-overlay[data-v-1794ce54]{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-1794ce54]{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-1794ce54]{width:400px}.modal-medium[data-v-1794ce54]{width:600px}.modal-large[data-v-1794ce54]{width:900px}.modal-header[data-v-1794ce54]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-title-wrapper[data-v-1794ce54]{display:flex;align-items:center;gap:.75rem}.modal-icon[data-v-1794ce54]{font-size:1.5rem;line-height:1}.modal-title[data-v-1794ce54]{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.modal-close[data-v-1794ce54]{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-1794ce54]:hover{color:#111827;background-color:#f3f4f6}.modal-body[data-v-1794ce54]{padding:1.5rem;overflow-y:auto;flex:1}.modal-body p[data-v-1794ce54]{margin:0;color:#4b5563;line-height:1.6}.modal-footer[data-v-1794ce54]{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-1794ce54],.modal-danger .modal-title[data-v-1794ce54]{color:#dc2626}.modal-warning .modal-icon[data-v-1794ce54],.modal-warning .modal-title[data-v-1794ce54]{color:#f59e0b}.modal-success .modal-icon[data-v-1794ce54],.modal-success .modal-title[data-v-1794ce54]{color:#10b981}.modal-info .modal-icon[data-v-1794ce54],.modal-info .modal-title[data-v-1794ce54]{color:#3b82f6}.spinner[data-v-1794ce54]{width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white);border-radius:50%;animation:spin-1794ce54 .6s linear infinite}@keyframes spin-1794ce54{to{transform:rotate(360deg)}}.modal-enter-active[data-v-1794ce54],.modal-leave-active[data-v-1794ce54]{transition:opacity .3s ease}.modal-enter-active .modal-container[data-v-1794ce54],.modal-leave-active .modal-container[data-v-1794ce54]{transition:transform .3s ease}.modal-enter-from[data-v-1794ce54],.modal-leave-to[data-v-1794ce54]{opacity:0}.modal-enter-from .modal-container[data-v-1794ce54],.modal-leave-to .modal-container[data-v-1794ce54]{transform:scale(.9)}@media(max-width:640px){.modal-small[data-v-1794ce54],.modal-medium[data-v-1794ce54],.modal-large[data-v-1794ce54]{width:100%;max-width:100%}.modal-container[data-v-1794ce54]{border-radius:12px 12px 0 0;align-self:flex-end;max-height:85vh}}.brand-logo[data-v-5f5ee232]{display:flex;flex-direction:column;align-items:center;gap:6px;line-height:1}.brand-mark[data-v-5f5ee232]{display:block;max-width:100%;height:auto}.brand-text[data-v-5f5ee232]{font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-text-color, var(--color-text-primary));font-family:var(--font-display)}.brand-sm .brand-mark[data-v-5f5ee232]{width:48px}.brand-sm .brand-text[data-v-5f5ee232]{font-size:11px}.brand-md .brand-mark[data-v-5f5ee232]{width:72px}.brand-md .brand-text[data-v-5f5ee232]{font-size:12px}.brand-lg .brand-mark[data-v-5f5ee232]{width:110px}.brand-lg .brand-text[data-v-5f5ee232]{font-size:14px}.modal-overlay[data-v-7721bb54]{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn-7721bb54 .2s ease}@keyframes fadeIn-7721bb54{0%{opacity:0}to{opacity:1}}.modal-content[data-v-7721bb54]{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-7721bb54 .3s ease}@keyframes slideUp-7721bb54{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header[data-v-7721bb54]{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.modal-header h2[data-v-7721bb54]{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.btn-close[data-v-7721bb54]{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-7721bb54]:hover{color:var(--color-text-primary)}.modal-body[data-v-7721bb54]{padding:24px}.intro-text[data-v-7721bb54]{margin:0 0 24px;font-size:14px;color:var(--color-text-secondary);line-height:1.6}.form-group[data-v-7721bb54]{margin-bottom:20px}.form-group label[data-v-7721bb54]{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.form-group select[data-v-7721bb54],.form-group input[data-v-7721bb54],.form-group textarea[data-v-7721bb54]{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-7721bb54]{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}:root.dark .form-group select[data-v-7721bb54],.dark-mode .form-group select[data-v-7721bb54]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23d1d5db' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.form-group select[data-v-7721bb54]:focus,.form-group input[data-v-7721bb54]:focus,.form-group textarea[data-v-7721bb54]:focus{outline:none;border-color:var(--color-primary)}.form-group textarea[data-v-7721bb54]{resize:vertical;min-height:120px}.char-count[data-v-7721bb54]{text-align:right;font-size:12px;color:var(--color-text-secondary);margin-top:4px}.tips-box[data-v-7721bb54]{padding:16px;background:var(--bg-secondary);border-left:4px solid var(--color-primary);border-radius:6px;margin-bottom:20px}.tips-title[data-v-7721bb54]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.tips-box ul[data-v-7721bb54]{margin:0;padding-left:20px;font-size:13px;color:var(--color-text-secondary)}.tips-box li[data-v-7721bb54]{margin-bottom:4px;line-height:1.5}.error-message[data-v-7721bb54]{padding:12px;background:#fee2e2;color:#991b1b;border-radius:6px;margin-bottom:16px;font-size:14px}.modal-footer[data-v-7721bb54]{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border-color)}@media(max-width:768px){.modal-content[data-v-7721bb54]{max-height:95vh}.modal-header[data-v-7721bb54],.modal-body[data-v-7721bb54]{padding:16px}.modal-header h2[data-v-7721bb54]{font-size:20px}.modal-footer[data-v-7721bb54]{flex-direction:column-reverse}.btn-primary[data-v-7721bb54],.btn-secondary[data-v-7721bb54]{width:100%}}.impersonation-banner[data-v-6672ae3f]{background:var(--gradient-warning);color:var(--color-white);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-6672ae3f]{display:flex;align-items:center;gap:8px}.impersonation-text strong[data-v-6672ae3f]{font-weight:600}.impersonation-text .org-name[data-v-6672ae3f]{opacity:.9}.return-btn[data-v-6672ae3f]{background:var(--color-white-alpha-20);border:1px solid var(--color-white-alpha-40);color:var(--color-white);padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.return-btn[data-v-6672ae3f]:hover{background:var(--color-white-alpha-30);border-color:var(--color-white-alpha-60)}.navbar[data-v-6672ae3f]{background:var(--navbar-bg);color:var(--color-white);box-shadow:var(--shadow-md)}.navbar-container[data-v-6672ae3f]{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:64px}.navbar-brand a[data-v-6672ae3f]{color:var(--color-white);text-decoration:none}.navbar-brand[data-v-6672ae3f]{--brand-text-color: var(--color-white)}.navbar-menu[data-v-6672ae3f]{display:flex;gap:24px;align-items:center}.nav-link[data-v-6672ae3f]{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-6672ae3f]:hover,.nav-link.router-link-active[data-v-6672ae3f]{background-color:var(--color-white-alpha-10)}.nav-icon[data-v-6672ae3f]{font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center}.nav-text[data-v-6672ae3f]{white-space:nowrap}.superadmin-link[data-v-6672ae3f]{background:var(--color-white-alpha-20);font-weight:600;border:1px solid var(--color-white-alpha-40)}.superadmin-link[data-v-6672ae3f]:hover{background:var(--color-white-alpha-30)}.navbar-user[data-v-6672ae3f]{display:flex;gap:16px;align-items:center}.feature-request-btn[data-v-6672ae3f],.theme-toggle-btn[data-v-6672ae3f]{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-6672ae3f]:hover,.theme-toggle-btn[data-v-6672ae3f]:hover{background:var(--color-white-alpha-20);transform:scale(1.05)}.feature-request-btn[data-v-6672ae3f]{background:linear-gradient(135deg,var(--color-warning-alpha-20) 0%,var(--color-warning-alpha-30) 100%);border-color:var(--color-warning-alpha-40)}.feature-request-btn[data-v-6672ae3f]:hover{background:linear-gradient(135deg,var(--color-warning-alpha-30) 0%,var(--color-warning-alpha-40) 100%);border-color:var(--color-warning-alpha-60)}.language-select-input[data-v-6672ae3f]{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-6672ae3f]:hover{background:var(--color-white-alpha-20)}.language-select-input[data-v-6672ae3f]: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-6672ae3f]{color:var(--color-text-primary);background:var(--bg-primary)}.user-info[data-v-6672ae3f]{display:flex;flex-direction:column;align-items:flex-end;font-size:14px}.user-name[data-v-6672ae3f]{font-weight:600}.user-org[data-v-6672ae3f]{font-size:12px;opacity:.8}.user-menu[data-v-6672ae3f]{position:relative}.user-menu-btn[data-v-6672ae3f]{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-6672ae3f]:hover{background:var(--color-white-alpha-20)}.dropdown-arrow[data-v-6672ae3f]{font-size:10px;transition:transform .3s ease}.user-dropdown[data-v-6672ae3f]{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-6672ae3f]{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-6672ae3f]:hover{background:var(--bg-tertiary)}.dropdown-item.logout[data-v-6672ae3f]{color:var(--color-danger)}.dropdown-item.logout[data-v-6672ae3f]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-6672ae3f]{margin:0;border:none;border-top:1px solid var(--border-color)}.password-form[data-v-6672ae3f]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-6672ae3f]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-6672ae3f]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-6672ae3f]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-6672ae3f]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-6672ae3f]{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-6672ae3f]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-6672ae3f]{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-6672ae3f]{color:var(--color-white);border-color:var(--color-white-alpha-50)}.navbar-user .btn[data-v-6672ae3f]:hover{background-color:var(--color-white-alpha-10)}@media(max-width:1023px){.navbar[data-v-6672ae3f]{display:none}.impersonation-banner[data-v-6672ae3f]{display:flex!important}}@media(max-width:768px){.navbar[data-v-6672ae3f]{position:sticky;top:0;z-index:1001}.navbar-container[data-v-6672ae3f]{flex-wrap:wrap;height:auto;padding:12px 16px}.navbar-brand[data-v-6672ae3f]{flex-shrink:0}.navbar-menu[data-v-6672ae3f]{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-6672ae3f]::-webkit-scrollbar{height:4px}.navbar-menu[data-v-6672ae3f]::-webkit-scrollbar-track{background:transparent}.navbar-menu[data-v-6672ae3f]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-30);border-radius:2px}.nav-link[data-v-6672ae3f]{flex-shrink:0;white-space:nowrap;font-size:14px;padding:6px 10px}.nav-icon[data-v-6672ae3f]{font-size:16px}.user-info[data-v-6672ae3f]{display:none}}.bottom-nav[data-v-9f6b6b2c]{position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--card-bg);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;align-items:flex-start;padding-top:8px;padding-left:8px;padding-right:8px;z-index:999;box-shadow:0 -2px 10px var(--color-black-alpha-15);transform:translateZ(0);-webkit-transform:translateZ(0);touch-action:none;-webkit-user-select:none;user-select:none;overscroll-behavior:none}@media(min-width:1024px){.bottom-nav[data-v-9f6b6b2c]{display:none}}.bottom-nav-item[data-v-9f6b6b2c]{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);background:transparent;border:none;appearance:none;-webkit-appearance:none;font:inherit;transition:all .2s ease;border-radius:8px;position:relative;min-width:60px;max-width:80px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;-webkit-touch-callout:none}.bottom-nav-item[data-v-9f6b6b2c]:active{transform:scale(.95)}.nav-item-icon[data-v-9f6b6b2c]{font-size:24px;line-height:1;transition:transform .2s ease;color:inherit;font-variant-emoji:text}.nav-item-label[data-v-9f6b6b2c]{font-size:11px;font-weight:500;line-height:1;white-space:nowrap;transition:color .2s ease}.bottom-nav-item.active[data-v-9f6b6b2c]{color:var(--color-primary)}.bottom-nav-item.active .nav-item-icon[data-v-9f6b6b2c]{transform:scale(1.1)}.bottom-nav-item.active .nav-item-label[data-v-9f6b6b2c]{font-weight:600}.bottom-nav-item.active[data-v-9f6b6b2c]: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-9f6b6b2c]:hover{background:var(--bg-tertiary)}}.more-menu-overlay[data-v-9f6b6b2c]{position:fixed;inset:0;background:var(--bg-overlay);z-index:1000;display:flex;align-items:flex-end;justify-content:center}.more-menu[data-v-9f6b6b2c]{background:var(--card-bg);border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:80vh;overflow-y:auto;padding-bottom:80px}.more-menu-header[data-v-9f6b6b2c]{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.more-menu-header .user-info[data-v-9f6b6b2c]{display:flex;flex-direction:column;gap:2px}.more-menu-header .user-name[data-v-9f6b6b2c]{font-weight:600;font-size:16px;color:var(--color-text-primary)}.more-menu-header .user-org[data-v-9f6b6b2c]{font-size:13px;color:var(--color-text-secondary)}.more-menu-header .close-btn[data-v-9f6b6b2c]{width:44px;height:44px;border:none;background:var(--bg-tertiary);border-radius:50%;font-size:24px;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.more-menu-header .close-btn[data-v-9f6b6b2c]:active{background:var(--bg-secondary);transform:scale(.95)}.more-menu-items[data-v-9f6b6b2c]{padding:12px 0}.menu-item[data-v-9f6b6b2c]{display:flex;align-items:center;gap:16px;width:100%;padding:16px 20px;background:none;border:none;text-align:left;font-size:16px;color:var(--color-text-primary);cursor:pointer;transition:background .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:52px;position:relative}.menu-item[data-v-9f6b6b2c]>*{pointer-events:none}.menu-item[data-v-9f6b6b2c]:active{background:var(--bg-tertiary)}.menu-item .menu-icon[data-v-9f6b6b2c]{font-size:22px;width:28px;text-align:center;flex-shrink:0}.menu-item.logout[data-v-9f6b6b2c]{color:var(--color-danger)}.menu-divider[data-v-9f6b6b2c]{height:1px;background:var(--border-color);margin:8px 20px}.slide-up-enter-active[data-v-9f6b6b2c],.slide-up-leave-active[data-v-9f6b6b2c]{transition:all .3s ease}.slide-up-enter-from[data-v-9f6b6b2c],.slide-up-leave-to[data-v-9f6b6b2c]{opacity:0}.slide-up-enter-from .more-menu[data-v-9f6b6b2c],.slide-up-leave-to .more-menu[data-v-9f6b6b2c]{transform:translateY(100%)}.slide-up-enter-to .more-menu[data-v-9f6b6b2c],.slide-up-leave-from .more-menu[data-v-9f6b6b2c]{transform:translateY(0)}.mobile-layout[data-v-5bd2aa91]{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--app-bg);height:100%;overflow:hidden;overscroll-behavior-x:none;touch-action:pan-y}.mobile-main[data-v-5bd2aa91]{flex:1;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;overscroll-behavior-x:none}@media(min-width:1024px){.mobile-layout[data-v-5bd2aa91]{display:none}}.desktop-sidebar[data-v-7e0e999a]{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-7e0e999a]{width:80px}@media(max-width:1023px){.desktop-sidebar[data-v-7e0e999a]{display:none}}.sidebar-header[data-v-7e0e999a]{padding:20px;border-bottom:1px solid var(--color-white-alpha-10)}.sidebar-brand[data-v-7e0e999a]{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--color-white);--brand-text-color: var(--color-white)}.brand-subtitle[data-v-7e0e999a]{font-size:12px;margin:0;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav[data-v-7e0e999a]{flex:1;padding:20px 0;overflow-y:auto;overflow-x:hidden}.sidebar-link[data-v-7e0e999a]{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-7e0e999a]:hover{background:var(--color-white-alpha-10)}.sidebar-link.router-link-active[data-v-7e0e999a]{background:var(--color-white-alpha-15);font-weight:600}.sidebar-link.router-link-active[data-v-7e0e999a]: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-7e0e999a]{font-size:20px;line-height:1;flex-shrink:0;width:24px;display:flex;align-items:center;justify-content:center}.link-text[data-v-7e0e999a]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-link.superadmin[data-v-7e0e999a]{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-7e0e999a]:hover{background:var(--color-white-alpha-30)}.sidebar-footer[data-v-7e0e999a]{padding:16px;border-top:1px solid var(--color-white-alpha-10);display:flex;flex-direction:column;gap:12px}.sidebar-action-btn[data-v-7e0e999a]{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-7e0e999a]:hover{background:var(--color-white-alpha-20)}.action-icon[data-v-7e0e999a]{font-size:18px;flex-shrink:0}.action-text[data-v-7e0e999a]{white-space:nowrap}.feature-request-btn[data-v-7e0e999a]{background:linear-gradient(135deg,#ffd70026,#ffa50026);border-color:#ffd7004d}.feature-request-btn[data-v-7e0e999a]:hover{background:linear-gradient(135deg,#ffd70040,#ffa50040);border-color:#ffd70080}.user-section[data-v-7e0e999a]{position:relative}.user-btn[data-v-7e0e999a]{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-7e0e999a]:hover{background:var(--color-white-alpha-20)}.user-avatar[data-v-7e0e999a]{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-7e0e999a]{flex:1;text-align:left;overflow:hidden}.user-name[data-v-7e0e999a]{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role[data-v-7e0e999a]{font-size:11px;opacity:.8;text-transform:capitalize}.user-dropdown[data-v-7e0e999a]{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-7e0e999a]{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-7e0e999a]:hover{background:var(--bg-tertiary)}.dropdown-icon[data-v-7e0e999a]{font-size:16px}.dropdown-item.logout[data-v-7e0e999a]{color:var(--color-danger)}.dropdown-item.logout[data-v-7e0e999a]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-7e0e999a]{margin:0;border:none;border-top:1px solid var(--border-color)}.collapse-btn[data-v-7e0e999a]{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-7e0e999a]:hover{background:var(--color-white-alpha-20)}.collapse-icon[data-v-7e0e999a]{font-size:16px;font-weight:700}.desktop-sidebar.collapsed .sidebar-link[data-v-7e0e999a],.desktop-sidebar.collapsed .sidebar-action-btn[data-v-7e0e999a],.desktop-sidebar.collapsed .user-btn[data-v-7e0e999a]{justify-content:center;padding-left:12px;padding-right:12px}.desktop-sidebar.collapsed .sidebar-header[data-v-7e0e999a]{display:flex;justify-content:center;padding:20px 10px}.desktop-sidebar.collapsed .brand-text[data-v-7e0e999a]{display:none}.password-form[data-v-7e0e999a]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-7e0e999a]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-7e0e999a]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-7e0e999a]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-7e0e999a]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-7e0e999a]{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-7e0e999a]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-7e0e999a]{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-7e0e999a]::-webkit-scrollbar{width:6px}.sidebar-nav[data-v-7e0e999a]::-webkit-scrollbar-track{background:var(--color-white-alpha-10)}.sidebar-nav[data-v-7e0e999a]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-20);border-radius:3px}.sidebar-nav[data-v-7e0e999a]::-webkit-scrollbar-thumb:hover{background:var(--color-white-alpha-30)}.notification-section[data-v-7e0e999a],.notification-btn[data-v-7e0e999a]{position:relative}.notification-btn.has-unread .action-icon[data-v-7e0e999a]{animation:bell-shake-7e0e999a .5s ease-in-out}@keyframes bell-shake-7e0e999a{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}50%{transform:rotate(15deg)}75%{transform:rotate(-10deg)}}.notification-badge[data-v-7e0e999a]{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;background:var(--color-danger);color:#fff;font-size:11px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1}.desktop-sidebar.collapsed .notification-badge[data-v-7e0e999a]{top:2px;right:8px}.notification-dropdown[data-v-7e0e999a]{position:absolute;bottom:calc(100% + 8px);left:0;width:360px;max-height:480px;background:var(--card-bg);border-radius:12px;box-shadow:0 -8px 32px #00000040;border:1px solid var(--border-color);overflow:hidden;z-index:1100}.notification-header[data-v-7e0e999a]{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.notification-header h4[data-v-7e0e999a]{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.mark-all-read[data-v-7e0e999a]{background:none;border:none;color:var(--color-primary);font-size:13px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.mark-all-read[data-v-7e0e999a]:hover{background:var(--color-primary-bg)}.notification-list[data-v-7e0e999a]{max-height:360px;overflow-y:auto}.notification-empty[data-v-7e0e999a]{padding:32px 16px;text-align:center;color:var(--color-text-secondary);font-size:14px}.notification-item[data-v-7e0e999a]{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s;position:relative}.notification-item[data-v-7e0e999a]:hover{background:var(--bg-tertiary)}.notification-item[data-v-7e0e999a]:last-child{border-bottom:none}.notification-item.unread[data-v-7e0e999a]{background:var(--color-primary-bg)}.notification-item.unread[data-v-7e0e999a]:hover{background:#3b82f626}.notification-icon[data-v-7e0e999a]{font-size:20px;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:8px}.notification-content[data-v-7e0e999a]{flex:1;min-width:0}.notification-title[data-v-7e0e999a]{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-body[data-v-7e0e999a]{font-size:13px;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time[data-v-7e0e999a]{font-size:11px;color:var(--color-text-tertiary);margin-top:4px}.notification-unread-dot[data-v-7e0e999a]{position:absolute;top:50%;right:12px;transform:translateY(-50%);width:8px;height:8px;background:var(--color-primary);border-radius:50%}.notification-footer[data-v-7e0e999a]{padding:12px 16px;text-align:center;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.notification-footer a[data-v-7e0e999a]{color:var(--color-primary);text-decoration:none;font-size:13px;font-weight:500}.notification-footer a[data-v-7e0e999a]:hover{text-decoration:underline}.desktop-layout[data-v-27d3e745]{display:none;min-height:100vh;background:var(--app-bg)}@media(min-width:1024px){.desktop-layout[data-v-27d3e745]{display:flex}}.desktop-content[data-v-27d3e745]{flex:1;margin-left:260px;display:flex;flex-direction:column;transition:margin-left .3s ease;min-height:100vh;background:var(--app-bg)}.desktop-sidebar.collapsed~.desktop-content[data-v-27d3e745]{margin-left:80px}.desktop-header[data-v-27d3e745]{background:transparent;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}.header-left[data-v-27d3e745]{flex:1}.page-title[data-v-27d3e745]{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.header-right[data-v-27d3e745]{display:flex;gap:12px;align-items:center}.desktop-main[data-v-27d3e745]{flex:1;padding:32px;overflow-y:auto}.desktop-main.no-padding[data-v-27d3e745]{padding:0}@media(min-width:1440px){.desktop-main[data-v-27d3e745]{padding:40px;max-width:1600px;margin:0 auto;width:100%}.desktop-main.no-padding[data-v-27d3e745]{padding:0;max-width:none}}.pwa-install-prompt[data-v-f899f9ea]{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-f899f9ea]{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:16px}.prompt-icon[data-v-f899f9ea]{font-size:36px;flex-shrink:0}.prompt-text[data-v-f899f9ea]{flex:1}.prompt-text h3[data-v-f899f9ea]{margin:0 0 4px;font-size:16px;font-weight:600}.prompt-text p[data-v-f899f9ea]{margin:0;font-size:13px;opacity:.95;line-height:1.4}.prompt-actions[data-v-f899f9ea]{display:flex;gap:12px;align-items:center;flex-shrink:0}.btn-install[data-v-f899f9ea]{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-f899f9ea]:hover{background:var(--bg-secondary);transform:translateY(-1px)}.btn-install[data-v-f899f9ea]:active{transform:translateY(0)}.btn-dismiss[data-v-f899f9ea]{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-f899f9ea]:hover{background:#ffffff4d}.slide-up-enter-active[data-v-f899f9ea],.slide-up-leave-active[data-v-f899f9ea]{transition:transform .3s ease-out}.slide-up-enter-from[data-v-f899f9ea],.slide-up-leave-to[data-v-f899f9ea]{transform:translateY(100%)}@media(max-width:768px){.pwa-install-prompt[data-v-f899f9ea]{padding:12px 16px}.prompt-content[data-v-f899f9ea]{flex-wrap:wrap;gap:12px}.prompt-icon[data-v-f899f9ea]{font-size:28px}.prompt-text h3[data-v-f899f9ea]{font-size:15px}.prompt-text p[data-v-f899f9ea]{font-size:12px}.prompt-actions[data-v-f899f9ea]{width:100%;justify-content:stretch}.btn-install[data-v-f899f9ea]{flex:1;padding:12px}}.ios-prompt[data-v-f899f9ea]{padding:20px}.ios-content[data-v-f899f9ea]{flex-direction:column;position:relative}.ios-close[data-v-f899f9ea]{position:absolute;top:-8px;right:-8px;background:#0000004d;padding:6px 10px}.ios-header[data-v-f899f9ea]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.ios-steps[data-v-f899f9ea]{display:flex;flex-direction:column;gap:12px;background:#ffffff1a;padding:16px;border-radius:8px}.ios-step[data-v-f899f9ea]{display:flex;align-items:center;gap:12px}.step-number[data-v-f899f9ea]{width:24px;height:24px;background:#ffffffe6;color:#1976d2;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.step-icon[data-v-f899f9ea]{width:32px;height:32px;background:#fff3;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.step-icon svg[data-v-f899f9ea]{stroke:currentColor;stroke-width:2;fill:none}.step-text[data-v-f899f9ea]{font-size:14px;line-height:1.4}.step-text strong[data-v-f899f9ea]{color:#fff}.floating-timer[data-v-0a295683]{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-0a295683]:active{transform:scale(.95)}.floating-timer[data-v-0a295683]:hover{box-shadow:0 12px 32px #667eea80;transform:translateY(-2px)}.timer-content[data-v-0a295683]{display:flex;align-items:center;gap:12px}.timer-icon[data-v-0a295683]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff3;border-radius:50%;position:relative}.pulse-dot[data-v-0a295683]{width:12px;height:12px;background:#ff4757;border-radius:50%;animation:pulse-0a295683 2s ease-in-out infinite}@keyframes pulse-0a295683{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.pause-icon[data-v-0a295683]{font-size:16px}.timer-info[data-v-0a295683]{flex:1}.timer-project[data-v-0a295683]{font-size:12px;font-weight:500;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.timer-time[data-v-0a295683]{font-size:18px;font-weight:700;font-family:Courier New,monospace;letter-spacing:1px}.timer-hint[data-v-0a295683]{margin-top:6px;font-size:10px;text-align:center;opacity:.7}.fade-slide-enter-active[data-v-0a295683],.fade-slide-leave-active[data-v-0a295683]{transition:all .3s cubic-bezier(.4,0,.2,1)}.fade-slide-enter-from[data-v-0a295683],.fade-slide-leave-to[data-v-0a295683]{opacity:0;transform:translateY(20px)}@media(min-width:769px){.floating-timer[data-v-0a295683]{bottom:24px;right:24px}}@media(max-width:360px){.floating-timer[data-v-0a295683]{min-width:180px;padding:10px 12px}.timer-time[data-v-0a295683]{font-size:16px}.timer-project[data-v-0a295683]{font-size:11px;max-width:110px}}.subscription-banner[data-v-f34d0767]{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;padding:12px 16px;box-shadow:0 4px 12px #dc262666}.banner-content[data-v-f34d0767]{display:flex;align-items:center;justify-content:center;gap:12px;max-width:1200px;margin:0 auto;flex-wrap:wrap}.banner-icon[data-v-f34d0767]{font-size:20px}.banner-message[data-v-f34d0767]{font-weight:500;font-size:14px;text-align:center}.banner-btn[data-v-f34d0767]{background:#fff;color:#dc2626;border:none;padding:8px 16px;border-radius:6px;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.banner-btn[data-v-f34d0767]:hover{background:#fef2f2;transform:translateY(-1px)}.slide-enter-active[data-v-f34d0767],.slide-leave-active[data-v-f34d0767]{transition:transform .3s ease,opacity .3s ease}.slide-enter-from[data-v-f34d0767],.slide-leave-to[data-v-f34d0767]{transform:translateY(-100%);opacity:0}@media(max-width:768px){.subscription-banner[data-v-f34d0767]{padding:10px 12px}.banner-content[data-v-f34d0767]{flex-direction:column;gap:8px}.banner-message[data-v-f34d0767]{font-size:13px}.banner-btn[data-v-f34d0767]{width:100%;padding:10px 16px}}.notification-banner[data-v-b143cb8d]{position:fixed;bottom:70px;left:16px;right:16px;background:linear-gradient(135deg,#10b981,#059669);color:var(--color-white);padding:16px 20px;border-radius:12px;box-shadow:0 4px 20px #10b98166;z-index:9998}@media(min-width:769px){.notification-banner[data-v-b143cb8d]{bottom:24px;left:auto;right:24px;max-width:420px}}.banner-content[data-v-b143cb8d]{display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px}.banner-icon[data-v-b143cb8d]{font-size:32px;flex-shrink:0;line-height:1}.banner-text[data-v-b143cb8d]{flex:1;min-width:200px}.banner-text h3[data-v-b143cb8d]{margin:0 0 4px;font-size:16px;font-weight:600}.banner-text p[data-v-b143cb8d]{margin:0;font-size:13px;opacity:.95;line-height:1.4}.banner-actions[data-v-b143cb8d]{display:flex;gap:8px;align-items:center;flex-shrink:0;width:100%;margin-top:8px}@media(min-width:769px){.banner-actions[data-v-b143cb8d]{width:auto;margin-top:0}}.btn-activate[data-v-b143cb8d],.btn-settings[data-v-b143cb8d]{flex:1;padding:10px 16px;background:var(--card-bg);color:#059669;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-activate[data-v-b143cb8d]:hover:not(:disabled),.btn-settings[data-v-b143cb8d]:hover{background:var(--bg-secondary);transform:translateY(-1px)}.btn-activate[data-v-b143cb8d]:disabled{opacity:.7;cursor:not-allowed}.btn-dismiss[data-v-b143cb8d]{padding:10px 16px;background:#fff3;color:var(--color-white);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-dismiss[data-v-b143cb8d]:hover{background:#ffffff4d}.slide-up-enter-active[data-v-b143cb8d],.slide-up-leave-active[data-v-b143cb8d]{transition:all .3s ease-out}.slide-up-enter-from[data-v-b143cb8d],.slide-up-leave-to[data-v-b143cb8d]{transform:translateY(100%);opacity:0}#app{min-height:100vh}:root{--color-primary: #3b82f6;--color-primary-light: #60a5fa;--color-primary-dark: #2563eb;--color-primary-darker: #1d4ed8;--primary-color: var(--color-primary);--primary-dark: var(--color-primary-dark);--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-tertiary: var(--color-text-tertiary);--color-text-muted: var(--color-text-tertiary);--success-color: var(--color-success);--danger-color: var(--color-danger);--color-error: var(--color-danger);--warning-color: var(--color-warning);--info-color: var(--color-info);--secondary-color: var(--color-secondary);--hover-bg: var(--bg-tertiary);--shadow: var(--shadow-md);--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-accent-purple: #8b5cf6;--color-accent-purple-light: #a78bfa;--color-accent-purple-dark: #7c3aed;--color-accent-purple-bg: #ede9fe;--color-accent-purple-bg-strong: #e9d5ff;--color-accent-purple-text: #6b21a8;--color-accent-purple-muted: #7c3aed;--color-accent-indigo: #6366f1;--color-accent-indigo-light: #818cf8;--color-accent-indigo-dark: #4f46e5;--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: #374151;--color-text-tertiary: #4b5563;--color-text-inverse: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-secondary-alt: var(--bg-secondary);--bg-tertiary: #f3f4f6;--bg-quaternary: var(--bg-tertiary);--bg-dark: #111827;--bg-overlay: rgba(0, 0, 0, .5);--bg-overlay-strong: rgba(0, 0, 0, .6);--app-bg: var(--bg-secondary);--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: "IBM Plex Sans", "Helvetica Neue", sans-serif;--font-display: "Space Grotesk", "IBM Plex Sans", sans-serif;--font-mono: "JetBrains 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;--btn-min-height: 2.5rem;--btn-min-height-touch: 2.75rem;--btn-icon-size: 2.5rem;--btn-icon-size-touch: 2.75rem;--input-height-sm: 2rem;--input-height-md: 2.5rem;--input-height-lg: 3rem;--input-bg: #ffffff;--input-text: var(--color-text-primary);--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);--status-info-bg: #dbeafe;--status-info-text: #1e40af;--status-info-border: #3b82f6;--color-primary-alpha-10: rgba(59, 130, 246, .1);--color-primary-alpha-20: rgba(59, 130, 246, .2);--color-primary-alpha-30: rgba(59, 130, 246, .3);--color-success-alpha-05: rgba(16, 185, 129, .05);--color-success-alpha-10: rgba(16, 185, 129, .1);--color-success-alpha-20: rgba(16, 185, 129, .2);--color-success-alpha-30: rgba(16, 185, 129, .3);--color-success-alpha-40: rgba(16, 185, 129, .4);--color-warning-alpha-10: rgba(245, 158, 11, .1);--color-warning-alpha-20: rgba(245, 158, 11, .2);--color-warning-alpha-30: rgba(245, 158, 11, .3);--color-warning-alpha-40: rgba(245, 158, 11, .4);--color-warning-alpha-60: rgba(245, 158, 11, .6);--color-danger-alpha-10: rgba(239, 68, 68, .1);--color-accent-purple-alpha-10: rgba(139, 92, 246, .1);--color-accent-purple-alpha-30: rgba(139, 92, 246, .3);--color-accent-purple-alpha-40: rgba(139, 92, 246, .4);--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-05: rgba(0, 0, 0, .05);--color-black-alpha-10: rgba(0, 0, 0, .1);--color-black-alpha-15: rgba(0, 0, 0, .15);--color-black-alpha-25: rgba(0, 0, 0, .25);--color-black-alpha-30: rgba(0, 0, 0, .3);--color-black-alpha-50: rgba(0, 0, 0, .5);--color-danger-alpha-05: rgba(239, 68, 68, .05);--modal-overlay-bg: rgba(0, 0, 0, .5);--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-danger: linear-gradient(135deg, var(--color-danger) 0%, var(--color-danger-dark) 100%);--gradient-accent-purple: linear-gradient(135deg, var(--color-accent-purple) 0%, var(--color-accent-purple-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);--calendar-header-bg: var(--bg-tertiary);--calendar-header-text: var(--color-primary-dark);--calendar-day-bg: var(--card-bg);--calendar-day-border: var(--border-color);--calendar-day-empty-bg: var(--bg-secondary);--calendar-day-today-bg: var(--color-warning-bg);--calendar-day-today-border: var(--color-warning);--calendar-day-today-text: var(--color-warning-dark);--calendar-day-holiday-bg: var(--color-success-bg);--calendar-day-holiday-border: var(--color-success);--calendar-day-holiday-text: var(--color-success-dark);--calendar-holiday-indicator-bg: var(--color-success-alpha-10);--calendar-holiday-indicator-text: var(--color-success);--calendar-absence-pill-bg: var(--gradient-warning);--calendar-absence-pill-text: var(--color-text-inverse);--calendar-absence-pill-border: var(--color-warning);--calendar-absence-badge-bg: var(--color-black-alpha-15);--calendar-absence-external-bg: var(--gradient-success);--calendar-absence-external-text: var(--color-success-dark);--calendar-absence-external-border: var(--color-success);--calendar-assignment-text: var(--color-text-primary);--calendar-assignment-subtext: var(--color-text-secondary);--calendar-assignment-accent: var(--color-warning-dark);--calendar-assignment-shadow: var(--color-black-alpha-15);--calendar-conflict-bg: var(--color-warning-bg);--calendar-conflict-border: var(--color-warning);--calendar-conflict-text: var(--color-warning-dark);--calendar-absence-block-bg: var(--color-warning-bg);--calendar-absence-block-border: var(--color-warning);--calendar-absence-type-vacation-bg: var(--gradient-primary);--calendar-absence-type-vacation-text: var(--color-text-inverse);--calendar-absence-type-sick-bg: var(--gradient-danger);--calendar-absence-type-sick-text: var(--color-text-inverse);--calendar-grid-bg: var(--border-color-light);--calendar-grid-border: var(--border-color);--calendar-btn-icon-border: var(--border-color);--calendar-btn-icon-hover-bg: var(--bg-tertiary);--calendar-btn-icon-hover-border: var(--color-primary);--appointment-montage-color: #1565c0;--appointment-montage-bg: #bbdefb;--appointment-aufmass-color: #7b1fa2;--appointment-aufmass-bg: #e1bee7;--appointment-reparatur-color: #e65100;--appointment-reparatur-bg: #ffe0b2;--appointment-wartung-color: #455a64;--appointment-wartung-bg: #cfd8dc;--appointment-beratung-color: #00838f;--appointment-beratung-bg: #b2ebf2;--appointment-lieferung-color: #4e342e;--appointment-lieferung-bg: #d7ccc8;--appointment-privat-color: #ad1457;--appointment-privat-bg: #f8bbd9;--appointment-sonstiges-color: #616161;--appointment-sonstiges-bg: #e0e0e0;--nav-google-bg: linear-gradient(135deg, #4285f4 0%, #357ae8 100%);--nav-google-bg-hover: linear-gradient(135deg, #357ae8 0%, #2a65c9 100%);--nav-google-border: #357ae8;--nav-google-shadow: rgba(66, 133, 244, .3);--nav-apple-bg: linear-gradient(135deg, #555555 0%, #333333 100%);--nav-apple-bg-hover: linear-gradient(135deg, #333333 0%, #1a1a1a 100%);--nav-apple-border: #333333;--nav-apple-shadow: rgba(0, 0, 0, .3)}:root.dark{--bg-primary: #1f2937;--bg-secondary: #111827;--bg-tertiary: #374151;--bg-dark: #000000;--bg-overlay: rgba(0, 0, 0, .75);--bg-overlay-strong: rgba(0, 0, 0, .85);--color-text-primary: #f9fafb;--color-text-secondary: #e5e7eb;--color-text-tertiary: #cbd5e1;--color-text-inverse: #111827;--primary-color: var(--color-primary);--primary-dark: var(--color-primary-dark);--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-tertiary: var(--color-text-tertiary);--success-color: var(--color-success);--danger-color: var(--color-danger);--warning-color: var(--color-warning);--info-color: var(--color-info);--secondary-color: var(--color-secondary);--hover-bg: var(--bg-tertiary);--shadow: var(--shadow-md);--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;--status-info-bg: rgba(59, 130, 246, .2);--status-info-text: #93c5fd;--status-info-border: #3b82f6;--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-accent-purple: #a78bfa;--color-accent-purple-light: #c4b5fd;--color-accent-purple-dark: #8b5cf6;--color-accent-purple-bg: rgba(139, 92, 246, .18);--color-accent-purple-bg-strong: rgba(139, 92, 246, .28);--color-accent-purple-text: #c4b5fd;--color-accent-purple-muted: #a78bfa;--color-accent-indigo: #818cf8;--color-accent-indigo-light: #a5b4fc;--color-accent-indigo-dark: #6366f1;--color-primary-alpha-10: rgba(96, 165, 250, .15);--color-primary-alpha-20: rgba(96, 165, 250, .2);--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);--input-bg: #374151;--input-text: #f9fafb;--input-border: 2px solid #4b5563;--input-border-focus: 2px solid var(--color-primary-light);--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);--calendar-header-bg: #1e3a5f;--calendar-header-text: #60a5fa;--calendar-day-bg: var(--card-bg);--calendar-day-border: #374151;--calendar-day-empty-bg: #1f2937;--calendar-day-today-bg: #422006;--calendar-day-today-border: #f59e0b;--calendar-day-today-text: #fbbf24;--calendar-day-holiday-bg: rgba(34, 197, 94, .15);--calendar-day-holiday-border: #22c55e;--calendar-day-holiday-text: #4ade80;--calendar-holiday-indicator-bg: rgba(34, 197, 94, .2);--calendar-holiday-indicator-text: #4ade80;--calendar-absence-pill-bg: linear-gradient(135deg, #78350f 0%, #92400e 100%);--calendar-absence-pill-text: #fef3c7;--calendar-absence-pill-border: #fbbf24;--calendar-absence-badge-bg: var(--color-white-alpha-20);--calendar-absence-external-bg: var(--gradient-success);--calendar-absence-external-text: var(--color-text-primary);--calendar-absence-external-border: var(--color-success);--calendar-assignment-text: #f3f4f6;--calendar-assignment-subtext: #e5e7eb;--calendar-assignment-accent: #fbbf24;--calendar-assignment-shadow: var(--color-black-alpha-30);--calendar-conflict-bg: #422006;--calendar-conflict-border: #fbbf24;--calendar-conflict-text: #fef3c7;--calendar-absence-block-bg: #422006;--calendar-absence-block-border: #f59e0b;--calendar-absence-type-vacation-bg: linear-gradient(135deg, #1e3a5f 0%, #1e40af 100%);--calendar-absence-type-vacation-text: #93c5fd;--calendar-absence-type-sick-bg: linear-gradient(135deg, #450a0a 0%, #7f1d1d 100%);--calendar-absence-type-sick-text: #fca5a5;--calendar-grid-bg: #374151;--calendar-grid-border: #374151;--calendar-btn-icon-border: #4b5563;--calendar-btn-icon-hover-bg: #374151;--calendar-btn-icon-hover-border: var(--color-primary);--appointment-montage-color: #1565c0;--appointment-montage-bg: rgba(33, 150, 243, .25);--appointment-aufmass-color: #7b1fa2;--appointment-aufmass-bg: rgba(156, 39, 176, .25);--appointment-reparatur-color: #e65100;--appointment-reparatur-bg: rgba(255, 152, 0, .25);--appointment-wartung-color: #455a64;--appointment-wartung-bg: rgba(96, 125, 139, .25);--appointment-beratung-color: #00838f;--appointment-beratung-bg: rgba(0, 188, 212, .25);--appointment-lieferung-color: #4e342e;--appointment-lieferung-bg: rgba(121, 85, 72, .25);--appointment-privat-color: #ad1457;--appointment-privat-bg: rgba(233, 30, 99, .25);--appointment-sonstiges-color: #616161;--appointment-sonstiges-bg: rgba(158, 158, 158, .25);--nav-google-bg: linear-gradient(135deg, #3b6fe0 0%, #2b59c7 100%);--nav-google-bg-hover: linear-gradient(135deg, #2b59c7 0%, #1f47a5 100%);--nav-google-border: #2b59c7;--nav-google-shadow: rgba(30, 64, 175, .35);--nav-apple-bg: linear-gradient(135deg, #4b5563 0%, #1f2937 100%);--nav-apple-bg-hover: linear-gradient(135deg, #374151 0%, #111827 100%);--nav-apple-border: #1f2937;--nav-apple-shadow: rgba(0, 0, 0, .5);--color-black-alpha-05: rgba(0, 0, 0, .15);--color-black-alpha-25: rgba(0, 0, 0, .45);--color-black-alpha-50: rgba(0, 0, 0, .65);--color-danger-alpha-05: rgba(239, 68, 68, .1);--modal-overlay-bg: rgba(0, 0, 0, .7);--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)}:root[data-theme=industrial]{--font-sans: "IBM Plex Sans", sans-serif;--font-display: "Space Grotesk", sans-serif;--color-primary: #0f4c81;--color-primary-light: #2a6bb3;--color-primary-dark: #0b3a63;--color-primary-darker: #09294b;--color-primary-alpha-10: rgba(15, 76, 129, .1);--color-primary-alpha-20: rgba(15, 76, 129, .2);--color-primary-alpha-30: rgba(15, 76, 129, .3);--color-secondary: #f97316;--color-secondary-light: #fb923c;--color-secondary-dark: #c2410c;--bg-primary: #ffffff;--bg-secondary: #f4f7fb;--bg-tertiary: #e7edf4;--border-color: #d5dee8;--border-color-light: #e7edf5;--border-color-dark: #bcc7d6;--card-bg: #ffffff;--gradient-brand: linear-gradient(135deg, #0f4c81 0%, #0b3a63 100%);--header-bg: linear-gradient(135deg, #0f4c81 0%, #0b3a63 55%, #111827 100%);--header-text-color: #ffffff;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #0f4c81 0%, #0b3a63 60%, #1f2937 100%);--app-bg: radial-gradient(circle at 12% 12%, rgba(15, 76, 129, .14) 0%, rgba(15, 76, 129, 0) 55%), linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%)}:root.dark[data-theme=industrial]{--color-primary: #4f8cc9;--color-primary-light: #7ab0e0;--color-primary-dark: #2f5f91;--color-primary-darker: #24466b;--color-primary-alpha-10: rgba(79, 140, 201, .2);--color-primary-alpha-20: rgba(79, 140, 201, .3);--color-primary-alpha-30: rgba(79, 140, 201, .4);--color-secondary: #fb923c;--color-secondary-light: #fdba74;--color-secondary-dark: #f97316;--bg-primary: #111827;--bg-secondary: #0b1220;--bg-tertiary: #111c2f;--border-color: #1f2a3d;--border-color-light: #273447;--border-color-dark: #0f172a;--card-bg: #0f172a;--gradient-brand: linear-gradient(135deg, #0b3a63 0%, #0f172a 100%);--header-bg: linear-gradient(135deg, #0f4c81 0%, #0b3a63 55%, #0f172a 100%);--header-text-color: #f8fafc;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #0b3a63 0%, #0f172a 100%);--app-bg: radial-gradient(circle at 18% 10%, rgba(79, 140, 201, .25) 0%, rgba(79, 140, 201, 0) 55%), linear-gradient(180deg, #0b1220 0%, #0f172a 100%)}:root[data-theme=blueprint]{--font-sans: "Sora", sans-serif;--font-display: "Source Serif 4", serif;--color-primary: #1e3a8a;--color-primary-light: #2563eb;--color-primary-dark: #172554;--color-primary-darker: #0f172a;--color-primary-alpha-10: rgba(30, 58, 138, .1);--color-primary-alpha-20: rgba(30, 58, 138, .2);--color-primary-alpha-30: rgba(30, 58, 138, .3);--color-secondary: #38bdf8;--color-secondary-light: #7dd3fc;--color-secondary-dark: #0ea5e9;--bg-primary: #ffffff;--bg-secondary: #f7f9ff;--bg-tertiary: #e9effc;--border-color: #d2dbea;--border-color-light: #e5ebf7;--border-color-dark: #b8c6dc;--card-bg: #ffffff;--gradient-brand: linear-gradient(135deg, #1e3a8a 0%, #172554 100%);--header-bg: linear-gradient(135deg, #1e3a8a 0%, #172554 60%, #0f172a 100%);--header-text-color: #ffffff;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #1e3a8a 0%, #172554 60%, #0f172a 100%);--app-bg: repeating-linear-gradient(0deg, rgba(30, 58, 138, .06) 0, rgba(30, 58, 138, .06) 1px, transparent 1px, transparent 28px), repeating-linear-gradient(90deg, rgba(30, 58, 138, .06) 0, rgba(30, 58, 138, .06) 1px, transparent 1px, transparent 28px), linear-gradient(180deg, #f7f9ff 0%, #e6eefc 100%)}:root.dark[data-theme=blueprint]{--color-primary: #5b7cdd;--color-primary-light: #8aa2f0;--color-primary-dark: #3a5ec2;--color-primary-darker: #243b83;--color-primary-alpha-10: rgba(91, 124, 221, .2);--color-primary-alpha-20: rgba(91, 124, 221, .3);--color-primary-alpha-30: rgba(91, 124, 221, .4);--color-secondary: #38bdf8;--color-secondary-light: #7dd3fc;--color-secondary-dark: #0ea5e9;--bg-primary: #0f172a;--bg-secondary: #0b1124;--bg-tertiary: #111a35;--border-color: #1b2541;--border-color-light: #24304f;--border-color-dark: #0b1020;--card-bg: #0f172a;--gradient-brand: linear-gradient(135deg, #172554 0%, #0f172a 100%);--header-bg: linear-gradient(135deg, #1e3a8a 0%, #172554 60%, #0f172a 100%);--header-text-color: #f8fafc;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #172554 0%, #0f172a 100%);--app-bg: repeating-linear-gradient(0deg, rgba(91, 124, 221, .12) 0, rgba(91, 124, 221, .12) 1px, transparent 1px, transparent 28px), repeating-linear-gradient(90deg, rgba(91, 124, 221, .12) 0, rgba(91, 124, 221, .12) 1px, transparent 1px, transparent 28px), linear-gradient(180deg, #0b1124 0%, #0f172a 100%)}:root[data-theme=craftsman]{--font-sans: "Manrope", sans-serif;--font-display: "Fraunces", serif;--color-primary: #9a3412;--color-primary-light: #c2410c;--color-primary-dark: #7c2d12;--color-primary-darker: #5a1f0e;--color-primary-alpha-10: rgba(154, 52, 18, .1);--color-primary-alpha-20: rgba(154, 52, 18, .2);--color-primary-alpha-30: rgba(154, 52, 18, .3);--color-secondary: #3f6212;--color-secondary-light: #65a30d;--color-secondary-dark: #365314;--bg-primary: #fffdf9;--bg-secondary: #fdf4ea;--bg-tertiary: #f4e7da;--border-color: #e7d5c0;--border-color-light: #f1e2d1;--border-color-dark: #d6c2aa;--card-bg: #fffdf9;--gradient-brand: linear-gradient(135deg, #9a3412 0%, #7c2d12 100%);--header-bg: linear-gradient(135deg, #9a3412 0%, #7c2d12 60%, #3f2a1e 100%);--header-text-color: #ffffff;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #9a3412 0%, #7c2d12 60%, #3f2a1e 100%);--app-bg: radial-gradient(circle at 15% 12%, rgba(249, 115, 22, .16) 0%, rgba(249, 115, 22, 0) 55%), linear-gradient(180deg, #fff8f0 0%, #f7e9da 100%)}:root.dark[data-theme=craftsman]{--color-primary: #f97316;--color-primary-light: #fb923c;--color-primary-dark: #ea580c;--color-primary-darker: #c2410c;--color-primary-alpha-10: rgba(249, 115, 22, .2);--color-primary-alpha-20: rgba(249, 115, 22, .3);--color-primary-alpha-30: rgba(249, 115, 22, .4);--color-secondary: #84cc16;--color-secondary-light: #a3e635;--color-secondary-dark: #65a30d;--bg-primary: #17120d;--bg-secondary: #110d0a;--bg-tertiary: #21180f;--border-color: #2a1f15;--border-color-light: #36281b;--border-color-dark: #120d08;--card-bg: #17120d;--gradient-brand: linear-gradient(135deg, #7c2d12 0%, #3f2a1e 100%);--header-bg: linear-gradient(135deg, #9a3412 0%, #7c2d12 60%, #2a1f15 100%);--header-text-color: #fef3c7;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #7c2d12 0%, #2a1f15 100%);--app-bg: radial-gradient(circle at 12% 10%, rgba(249, 115, 22, .22) 0%, rgba(249, 115, 22, 0) 55%), linear-gradient(180deg, #110d0a 0%, #17120d 100%)}:root[data-theme=modern]{--font-sans: "Plus Jakarta Sans", sans-serif;--font-display: "Sora", sans-serif;--color-primary: #0ea5e9;--color-primary-light: #38bdf8;--color-primary-dark: #0284c7;--color-primary-darker: #0369a1;--color-primary-alpha-10: rgba(14, 165, 233, .1);--color-primary-alpha-20: rgba(14, 165, 233, .2);--color-primary-alpha-30: rgba(14, 165, 233, .3);--color-secondary: #14b8a6;--color-secondary-light: #5eead4;--color-secondary-dark: #0f766e;--bg-primary: #ffffff;--bg-secondary: #f7fafc;--bg-tertiary: #ecf2f8;--border-color: #d7e3ef;--border-color-light: #e6eef6;--border-color-dark: #c3d3e6;--card-bg: #ffffff;--gradient-brand: linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);--header-bg: linear-gradient(135deg, #0ea5e9 0%, #0284c7 60%, #0f766e 100%);--header-text-color: #ffffff;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #0ea5e9 0%, #0284c7 60%, #0f766e 100%);--app-bg: radial-gradient(circle at 82% 18%, rgba(14, 165, 233, .18) 0%, rgba(14, 165, 233, 0) 55%), radial-gradient(circle at 20% 80%, rgba(20, 184, 166, .14) 0%, rgba(20, 184, 166, 0) 55%), linear-gradient(180deg, #f8fafc 0%, #eef5fb 100%)}:root.dark[data-theme=modern]{--color-primary: #38bdf8;--color-primary-light: #7dd3fc;--color-primary-dark: #0ea5e9;--color-primary-darker: #0284c7;--color-primary-alpha-10: rgba(56, 189, 248, .2);--color-primary-alpha-20: rgba(56, 189, 248, .3);--color-primary-alpha-30: rgba(56, 189, 248, .4);--color-secondary: #5eead4;--color-secondary-light: #99f6e4;--color-secondary-dark: #2dd4bf;--bg-primary: #0b1220;--bg-secondary: #0a0f1a;--bg-tertiary: #121a2a;--border-color: #1d2535;--border-color-light: #273145;--border-color-dark: #0b1020;--card-bg: #0b1220;--gradient-brand: linear-gradient(135deg, #0284c7 0%, #0f172a 100%);--header-bg: linear-gradient(135deg, #0ea5e9 0%, #0284c7 60%, #0f172a 100%);--header-text-color: #f8fafc;--navbar-bg: var(--gradient-brand);--sidebar-bg: var(--gradient-brand);--auth-page-bg: linear-gradient(135deg, #0284c7 0%, #0f172a 100%);--app-bg: radial-gradient(circle at 75% 15%, rgba(56, 189, 248, .25) 0%, rgba(56, 189, 248, 0) 55%), radial-gradient(circle at 18% 82%, rgba(20, 184, 166, .2) 0%, rgba(20, 184, 166, 0) 55%), linear-gradient(180deg, #0a0f1a 0%, #0b1220 100%)}.btn,.btn-primary,.btn-info,.btn-secondary,.btn-success,.btn-warning,.btn-danger,.btn-outline,.btn-ghost{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;min-height:var(--btn-min-height)}.btn:disabled,.btn-primary:disabled,.btn-info:disabled,.btn-secondary:disabled,.btn-success:disabled,.btn-warning:disabled,.btn-danger:disabled,.btn-outline:disabled,.btn-ghost: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:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-info{background-color:var(--color-info);color:var(--color-text-inverse)}.btn-info:hover:not(:disabled){background-color:var(--color-info-dark)}.btn:active:not(:disabled),.btn-primary:active:not(:disabled),.btn-info:active:not(:disabled),.btn-secondary:active:not(:disabled),.btn-success:active:not(:disabled),.btn-warning:active:not(:disabled),.btn-danger:active:not(:disabled),.btn-outline:active:not(:disabled),.btn-ghost:active:not(:disabled){transform:translateY(0)}.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:var(--color-text-inverse)}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark)}.btn-warning{background-color:var(--color-warning);color:var(--color-text-inverse)}.btn-warning:hover:not(:disabled){background-color:var(--color-warning-dark)}.btn-danger{background-color:var(--color-danger);color:var(--color-text-inverse)}.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:var(--color-text-inverse)}.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)}.btn:focus-visible,.btn-primary:focus-visible,.btn-info:focus-visible,.btn-secondary:focus-visible,.btn-success:focus-visible,.btn-warning:focus-visible,.btn-danger:focus-visible,.btn-outline:focus-visible,.btn-ghost:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-icon{display:inline-flex;align-items:center;gap:var(--spacing-xs)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn),.btn-close,.close-btn){width:var(--btn-icon-size);height:var(--btn-icon-size);min-width:var(--btn-icon-size);min-height:var(--btn-icon-size);padding:0;border:none;border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;transition:all var(--transition-base)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)):hover:not(:disabled),.btn-close:hover:not(:disabled),.close-btn:hover:not(:disabled){background:var(--color-gray-200);color:var(--color-text-primary)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)):active:not(:disabled),.btn-close:active:not(:disabled),.close-btn:active:not(:disabled){background:var(--color-gray-300)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)):focus-visible,.btn-close:focus-visible,.close-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-danger,.btn-close.btn-danger,.close-btn.btn-danger{color:var(--color-danger)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-danger:hover:not(:disabled),.btn-close.btn-danger:hover:not(:disabled),.close-btn.btn-danger:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-primary,:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-secondary,:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-success,:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-warning,:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-info{background:var(--bg-tertiary)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-primary{background:var(--color-primary-alpha-10);color:var(--color-primary)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-secondary{background:var(--color-gray-100);color:var(--color-text-primary)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-success{background:var(--color-success-bg);color:var(--color-success-dark)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-warning{background:var(--color-warning-bg);color:var(--color-warning-dark)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-info{background:var(--color-info-bg);color:var(--color-info-dark)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-primary:hover:not(:disabled),:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-secondary:hover:not(:disabled),:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-success:hover:not(:disabled),:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-warning:hover:not(:disabled),:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)).btn-info:hover:not(:disabled){filter:brightness(.98)}@media(pointer:coarse){.btn,.btn-primary,.btn-info,.btn-secondary,.btn-success,.btn-warning,.btn-danger,.btn-outline,.btn-ghost{min-height:var(--btn-min-height-touch)}:is(button.btn-icon:not(.btn),a.btn-icon:not(.btn),.btn-icon[role=button]:not(.btn)),.btn-close,.close-btn{width:var(--btn-icon-size-touch);height:var(--btn-icon-size-touch);min-width:var(--btn-icon-size-touch);min-height:var(--btn-icon-size-touch)}}.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,input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],input[type=datetime-local],input[type=tel],input[type=url],input[type=search],select,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(--input-text, var(--color-text-primary));background-color:var(--input-bg, var(--bg-primary));transition:border-color var(--transition-fast);color-scheme:light dark}select,.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:2.5rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;cursor:pointer}:root.dark select,:root.dark .form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23d1d5db' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.form-input:focus,.form-select:focus,.form-textarea:focus,input:focus,select:focus,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}html{height:100%;height:-webkit-fill-available}body{font-family:var(--font-sans);background:var(--app-bg, var(--bg-secondary));color:var(--color-text-primary);line-height:var(--line-height-normal);overflow-x:hidden;width:100%;min-height:100%;min-height:-webkit-fill-available;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none}@supports (-webkit-touch-callout: none){html,body,#app{position:fixed;width:100%;height:100%;overflow:hidden}}#app{min-height:100vh;min-height:100dvh;overflow-x:hidden;width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);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)}select,.filter-select,.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:36px!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right 10px center!important;background-size:16px!important;cursor:pointer}:root.dark select,:root.dark .filter-select,:root.dark .form-select,.dark-mode select,.dark-mode .filter-select,.dark-mode .form-select{background-color:var(--input-bg, #374151)!important;color:var(--input-text, #f9fafb)!important;border-color:var(--border-color, #4b5563)!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23d1d5db' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")!important}:root.dark select option,.dark-mode select option{background-color:#374151;color:#f9fafb}::-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}}
