.modal-overlay[data-v-563d3c33]{position:fixed;inset:0;background-color:var(--modal-overlay-bg);-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-563d3c33]{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px var(--color-black-alpha-30);max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-small[data-v-563d3c33]{width:400px}.modal-medium[data-v-563d3c33]{width:600px}.modal-large[data-v-563d3c33]{width:900px}.modal-header[data-v-563d3c33]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-title-wrapper[data-v-563d3c33]{display:flex;align-items:center;gap:.75rem}.modal-icon[data-v-563d3c33]{font-size:1.5rem;line-height:1}.modal-title[data-v-563d3c33]{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-563d3c33]{background:none;border:none;font-size:1.5rem;color:var(--color-gray-500);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-563d3c33]:hover{color:var(--color-text-primary);background-color:var(--bg-tertiary)}.modal-body[data-v-563d3c33]{padding:1.5rem;overflow-y:auto;flex:1}.modal-body p[data-v-563d3c33]{margin:0;color:var(--color-text-tertiary);line-height:1.6}.modal-footer[data-v-563d3c33]{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.modal-danger .modal-icon[data-v-563d3c33],.modal-danger .modal-title[data-v-563d3c33]{color:var(--color-danger-dark)}.modal-warning .modal-icon[data-v-563d3c33],.modal-warning .modal-title[data-v-563d3c33]{color:var(--color-warning)}.modal-success .modal-icon[data-v-563d3c33],.modal-success .modal-title[data-v-563d3c33]{color:var(--color-success)}.modal-info .modal-icon[data-v-563d3c33],.modal-info .modal-title[data-v-563d3c33]{color:var(--color-primary)}.spinner[data-v-563d3c33]{width:1rem;height:1rem;border:2px solid var(--color-white-alpha-30);border-top-color:var(--color-white);border-radius:50%;animation:spin-563d3c33 .6s linear infinite}@keyframes spin-563d3c33{to{transform:rotate(360deg)}}.modal-enter-active[data-v-563d3c33],.modal-leave-active[data-v-563d3c33]{transition:opacity .3s ease}.modal-enter-active .modal-container[data-v-563d3c33],.modal-leave-active .modal-container[data-v-563d3c33]{transition:transform .3s ease}.modal-enter-from[data-v-563d3c33],.modal-leave-to[data-v-563d3c33]{opacity:0}.modal-enter-from .modal-container[data-v-563d3c33],.modal-leave-to .modal-container[data-v-563d3c33]{transform:scale(.9)}@media(max-width:640px){.modal-small[data-v-563d3c33],.modal-medium[data-v-563d3c33],.modal-large[data-v-563d3c33]{width:100%;max-width:100%}.modal-container[data-v-563d3c33]{border-radius:12px 12px 0 0;align-self:flex-end;max-height:85vh}}.brand-logo[data-v-e3bdeb77]{display:flex;flex-direction:column;align-items:center;gap:6px;line-height:1}.brand-mark[data-v-e3bdeb77]{display:block;max-width:100%;height:auto}.brand-text[data-v-e3bdeb77]{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-e3bdeb77]{width:48px}.brand-sm .brand-text[data-v-e3bdeb77]{font-size:11px}.brand-md .brand-mark[data-v-e3bdeb77]{width:72px}.brand-md .brand-text[data-v-e3bdeb77]{font-size:12px}.brand-lg .brand-mark[data-v-e3bdeb77]{width:110px}.brand-lg .brand-text[data-v-e3bdeb77]{font-size:14px}.modal-overlay[data-v-f3290159]{position:fixed;inset:0;background:var(--modal-overlay-bg);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn-f3290159 .2s ease}@keyframes fadeIn-f3290159{0%{opacity:0}to{opacity:1}}.modal-content[data-v-f3290159]{background:var(--card-bg);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px var(--color-black-alpha-10);animation:slideUp-f3290159 .3s ease}@keyframes slideUp-f3290159{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header[data-v-f3290159]{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.modal-header h2[data-v-f3290159]{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.btn-close[data-v-f3290159]{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-f3290159]:hover{color:var(--color-text-primary)}.modal-body[data-v-f3290159]{padding:24px}.intro-text[data-v-f3290159]{margin:0 0 24px;font-size:14px;color:var(--color-text-secondary);line-height:1.6}.form-group[data-v-f3290159]{margin-bottom:20px}.form-group label[data-v-f3290159]{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.form-group select[data-v-f3290159],.form-group input[data-v-f3290159],.form-group textarea[data-v-f3290159]{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-f3290159]{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-f3290159],.dark-mode .form-group select[data-v-f3290159]{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-f3290159]:focus,.form-group input[data-v-f3290159]:focus,.form-group textarea[data-v-f3290159]:focus{outline:none;border-color:var(--color-primary)}.form-group textarea[data-v-f3290159]{resize:vertical;min-height:120px}.char-count[data-v-f3290159]{text-align:right;font-size:12px;color:var(--color-text-secondary);margin-top:4px}.tips-box[data-v-f3290159]{padding:16px;background:var(--bg-secondary);border-left:4px solid var(--color-primary);border-radius:6px;margin-bottom:20px}.tips-title[data-v-f3290159]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.tips-box ul[data-v-f3290159]{margin:0;padding-left:20px;font-size:13px;color:var(--color-text-secondary)}.tips-box li[data-v-f3290159]{margin-bottom:4px;line-height:1.5}.error-message[data-v-f3290159]{padding:12px;background:var(--color-danger-bg);color:var(--color-danger-dark);border-radius:6px;margin-bottom:16px;font-size:14px}.modal-footer[data-v-f3290159]{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-f3290159]{max-height:95vh}.modal-header[data-v-f3290159],.modal-body[data-v-f3290159]{padding:16px}.modal-header h2[data-v-f3290159]{font-size:20px}.modal-footer[data-v-f3290159]{flex-direction:column-reverse}.btn-primary[data-v-f3290159],.btn-secondary[data-v-f3290159]{width:100%}}.impersonation-banner[data-v-b5044578]{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-b5044578]{display:flex;align-items:center;gap:8px}.impersonation-text strong[data-v-b5044578]{font-weight:600}.impersonation-text .org-name[data-v-b5044578]{opacity:.9}.return-btn[data-v-b5044578]{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-b5044578]:hover{background:var(--color-white-alpha-30);border-color:var(--color-white-alpha-60)}.navbar[data-v-b5044578]{background:var(--navbar-bg);color:var(--color-white);box-shadow:var(--shadow-md)}.navbar-container[data-v-b5044578]{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-b5044578]{color:var(--color-white);text-decoration:none}.navbar-brand[data-v-b5044578]{--brand-text-color: var(--color-white)}.navbar-menu[data-v-b5044578]{display:flex;gap:24px;align-items:center}.nav-link[data-v-b5044578]{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-b5044578]:hover,.nav-link.router-link-active[data-v-b5044578]{background-color:var(--color-white-alpha-10)}.nav-icon[data-v-b5044578]{line-height:1;display:flex;align-items:center;justify-content:center;width:18px;height:18px}.nav-text[data-v-b5044578]{white-space:nowrap}.superadmin-link[data-v-b5044578]{background:var(--color-white-alpha-20);font-weight:600;border:1px solid var(--color-white-alpha-40)}.superadmin-link[data-v-b5044578]:hover{background:var(--color-white-alpha-30)}.navbar-user[data-v-b5044578]{display:flex;gap:16px;align-items:center}.feature-request-btn[data-v-b5044578],.theme-toggle-btn[data-v-b5044578]{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-b5044578]:hover,.theme-toggle-btn[data-v-b5044578]:hover{background:var(--color-white-alpha-20);transform:scale(1.05)}.feature-request-btn[data-v-b5044578]{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-b5044578]: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-b5044578]{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-b5044578]:hover{background:var(--color-white-alpha-20)}.language-select-input[data-v-b5044578]: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-b5044578]{color:var(--color-text-primary);background:var(--bg-primary)}.user-info[data-v-b5044578]{display:flex;flex-direction:column;align-items:flex-end;font-size:14px}.user-name[data-v-b5044578]{font-weight:600}.user-org[data-v-b5044578]{font-size:12px;opacity:.8}.user-menu[data-v-b5044578]{position:relative}.user-menu-btn[data-v-b5044578]{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-b5044578]:hover{background:var(--color-white-alpha-20)}.dropdown-arrow[data-v-b5044578]{font-size:10px;transition:transform .3s ease}.user-dropdown[data-v-b5044578]{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-b5044578]{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-b5044578]:hover{background:var(--bg-tertiary)}.dropdown-item.logout[data-v-b5044578]{color:var(--color-danger)}.dropdown-item.logout[data-v-b5044578]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-b5044578]{margin:0;border:none;border-top:1px solid var(--border-color)}.password-form[data-v-b5044578]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-b5044578]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-b5044578]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-b5044578]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-b5044578]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-b5044578]{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-b5044578]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-b5044578]{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-b5044578]{color:var(--color-white);border-color:var(--color-white-alpha-50)}.navbar-user .btn[data-v-b5044578]:hover{background-color:var(--color-white-alpha-10)}@media(max-width:1023px){.navbar[data-v-b5044578]{display:none}.impersonation-banner[data-v-b5044578]{display:flex!important}}@media(max-width:768px){.navbar[data-v-b5044578]{position:sticky;top:0;z-index:1001}.navbar-container[data-v-b5044578]{flex-wrap:wrap;height:auto;padding:12px 16px}.navbar-brand[data-v-b5044578]{flex-shrink:0}.navbar-menu[data-v-b5044578]{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-b5044578]::-webkit-scrollbar{height:4px}.navbar-menu[data-v-b5044578]::-webkit-scrollbar-track{background:transparent}.navbar-menu[data-v-b5044578]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-30);border-radius:2px}.nav-link[data-v-b5044578]{flex-shrink:0;white-space:nowrap;font-size:14px;padding:6px 10px}.nav-icon[data-v-b5044578]{font-size:16px}.user-info[data-v-b5044578]{display:none}}.bottom-nav[data-v-1246f6df]{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-1246f6df]{display:none}}.bottom-nav-item[data-v-1246f6df]{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-1246f6df]:active{transform:scale(.95)}.nav-item-icon[data-v-1246f6df]{width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;color:inherit}.nav-item-label[data-v-1246f6df]{font-size:11px;font-weight:500;line-height:1;white-space:nowrap;transition:color .2s ease}.bottom-nav-item.active[data-v-1246f6df]{color:var(--color-primary)}.bottom-nav-item.active .nav-item-icon[data-v-1246f6df]{transform:scale(1.1)}.bottom-nav-item.active .nav-item-label[data-v-1246f6df]{font-weight:600}.bottom-nav-item.active[data-v-1246f6df]: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-1246f6df]:hover{background:var(--bg-tertiary)}}.more-menu-overlay[data-v-1246f6df]{position:fixed;inset:0;background:var(--bg-overlay);z-index:1000;display:flex;align-items:flex-end;justify-content:center}.more-menu[data-v-1246f6df]{background:var(--card-bg);border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:80vh;overflow-y:auto;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.more-menu-header[data-v-1246f6df]{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-1246f6df]{display:flex;flex-direction:column;gap:2px}.more-menu-header .user-name[data-v-1246f6df]{font-weight:600;font-size:16px;color:var(--color-text-primary)}.more-menu-header .user-org[data-v-1246f6df]{font-size:13px;color:var(--color-text-secondary)}.more-menu-header .close-btn[data-v-1246f6df]{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-1246f6df]:active{background:var(--bg-secondary);transform:scale(.95)}.more-menu-items[data-v-1246f6df]{padding:12px 0}.menu-item[data-v-1246f6df]{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-1246f6df]>*{pointer-events:none}.menu-item[data-v-1246f6df]:active{background:var(--bg-tertiary)}.menu-item .menu-icon[data-v-1246f6df]{width:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-secondary)}.menu-item.logout[data-v-1246f6df]{color:var(--color-danger)}.menu-divider[data-v-1246f6df]{height:1px;background:var(--border-color);margin:8px 20px}.slide-up-enter-active[data-v-1246f6df],.slide-up-leave-active[data-v-1246f6df]{transition:all .3s ease}.slide-up-enter-from[data-v-1246f6df],.slide-up-leave-to[data-v-1246f6df]{opacity:0}.slide-up-enter-from .more-menu[data-v-1246f6df],.slide-up-leave-to .more-menu[data-v-1246f6df]{transform:translateY(100%)}.slide-up-enter-to .more-menu[data-v-1246f6df],.slide-up-leave-from .more-menu[data-v-1246f6df]{transform:translateY(0)}.mobile-layout[data-v-63cb4dfb]{height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden;overscroll-behavior-x:none}.mobile-main[data-v-63cb4dfb]{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-63cb4dfb]{display:none}}.desktop-sidebar[data-v-e4e7729c]{position:fixed;left:0;top:0;bottom:0;width:260px;background:var(--bg-sidebar, #1e293b);color:#fff;display:flex;flex-direction:column;transition:width .3s ease;z-index:1000;overflow:hidden}.desktop-sidebar.collapsed[data-v-e4e7729c]{width:72px}@media(max-width:1023px){.desktop-sidebar[data-v-e4e7729c]{display:none}}.sidebar-brand[data-v-e4e7729c]{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1);min-height:72px}.brand-link[data-v-e4e7729c]{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}.brand-icon[data-v-e4e7729c]{width:32px;height:32px;background:var(--color-primary);border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:18px;flex-shrink:0}.brand-text[data-v-e4e7729c]{font-weight:700;font-size:1.25rem;letter-spacing:-.5px;white-space:nowrap}.sidebar-nav[data-v-e4e7729c]{flex:1;overflow-y:auto;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.sidebar-nav[data-v-e4e7729c]::-webkit-scrollbar{width:4px}.sidebar-nav[data-v-e4e7729c]::-webkit-scrollbar-track{background:transparent}.sidebar-nav[data-v-e4e7729c]::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.nav-group[data-v-e4e7729c]{margin-bottom:4px}.nav-item[data-v-e4e7729c]{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:#cbd5e1;cursor:pointer;transition:all .2s;white-space:nowrap;position:relative;font-size:.9rem;font-weight:500;text-decoration:none}.nav-item[data-v-e4e7729c]:hover{background:var(--bg-sidebar-hover, #334155);color:#fff}.nav-item.active[data-v-e4e7729c]{background:var(--color-primary);color:#fff;box-shadow:0 1px 2px #0000000d}.nav-item.active .nav-icon svg[data-v-e4e7729c]{color:#fff}.nav-icon[data-v-e4e7729c]{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-icon svg[data-v-e4e7729c]{color:#64748b;transition:color .2s}.nav-item:hover .nav-icon svg[data-v-e4e7729c]{color:#fff}.nav-label[data-v-e4e7729c]{flex:1;overflow:hidden;text-overflow:ellipsis}.nav-badge[data-v-e4e7729c]{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--color-danger, #ef4444);color:#fff;font-size:11px;font-weight:700;line-height:1;margin-left:auto}.nav-expand-icon[data-v-e4e7729c]{margin-left:auto;opacity:.4;transition:transform .2s,opacity .2s;display:flex;align-items:center}.nav-expand-icon.expanded[data-v-e4e7729c]{transform:rotate(0);opacity:.8}.nav-expand-icon[data-v-e4e7729c]:not(.expanded){transform:rotate(-90deg)}.nav-item.active .nav-expand-icon[data-v-e4e7729c]{opacity:.8}.nav-sub-items[data-v-e4e7729c]{padding-left:20px;margin-top:2px;display:flex;flex-direction:column;gap:1px}.nav-sub-item[data-v-e4e7729c]{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:10px;color:#cbd5e1;cursor:pointer;transition:all .2s;white-space:nowrap;font-size:.82rem;font-weight:400;text-decoration:none;position:relative}.nav-sub-item[data-v-e4e7729c]:before{content:"";width:4px;height:4px;border-radius:50%;background:#64748b;flex-shrink:0;transition:all .2s}.nav-sub-item[data-v-e4e7729c]:hover{background:var(--bg-sidebar-hover, #334155);color:#fff}.nav-sub-item.router-link-active[data-v-e4e7729c],.nav-sub-item.active[data-v-e4e7729c]{color:var(--color-primary);font-weight:500}.nav-sub-item.router-link-active[data-v-e4e7729c]:before,.nav-sub-item.active[data-v-e4e7729c]:before{background:var(--color-primary);width:5px;height:5px}.sidebar-footer[data-v-e4e7729c]{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-actions[data-v-e4e7729c]{display:flex;align-items:center;gap:4px;margin-bottom:12px}.action-btn[data-v-e4e7729c]{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:all .15s;font-size:1.1rem;background:none;border:none;cursor:pointer;position:relative}.action-btn[data-v-e4e7729c]:hover{background:#ffffff14;color:#fff}.action-btn.has-unread[data-v-e4e7729c]{color:#fff}.notif-badge[data-v-e4e7729c]{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1}.user-section[data-v-e4e7729c]{position:relative}.sidebar-user[data-v-e4e7729c]{display:flex;align-items:center;gap:12px;padding:8px;border-radius:10px;cursor:pointer;transition:background .15s;background:var(--bg-sidebar-hover, #334155);border:none;color:#fff;width:100%;text-align:left}.sidebar-user[data-v-e4e7729c]:hover{background:#ffffff1f}.user-avatar[data-v-e4e7729c]{width:36px;height:36px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.user-info[data-v-e4e7729c]{overflow:hidden}.user-name[data-v-e4e7729c]{color:#fff;font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role[data-v-e4e7729c]{color:var(--color-primary);font-size:.75rem;font-weight:500;text-transform:capitalize;letter-spacing:.5px;white-space:nowrap}.user-dropdown[data-v-e4e7729c]{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:var(--card-bg, #fff);border-radius:10px;box-shadow:0 -4px 12px #00000026;overflow:hidden;border:1px solid var(--border-color);z-index:1100}.dropdown-item[data-v-e4e7729c]{width:100%;padding:12px 16px;background:var(--card-bg, #fff);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-e4e7729c]:hover{background:var(--bg-tertiary)}.dropdown-item.logout[data-v-e4e7729c]{color:var(--color-danger)}.dropdown-item.logout[data-v-e4e7729c]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-e4e7729c]{margin:0;border:none;border-top:1px solid var(--border-color)}.desktop-sidebar.collapsed .nav-label[data-v-e4e7729c],.desktop-sidebar.collapsed .nav-badge[data-v-e4e7729c],.desktop-sidebar.collapsed .nav-expand-icon[data-v-e4e7729c],.desktop-sidebar.collapsed .brand-text[data-v-e4e7729c],.desktop-sidebar.collapsed .user-info[data-v-e4e7729c]{display:none}.desktop-sidebar.collapsed .nav-item[data-v-e4e7729c]{justify-content:center;padding:10px}.desktop-sidebar.collapsed .sidebar-brand[data-v-e4e7729c]{padding:24px 12px;justify-content:center}.desktop-sidebar.collapsed .brand-link[data-v-e4e7729c]{justify-content:center}.desktop-sidebar.collapsed .sidebar-actions[data-v-e4e7729c]{flex-direction:column}.desktop-sidebar.collapsed .sidebar-user[data-v-e4e7729c]{justify-content:center;padding:8px}.notification-section[data-v-e4e7729c]{position:relative}.notification-dropdown[data-v-e4e7729c]{position:absolute;bottom:calc(100% + 8px);left:-100px;width:360px;max-height:480px;background:var(--card-bg, #fff);border-radius:12px;box-shadow:0 -8px 32px #00000040;border:1px solid var(--border-color);overflow:hidden;z-index:1100}.notification-header[data-v-e4e7729c]{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-e4e7729c]{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.mark-all-read[data-v-e4e7729c]{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-e4e7729c]:hover{background:var(--color-primary-alpha-10)}.notification-list[data-v-e4e7729c]{max-height:360px;overflow-y:auto}.notification-empty[data-v-e4e7729c]{padding:32px 16px;text-align:center;color:var(--color-text-secondary);font-size:14px}.notification-item[data-v-e4e7729c]{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-e4e7729c]:hover{background:var(--bg-tertiary)}.notification-item[data-v-e4e7729c]:last-child{border-bottom:none}.notification-item.unread[data-v-e4e7729c]{background:var(--color-primary-alpha-05)}.notification-content[data-v-e4e7729c]{flex:1;min-width:0}.notification-title[data-v-e4e7729c]{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-body[data-v-e4e7729c]{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-e4e7729c]{font-size:11px;color:var(--color-text-tertiary);margin-top:4px}.notification-unread-dot[data-v-e4e7729c]{position:absolute;top:50%;right:12px;transform:translateY(-50%);width:8px;height:8px;background:var(--color-primary);border-radius:50%}.notification-footer[data-v-e4e7729c]{padding:12px 16px;text-align:center;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.notification-footer a[data-v-e4e7729c]{color:var(--color-primary);text-decoration:none;font-size:13px;font-weight:500}.password-form[data-v-e4e7729c]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-e4e7729c]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-e4e7729c]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-e4e7729c]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-e4e7729c]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-e4e7729c]{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-e4e7729c]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-e4e7729c]{padding:10px;background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:6px;color:var(--color-danger-dark);font-size:14px}.topbar-wrapper[data-v-39afbba5]{position:sticky;top:0;z-index:10;flex-shrink:0}.topbar[data-v-39afbba5]{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-surface, var(--bg-primary, #fff));border-bottom:1px solid var(--border-color);gap:16px;height:64px;box-sizing:border-box}.topbar-left[data-v-39afbba5]{flex:1;max-width:500px}.search-bar[data-v-39afbba5]{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-page, var(--bg-tertiary, #f8fafc));border:1px solid var(--border-color);border-radius:14px;color:var(--color-text-tertiary);font-size:.9rem;cursor:pointer;transition:border-color .15s;width:300px}.search-bar[data-v-39afbba5]:hover{border-color:var(--color-primary)}.search-bar svg[data-v-39afbba5]{flex-shrink:0;opacity:.5}.search-bar span[data-v-39afbba5]{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-bar kbd[data-v-39afbba5]{margin-left:auto;padding:1px 6px;background:var(--bg-tertiary, #e2e8f0);border:1px solid var(--border-color);border-radius:4px;font-size:11px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:var(--color-text-secondary)}.topbar-right[data-v-39afbba5]{display:flex;align-items:center;gap:16px}.topbar-user[data-v-39afbba5]{text-align:right;line-height:1.2}.tu-name[data-v-39afbba5]{font-weight:600;font-size:.875rem;color:var(--color-text-primary)}.tu-role[data-v-39afbba5]{font-size:.7rem;color:var(--color-primary);font-weight:500;text-transform:capitalize}.btn-einstempeln[data-v-39afbba5]{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.btn-einstempeln[data-v-39afbba5]:hover{background:var(--color-primary-dark, #0891b2);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.breadcrumb-bar[data-v-39afbba5]{display:flex;align-items:center;gap:8px;padding:8px 24px;background:var(--bg-surface, var(--bg-primary, #fff));border-bottom:1px solid var(--border-color);font-size:.8125rem}.back-btn[data-v-39afbba5]{display:flex;align-items:center;gap:6px;padding:4px 10px;background:none;border:1px solid var(--border-color);border-radius:6px;color:var(--color-text-secondary);font-size:.8125rem;cursor:pointer;transition:all .15s;line-height:1}.back-btn[data-v-39afbba5]:hover{background:var(--bg-tertiary);border-color:var(--color-primary);color:var(--color-primary)}.back-btn svg[data-v-39afbba5]{flex-shrink:0}.breadcrumb-sep[data-v-39afbba5]{color:var(--color-text-tertiary);font-size:1rem;line-height:1}.breadcrumb-current[data-v-39afbba5]{color:var(--color-text-primary);font-weight:600}@media(max-width:1023px){.topbar-wrapper[data-v-39afbba5]{display:none}}.desktop-layout[data-v-265819bb]{display:none;min-height:100vh;background:var(--app-bg)}@media(min-width:1024px){.desktop-layout[data-v-265819bb]{display:flex}}.desktop-content[data-v-265819bb]{flex:1;margin-left:260px;display:flex;flex-direction:column;transition:margin-left .3s ease;min-height:100vh;background:var(--app-bg)}.desktop-main[data-v-265819bb]{flex:1;padding:32px;overflow-y:auto}@media(min-width:1440px){.desktop-main[data-v-265819bb]{padding:40px;max-width:1600px;margin:0 auto;width:100%}}.pwa-install-prompt[data-v-c310cccd]{position:fixed;bottom:0;left:0;right:0;background:var(--gradient-brand);color:var(--color-white);padding:16px 20px;box-shadow:0 -4px 12px var(--color-black-alpha-20);z-index:9999;animation:slideUp .3s ease-out}.prompt-content[data-v-c310cccd]{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:16px}.prompt-icon[data-v-c310cccd]{font-size:36px;flex-shrink:0}.prompt-text[data-v-c310cccd]{flex:1}.prompt-text h3[data-v-c310cccd]{margin:0 0 4px;font-size:16px;font-weight:600}.prompt-text p[data-v-c310cccd]{margin:0;font-size:13px;opacity:.95;line-height:1.4}.prompt-actions[data-v-c310cccd]{display:flex;gap:12px;align-items:center;flex-shrink:0}.btn-install[data-v-c310cccd]{padding:10px 20px;background:var(--card-bg);color:var(--color-secondary);border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-install[data-v-c310cccd]:hover{background:var(--bg-secondary);transform:translateY(-1px)}.btn-install[data-v-c310cccd]:active{transform:translateY(0)}.btn-dismiss[data-v-c310cccd]{padding:8px 12px;background:var(--color-white-alpha-20);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-c310cccd]:hover{background:var(--color-white-alpha-30)}.slide-up-enter-active[data-v-c310cccd],.slide-up-leave-active[data-v-c310cccd]{transition:transform .3s ease-out}.slide-up-enter-from[data-v-c310cccd],.slide-up-leave-to[data-v-c310cccd]{transform:translateY(100%)}@media(max-width:768px){.pwa-install-prompt[data-v-c310cccd]{padding:12px 16px}.prompt-content[data-v-c310cccd]{flex-wrap:wrap;gap:12px}.prompt-icon[data-v-c310cccd]{font-size:28px}.prompt-text h3[data-v-c310cccd]{font-size:15px}.prompt-text p[data-v-c310cccd]{font-size:12px}.prompt-actions[data-v-c310cccd]{width:100%;justify-content:stretch}.btn-install[data-v-c310cccd]{flex:1;padding:12px}}.ios-prompt[data-v-c310cccd]{padding:20px}.ios-content[data-v-c310cccd]{flex-direction:column;position:relative}.ios-close[data-v-c310cccd]{position:absolute;top:-8px;right:-8px;background:var(--color-black-alpha-30);padding:6px 10px}.ios-header[data-v-c310cccd]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.ios-steps[data-v-c310cccd]{display:flex;flex-direction:column;gap:12px;background:var(--color-white-alpha-10);padding:16px;border-radius:8px}.ios-step[data-v-c310cccd]{display:flex;align-items:center;gap:12px}.step-number[data-v-c310cccd]{width:24px;height:24px;background:var(--color-white-alpha-90);color:var(--color-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.step-icon[data-v-c310cccd]{width:32px;height:32px;background:var(--color-white-alpha-20);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.step-icon svg[data-v-c310cccd]{stroke:currentColor;stroke-width:2;fill:none}.step-text[data-v-c310cccd]{font-size:14px;line-height:1.4}.step-text strong[data-v-c310cccd]{color:var(--color-text-inverse)}.floating-timer[data-v-2af3d6f8]{position:fixed;bottom:80px;right:16px;background:var(--color-primary);color:#fff;border-radius:50px;padding:10px 18px;box-shadow:0 4px 16px #06b6d459;z-index:10000;cursor:pointer;min-width:180px;-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-2af3d6f8]:active{transform:scale(.95)}.floating-timer[data-v-2af3d6f8]:hover{box-shadow:0 8px 24px #06b6d473;transform:translateY(-2px)}.timer-content[data-v-2af3d6f8]{display:flex;align-items:center;gap:12px}.timer-icon[data-v-2af3d6f8]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fff3;border-radius:50%;position:relative}.pulse-dot[data-v-2af3d6f8]{width:10px;height:10px;background:#22c55e;border-radius:50%;animation:pulse-2af3d6f8 2s ease-in-out infinite}@keyframes pulse-2af3d6f8{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.timer-info[data-v-2af3d6f8]{flex:1}.timer-project[data-v-2af3d6f8]{font-size:12px;font-weight:500;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.timer-time[data-v-2af3d6f8]{font-size:18px;font-weight:700;font-family:Courier New,monospace;letter-spacing:1px}.timer-hint[data-v-2af3d6f8]{margin-top:6px;font-size:10px;text-align:center;opacity:.7}.fade-slide-enter-active[data-v-2af3d6f8],.fade-slide-leave-active[data-v-2af3d6f8]{transition:all .3s cubic-bezier(.4,0,.2,1)}.fade-slide-enter-from[data-v-2af3d6f8],.fade-slide-leave-to[data-v-2af3d6f8]{opacity:0;transform:translateY(20px)}@media(min-width:769px){.floating-timer[data-v-2af3d6f8]{bottom:24px;right:24px}}@media(max-width:360px){.floating-timer[data-v-2af3d6f8]{min-width:180px;padding:10px 12px}.timer-time[data-v-2af3d6f8]{font-size:16px}.timer-project[data-v-2af3d6f8]{font-size:11px;max-width:110px}}.subscription-banner[data-v-f1baf141]{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,var(--color-danger-dark) 0%,var(--color-danger-dark) 100%);color:var(--color-white);padding:12px 16px;box-shadow:0 4px 12px var(--color-danger-alpha-20)}.banner-content[data-v-f1baf141]{display:flex;align-items:center;justify-content:center;gap:12px;max-width:1200px;margin:0 auto;flex-wrap:wrap}.banner-icon[data-v-f1baf141]{font-size:20px}.banner-message[data-v-f1baf141]{font-weight:500;font-size:14px;text-align:center}.banner-btn[data-v-f1baf141]{background:var(--bg-primary);color:var(--color-danger-dark);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-f1baf141]:hover{background:var(--color-danger-bg);transform:translateY(-1px)}.slide-enter-active[data-v-f1baf141],.slide-leave-active[data-v-f1baf141]{transition:transform .3s ease,opacity .3s ease}.slide-enter-from[data-v-f1baf141],.slide-leave-to[data-v-f1baf141]{transform:translateY(-100%);opacity:0}@media(max-width:768px){.subscription-banner[data-v-f1baf141]{padding:10px 12px}.banner-content[data-v-f1baf141]{flex-direction:column;gap:8px}.banner-message[data-v-f1baf141]{font-size:13px}.banner-btn[data-v-f1baf141]{width:100%;padding:10px 16px}}.notification-banner[data-v-82f4fd28]{position:fixed;bottom:70px;left:16px;right:16px;background:linear-gradient(135deg,var(--color-success) 0%,var(--color-success-dark) 100%);color:var(--color-white);padding:16px 20px;border-radius:12px;box-shadow:0 4px 20px var(--color-success-alpha-40);z-index:9998}@media(min-width:769px){.notification-banner[data-v-82f4fd28]{bottom:24px;left:auto;right:24px;max-width:420px}}.banner-content[data-v-82f4fd28]{display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px}.banner-icon[data-v-82f4fd28]{font-size:32px;flex-shrink:0;line-height:1}.banner-text[data-v-82f4fd28]{flex:1;min-width:200px}.banner-text h3[data-v-82f4fd28]{margin:0 0 4px;font-size:16px;font-weight:600}.banner-text p[data-v-82f4fd28]{margin:0;font-size:13px;opacity:.95;line-height:1.4}.banner-actions[data-v-82f4fd28]{display:flex;gap:8px;align-items:center;flex-shrink:0;width:100%;margin-top:8px}@media(min-width:769px){.banner-actions[data-v-82f4fd28]{width:auto;margin-top:0}}.btn-activate[data-v-82f4fd28],.btn-settings[data-v-82f4fd28]{flex:1;padding:10px 16px;background:var(--card-bg);color:var(--color-success-dark);border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-activate[data-v-82f4fd28]:hover:not(:disabled),.btn-settings[data-v-82f4fd28]:hover{background:var(--bg-secondary);transform:translateY(-1px)}.btn-activate[data-v-82f4fd28]:disabled{opacity:.7;cursor:not-allowed}.btn-dismiss[data-v-82f4fd28]{padding:10px 16px;background:var(--color-white-alpha-20);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-82f4fd28]:hover{background:var(--color-white-alpha-30)}.slide-up-enter-active[data-v-82f4fd28],.slide-up-leave-active[data-v-82f4fd28]{transition:all .3s ease-out}.slide-up-enter-from[data-v-82f4fd28],.slide-up-leave-to[data-v-82f4fd28]{transform:translateY(100%);opacity:0}.sync-status[data-v-a9ee5b36]{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--color-black-alpha-80);color:var(--color-white);padding:8px 16px;border-radius:20px;display:flex;align-items:center;gap:8px;font-size:13px;z-index:1000;box-shadow:0 2px 10px var(--color-black-alpha-30);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;transition:all .3s ease}.sync-status.offline[data-v-a9ee5b36]{background:var(--color-danger-alpha-90)}.spinning[data-v-a9ee5b36]{display:inline-block;animation:spin-a9ee5b36 2s linear infinite}@keyframes spin-a9ee5b36{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(min-width:1024px){.sync-status[data-v-a9ee5b36]{bottom:20px;left:auto;right:20px;transform:none}}#app{min-height:100vh}:root{--color-primary: #00bcd4;--color-primary-light: #26c6da;--color-primary-dark: #00acc1;--color-primary-darker: #00838f;--primary-50: #ecfeff;--primary-100: #cffafe;--primary-200: #a5f3fc;--primary-300: #67e8f9;--primary-400: #22d3ee;--primary-500: #00bcd4;--primary-600: #00acc1;--primary-700: #0e7490;--primary-800: #155e75;--primary-900: #164e63;--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);--background-primary: var(--bg-primary);--background-secondary: var(--bg-secondary);--background-tertiary: var(--bg-tertiary);--bg-color: var(--bg-primary);--border-radius: var(--border-radius-md);--color-secondary: #0891b2;--color-secondary-light: #22d3ee;--color-secondary-dark: #0e7490;--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;--calendar-default-color: var(--color-gray-500);--illustration-slate-light: #e2e8f0;--illustration-slate-mid: #cbd5e1;--illustration-slate-base: #94a3b8;--illustration-slate-dark: #64748b;--illustration-metal: #475569;--illustration-charcoal: #334155;--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);--print-bg: #ffffff;--app-bg: var(--bg-secondary);--border-color: #e5e7eb;--border-color-light: #f3f4f6;--border-color-dark: #d1d5db;--border-radius-sm: 6px;--border-radius-md: 10px;--border-radius-lg: 14px;--border-radius-xl: 20px;--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(--bg-sidebar);--navbar-border: var(--border-color);--sidebar-width: 16rem;--sidebar-width-collapsed: 5rem;--sidebar-bg: #1e293b;--bg-sidebar: #1e293b;--bg-sidebar-hover: #334155;--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-05: rgba(0, 188, 212, .05);--color-primary-alpha-10: rgba(0, 188, 212, .1);--color-primary-alpha-20: rgba(0, 188, 212, .2);--color-primary-alpha-30: rgba(0, 188, 212, .3);--color-success-alpha-05: rgba(16, 185, 129, .05);--color-success-alpha-00: rgba(16, 185, 129, 0);--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-warning-gold-alpha-15: rgba(255, 215, 0, .15);--color-warning-gold-alpha-25: rgba(255, 215, 0, .25);--color-warning-gold-alpha-30: rgba(255, 215, 0, .3);--color-warning-gold-alpha-50: rgba(255, 215, 0, .5);--color-warning-orange-alpha-15: rgba(255, 165, 0, .15);--color-warning-orange-alpha-25: rgba(255, 165, 0, .25);--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-08: rgba(0, 0, 0, .08);--color-black-alpha-10: rgba(0, 0, 0, .1);--color-black-alpha-12: rgba(0, 0, 0, .12);--color-black-alpha-15: rgba(0, 0, 0, .15);--color-black-alpha-20: rgba(0, 0, 0, .2);--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-black-alpha-60: rgba(0, 0, 0, .6);--color-black-alpha-70: rgba(0, 0, 0, .7);--color-black-alpha-80: rgba(0, 0, 0, .8);--color-black-alpha-85: rgba(0, 0, 0, .85);--color-danger-alpha-05: rgba(239, 68, 68, .05);--color-danger-alpha-20: rgba(239, 68, 68, .2);--color-danger-alpha-90: rgba(239, 68, 68, .9);--color-success-alpha-08: rgba(16, 185, 129, .08);--color-success-alpha-15: rgba(16, 185, 129, .15);--color-success-alpha-50: rgba(16, 185, 129, .5);--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, #00bcd4 0%, #00acc1 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);--print-bg: #ffffff;--color-text-primary: #f9fafb;--color-text-secondary: #e5e7eb;--color-text-tertiary: #cbd5e1;--color-text-inverse: #111827;--calendar-default-color: var(--color-gray-500);--illustration-slate-light: #475569;--illustration-slate-mid: #64748b;--illustration-slate-base: #64748b;--illustration-slate-dark: #94a3b8;--illustration-metal: #cbd5e1;--illustration-charcoal: #e2e8f0;--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: #09090b;--bg-sidebar: #09090b;--bg-sidebar-hover: #27272a;--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-05: rgba(0, 188, 212, .08);--color-primary-alpha-10: rgba(0, 188, 212, .15);--color-primary-alpha-20: rgba(0, 188, 212, .2);--color-primary-alpha-30: rgba(0, 188, 212, .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-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-08: rgba(0, 0, 0, .2);--color-black-alpha-10: rgba(0, 0, 0, .4);--color-black-alpha-12: rgba(0, 0, 0, .42);--color-black-alpha-20: rgba(0, 0, 0, .5);--color-black-alpha-25: rgba(0, 0, 0, .45);--color-black-alpha-30: rgba(0, 0, 0, .55);--color-black-alpha-50: rgba(0, 0, 0, .65);--color-black-alpha-60: rgba(0, 0, 0, .75);--color-black-alpha-70: rgba(0, 0, 0, .8);--color-black-alpha-80: rgba(0, 0, 0, .85);--color-black-alpha-85: rgba(0, 0, 0, .9);--color-danger-alpha-05: rgba(239, 68, 68, .1);--color-danger-alpha-20: rgba(239, 68, 68, .25);--color-danger-alpha-90: rgba(239, 68, 68, .85);--color-success-alpha-08: rgba(16, 185, 129, .12);--color-success-alpha-15: rgba(16, 185, 129, .2);--color-success-alpha-50: rgba(16, 185, 129, .6);--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)}.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;background:var(--app-bg, var(--bg-secondary));overflow-x:hidden}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}body.modal-open{overflow:hidden;overscroll-behavior:none}.modal-overlay,.measurement-modal-overlay,.assignment-modal-overlay,.notes-modal-overlay,.work-report-overlay,.equipment-overlay,.project-measurement-overlay{pointer-events:auto;touch-action:none;overscroll-behavior:contain}.modal-overlay>*,.measurement-modal-overlay>*,.assignment-modal-overlay>*,.notes-modal-overlay>*,.work-report-overlay>*,.equipment-overlay>*,.project-measurement-overlay>*{touch-action:pan-y pinch-zoom}@supports (-webkit-touch-callout: none){@media(max-width:1023px){html,body{position:fixed;width:100%;height:100%;overflow:hidden;overscroll-behavior-y:none}#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, var(--color-gray-700))!important;color:var(--input-text, var(--color-gray-50))!important;border-color:var(--border-color, var(--color-gray-600))!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:var(--bg-tertiary);color:var(--color-text-primary)}::-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:var(--print-bg)}.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}}
