.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}}.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-61b1f54c]{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:8px 20px;display:flex;justify-content:center;align-items:center;gap:20px;font-size:14px;position:sticky;top:0;z-index:1001}.impersonation-text[data-v-61b1f54c]{display:flex;align-items:center;gap:8px}.impersonation-text strong[data-v-61b1f54c]{font-weight:600}.impersonation-text .org-name[data-v-61b1f54c]{opacity:.9}.return-btn[data-v-61b1f54c]{background:#fff3;border:1px solid rgba(255,255,255,.4);color:#fff;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.return-btn[data-v-61b1f54c]:hover{background:#ffffff4d;border-color:#fff9}.navbar[data-v-61b1f54c]{background:var(--navbar-bg);color:var(--color-white);box-shadow:var(--shadow-md)}.navbar-container[data-v-61b1f54c]{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:64px}.navbar-brand h1[data-v-61b1f54c]{font-size:24px;margin:0}.navbar-brand a[data-v-61b1f54c]{color:var(--color-white);text-decoration:none}.navbar-menu[data-v-61b1f54c]{display:flex;gap:24px;align-items:center}.nav-link[data-v-61b1f54c]{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-61b1f54c]:hover,.nav-link.router-link-active[data-v-61b1f54c]{background-color:var(--color-white-alpha-10)}.nav-icon[data-v-61b1f54c]{font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center}.nav-text[data-v-61b1f54c]{white-space:nowrap}.superadmin-link[data-v-61b1f54c]{background:var(--color-white-alpha-20);font-weight:600;border:1px solid var(--color-white-alpha-40)}.superadmin-link[data-v-61b1f54c]:hover{background:var(--color-white-alpha-30)}.navbar-user[data-v-61b1f54c]{display:flex;gap:16px;align-items:center}.feature-request-btn[data-v-61b1f54c],.theme-toggle-btn[data-v-61b1f54c]{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-61b1f54c]:hover,.theme-toggle-btn[data-v-61b1f54c]:hover{background:var(--color-white-alpha-20);transform:scale(1.05)}.feature-request-btn[data-v-61b1f54c]{background:linear-gradient(135deg,#ffd70033,#ffa50033);border-color:#ffd70066}.feature-request-btn[data-v-61b1f54c]:hover{background:linear-gradient(135deg,#ffd7004d,#ffa5004d);border-color:#ffd70099}.language-select-input[data-v-61b1f54c]{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-61b1f54c]:hover{background:var(--color-white-alpha-20)}.language-select-input[data-v-61b1f54c]: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-61b1f54c]{color:var(--color-text-primary);background:var(--bg-primary)}.user-info[data-v-61b1f54c]{display:flex;flex-direction:column;align-items:flex-end;font-size:14px}.user-name[data-v-61b1f54c]{font-weight:600}.user-org[data-v-61b1f54c]{font-size:12px;opacity:.8}.user-menu[data-v-61b1f54c]{position:relative}.user-menu-btn[data-v-61b1f54c]{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-61b1f54c]:hover{background:var(--color-white-alpha-20)}.dropdown-arrow[data-v-61b1f54c]{font-size:10px;transition:transform .3s ease}.user-dropdown[data-v-61b1f54c]{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-61b1f54c]{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-61b1f54c]:hover{background:var(--bg-tertiary)}.dropdown-item.logout[data-v-61b1f54c]{color:var(--color-danger)}.dropdown-item.logout[data-v-61b1f54c]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-61b1f54c]{margin:0;border:none;border-top:1px solid var(--border-color)}.password-form[data-v-61b1f54c]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-61b1f54c]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-61b1f54c]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-61b1f54c]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-61b1f54c]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-61b1f54c]{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-61b1f54c]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-61b1f54c]{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-61b1f54c]{color:var(--color-white);border-color:var(--color-white-alpha-50)}.navbar-user .btn[data-v-61b1f54c]:hover{background-color:var(--color-white-alpha-10)}@media(max-width:1023px){.navbar[data-v-61b1f54c]{display:none}.impersonation-banner[data-v-61b1f54c]{display:flex!important}}@media(max-width:768px){.navbar[data-v-61b1f54c]{position:sticky;top:0;z-index:1001}.navbar-container[data-v-61b1f54c]{flex-wrap:wrap;height:auto;padding:12px 16px}.navbar-brand[data-v-61b1f54c]{flex-shrink:0}.navbar-brand h1[data-v-61b1f54c]{font-size:20px}.navbar-menu[data-v-61b1f54c]{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-61b1f54c]::-webkit-scrollbar{height:4px}.navbar-menu[data-v-61b1f54c]::-webkit-scrollbar-track{background:transparent}.navbar-menu[data-v-61b1f54c]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-30);border-radius:2px}.nav-link[data-v-61b1f54c]{flex-shrink:0;white-space:nowrap;font-size:14px;padding:6px 10px}.nav-icon[data-v-61b1f54c]{font-size:16px}.user-info[data-v-61b1f54c]{display:none}}.bottom-nav[data-v-ffc09d1b]{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 #0000001a;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-ffc09d1b]{display:none}}.bottom-nav-item[data-v-ffc09d1b]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;text-decoration:none;color:var(--color-text-secondary);transition:all .2s ease;border-radius:8px;position:relative;min-width:60px;max-width:80px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;-webkit-touch-callout:none}.bottom-nav-item[data-v-ffc09d1b]:active{transform:scale(.95)}.nav-item-icon[data-v-ffc09d1b]{font-size:24px;line-height:1;transition:transform .2s ease}.nav-item-label[data-v-ffc09d1b]{font-size:11px;font-weight:500;line-height:1;white-space:nowrap;transition:color .2s ease}.bottom-nav-item.active[data-v-ffc09d1b]{color:var(--color-primary)}.bottom-nav-item.active .nav-item-icon[data-v-ffc09d1b]{transform:scale(1.1)}.bottom-nav-item.active .nav-item-label[data-v-ffc09d1b]{font-weight:600}.bottom-nav-item.active[data-v-ffc09d1b]: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-ffc09d1b]:hover{background:var(--bg-tertiary)}}@media(prefers-color-scheme:dark){.bottom-nav[data-v-ffc09d1b]{box-shadow:0 -2px 10px #0000004d}}.more-menu-overlay[data-v-ffc09d1b]{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.more-menu[data-v-ffc09d1b]{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-ffc09d1b]{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-ffc09d1b]{display:flex;flex-direction:column;gap:2px}.more-menu-header .user-name[data-v-ffc09d1b]{font-weight:600;font-size:16px;color:var(--color-text-primary)}.more-menu-header .user-org[data-v-ffc09d1b]{font-size:13px;color:var(--color-text-secondary)}.more-menu-items[data-v-ffc09d1b]{padding:12px 0}.menu-item[data-v-ffc09d1b]{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}.menu-item[data-v-ffc09d1b]:active{background:var(--bg-tertiary)}.menu-item .menu-icon[data-v-ffc09d1b]{font-size:22px;width:28px;text-align:center}.menu-item.logout[data-v-ffc09d1b]{color:var(--color-danger)}.menu-divider[data-v-ffc09d1b]{height:1px;background:var(--border-color);margin:8px 20px}.slide-up-enter-active[data-v-ffc09d1b],.slide-up-leave-active[data-v-ffc09d1b]{transition:all .3s ease}.slide-up-enter-from[data-v-ffc09d1b],.slide-up-leave-to[data-v-ffc09d1b]{opacity:0}.slide-up-enter-from .more-menu[data-v-ffc09d1b],.slide-up-leave-to .more-menu[data-v-ffc09d1b]{transform:translateY(100%)}.slide-up-enter-to .more-menu[data-v-ffc09d1b],.slide-up-leave-from .more-menu[data-v-ffc09d1b]{transform:translateY(0)}.mobile-layout[data-v-41e8786a]{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-primary);height:100%;overflow:hidden;overscroll-behavior-x:none;touch-action:pan-y}.mobile-main[data-v-41e8786a]{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-41e8786a]{display:none}}.desktop-sidebar[data-v-978ff7d1]{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-978ff7d1]{width:80px}@media(max-width:1023px){.desktop-sidebar[data-v-978ff7d1]{display:none}}.sidebar-header[data-v-978ff7d1]{padding:20px;border-bottom:1px solid var(--color-white-alpha-10)}.sidebar-brand[data-v-978ff7d1]{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--color-white)}.brand-icon[data-v-978ff7d1]{font-size:32px;line-height:1;flex-shrink:0}.brand-text h1[data-v-978ff7d1]{font-size:20px;margin:0;font-weight:600;white-space:nowrap}.brand-subtitle[data-v-978ff7d1]{font-size:12px;margin:0;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav[data-v-978ff7d1]{flex:1;padding:20px 0;overflow-y:auto;overflow-x:hidden}.sidebar-link[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--color-white-alpha-10)}.sidebar-link.router-link-active[data-v-978ff7d1]{background:var(--color-white-alpha-15);font-weight:600}.sidebar-link.router-link-active[data-v-978ff7d1]: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-978ff7d1]{font-size:20px;line-height:1;flex-shrink:0;width:24px;display:flex;align-items:center;justify-content:center}.link-text[data-v-978ff7d1]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-link.superadmin[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--color-white-alpha-30)}.sidebar-footer[data-v-978ff7d1]{padding:16px;border-top:1px solid var(--color-white-alpha-10);display:flex;flex-direction:column;gap:12px}.sidebar-action-btn[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--color-white-alpha-20)}.action-icon[data-v-978ff7d1]{font-size:18px;flex-shrink:0}.action-text[data-v-978ff7d1]{white-space:nowrap}.feature-request-btn[data-v-978ff7d1]{background:linear-gradient(135deg,#ffd70026,#ffa50026);border-color:#ffd7004d}.feature-request-btn[data-v-978ff7d1]:hover{background:linear-gradient(135deg,#ffd70040,#ffa50040);border-color:#ffd70080}.user-section[data-v-978ff7d1]{position:relative}.user-btn[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--color-white-alpha-20)}.user-avatar[data-v-978ff7d1]{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-978ff7d1]{flex:1;text-align:left;overflow:hidden}.user-name[data-v-978ff7d1]{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role[data-v-978ff7d1]{font-size:11px;opacity:.8;text-transform:capitalize}.user-dropdown[data-v-978ff7d1]{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-978ff7d1]{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-978ff7d1]:hover{background:var(--bg-tertiary)}.dropdown-icon[data-v-978ff7d1]{font-size:16px}.dropdown-item.logout[data-v-978ff7d1]{color:var(--color-danger)}.dropdown-item.logout[data-v-978ff7d1]:hover{background:var(--color-danger-bg)}.dropdown-divider[data-v-978ff7d1]{margin:0;border:none;border-top:1px solid var(--border-color)}.collapse-btn[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--color-white-alpha-20)}.collapse-icon[data-v-978ff7d1]{font-size:16px;font-weight:700}.desktop-sidebar.collapsed .sidebar-link[data-v-978ff7d1],.desktop-sidebar.collapsed .sidebar-action-btn[data-v-978ff7d1],.desktop-sidebar.collapsed .user-btn[data-v-978ff7d1]{justify-content:center;padding-left:12px;padding-right:12px}.desktop-sidebar.collapsed .sidebar-header[data-v-978ff7d1]{display:flex;justify-content:center;padding:20px 10px}.desktop-sidebar.collapsed .brand-text[data-v-978ff7d1]{display:none}.password-form[data-v-978ff7d1]{display:flex;flex-direction:column;gap:16px}.info-box[data-v-978ff7d1]{background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:8px;padding:12px;margin-bottom:8px}.info-box p[data-v-978ff7d1]{margin:0;font-size:14px;color:var(--color-info-dark);line-height:1.5}.form-group[data-v-978ff7d1]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-978ff7d1]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input[data-v-978ff7d1]{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-978ff7d1]{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.error-message[data-v-978ff7d1]{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-978ff7d1]::-webkit-scrollbar{width:6px}.sidebar-nav[data-v-978ff7d1]::-webkit-scrollbar-track{background:var(--color-white-alpha-10)}.sidebar-nav[data-v-978ff7d1]::-webkit-scrollbar-thumb{background:var(--color-white-alpha-20);border-radius:3px}.sidebar-nav[data-v-978ff7d1]::-webkit-scrollbar-thumb:hover{background:var(--color-white-alpha-30)}.notification-section[data-v-978ff7d1],.notification-btn[data-v-978ff7d1]{position:relative}.notification-btn.has-unread .action-icon[data-v-978ff7d1]{animation:bell-shake-978ff7d1 .5s ease-in-out}@keyframes bell-shake-978ff7d1{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}50%{transform:rotate(15deg)}75%{transform:rotate(-10deg)}}.notification-badge[data-v-978ff7d1]{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-978ff7d1]{top:2px;right:8px}.notification-dropdown[data-v-978ff7d1]{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-978ff7d1]{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-978ff7d1]{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.mark-all-read[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--color-primary-bg)}.notification-list[data-v-978ff7d1]{max-height:360px;overflow-y:auto}.notification-empty[data-v-978ff7d1]{padding:32px 16px;text-align:center;color:var(--color-text-secondary);font-size:14px}.notification-item[data-v-978ff7d1]{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-978ff7d1]:hover{background:var(--bg-tertiary)}.notification-item[data-v-978ff7d1]:last-child{border-bottom:none}.notification-item.unread[data-v-978ff7d1]{background:var(--color-primary-bg)}.notification-item.unread[data-v-978ff7d1]:hover{background:#3b82f626}.notification-icon[data-v-978ff7d1]{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-978ff7d1]{flex:1;min-width:0}.notification-title[data-v-978ff7d1]{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-978ff7d1]{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-978ff7d1]{font-size:11px;color:var(--color-text-tertiary);margin-top:4px}.notification-unread-dot[data-v-978ff7d1]{position:absolute;top:50%;right:12px;transform:translateY(-50%);width:8px;height:8px;background:var(--color-primary);border-radius:50%}.notification-footer[data-v-978ff7d1]{padding:12px 16px;text-align:center;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.notification-footer a[data-v-978ff7d1]{color:var(--color-primary);text-decoration:none;font-size:13px;font-weight:500}.notification-footer a[data-v-978ff7d1]:hover{text-decoration:underline}.desktop-layout[data-v-d07d0699]{display:none;min-height:100vh;background:var(--bg-secondary)}@media(min-width:1024px){.desktop-layout[data-v-d07d0699]{display:flex}}.desktop-content[data-v-d07d0699]{flex:1;margin-left:260px;display:flex;flex-direction:column;transition:margin-left .3s ease;min-height:100vh;background:var(--bg-secondary)}.desktop-sidebar.collapsed~.desktop-content[data-v-d07d0699]{margin-left:80px}.desktop-header[data-v-d07d0699]{background:var(--card-bg);border-bottom:1px solid var(--border-color);padding:20px 32px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.header-left[data-v-d07d0699]{flex:1}.page-title[data-v-d07d0699]{margin:0;font-size:24px;font-weight:600;color:var(--color-text-primary)}.header-right[data-v-d07d0699]{display:flex;gap:12px;align-items:center}.desktop-main[data-v-d07d0699]{flex:1;padding:32px;overflow-y:auto;background:var(--bg-secondary)}.desktop-main.no-padding[data-v-d07d0699]{padding:0}@media(min-width:1440px){.desktop-main[data-v-d07d0699]{padding:40px;max-width:1600px;margin:0 auto;width:100%}.desktop-main.no-padding[data-v-d07d0699]{padding:0;max-width:none}}.pwa-install-prompt[data-v-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);--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-tertiary: #f3f4f6;--bg-dark: #111827;--bg-overlay: rgba(0, 0, 0, .5);--border-color: #e5e7eb;--border-color-light: #f3f4f6;--border-color-dark: #d1d5db;--border-radius-sm: .375rem;--border-radius-md: .5rem;--border-radius-lg: .75rem;--border-radius-xl: 1rem;--border-radius-2xl: 1.5rem;--border-radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--btn-padding-sm: .5rem 1rem;--btn-padding-md: .75rem 1.5rem;--btn-padding-lg: 1rem 2rem;--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);--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-10: rgba(16, 185, 129, .1);--color-warning-alpha-10: rgba(245, 158, 11, .1);--color-danger-alpha-10: rgba(239, 68, 68, .1);--color-white-alpha-10: rgba(255, 255, 255, .1);--color-white-alpha-15: rgba(255, 255, 255, .15);--color-white-alpha-20: rgba(255, 255, 255, .2);--color-white-alpha-25: rgba(255, 255, 255, .25);--color-white-alpha-30: rgba(255, 255, 255, .3);--color-white-alpha-40: rgba(255, 255, 255, .4);--color-white-alpha-50: rgba(255, 255, 255, .5);--color-white-alpha-60: rgba(255, 255, 255, .6);--color-white-alpha-80: rgba(255, 255, 255, .8);--color-white-alpha-90: rgba(255, 255, 255, .9);--color-white: #ffffff;--color-black-alpha-10: rgba(0, 0, 0, .1);--color-black-alpha-15: rgba(0, 0, 0, .15);--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);--gradient-secondary: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-secondary-dark) 100%);--gradient-success: linear-gradient(135deg, var(--color-success) 0%, var(--color-success-dark) 100%);--gradient-warning: linear-gradient(135deg, var(--color-warning) 0%, var(--color-warning-dark) 100%);--gradient-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)}:root.dark{--bg-primary: #1f2937;--bg-secondary: #111827;--bg-tertiary: #374151;--bg-dark: #000000;--bg-overlay: rgba(0, 0, 0, .75);--color-text-primary: #f9fafb;--color-text-secondary: #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);--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;--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);--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:#fff}.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:#fff}.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:#fff}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark)}.btn-warning{background-color:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background-color:var(--color-warning-dark)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--color-danger-dark)}.btn-outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-text-primary)}.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-color: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-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}}
