body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.status-indicator{position:fixed;top:20px;right:20px;z-index:1000;max-width:300px}.status-item{background:rgba(0,0,0,.8);color:#fff;padding:12px 16px;border-radius:8px;margin-bottom:8px;display:flex;align-items:center;gap:8px;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);animation:slideIn .3s ease-out}.status-item.offline{background:rgba(255,87,87,.9)}.status-item.api-error{background:rgba(255,107,107,.9)}.status-item.token-warning{background:rgba(255,193,7,.9);color:#333}.status-icon{font-size:16px;flex-shrink:0}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.status-indicator{top:10px;right:10px;left:10px;max-width:none}.status-item{font-size:13px;padding:10px 14px}}form{display:flex;flex-direction:column;gap:12px;padding:10px}.form-btn{margin-left:30px;padding:8px 12px;border-radius:6px;border:1px solid rgb(209,213,219);background-color:#10b981;color:#fff;font-size:15px;cursor:pointer;transition:background .2s}.form-btn:hover{background-color:#059669}.form-btn:disabled{opacity:.7;cursor:not-allowed}.form-select{padding:8px 12px;border-radius:6px;border:1px solid rgb(209,213,219);font-size:15px;background-color:var(--card-bg);color:var(--text-primary)}.form-select:focus{border-color:#6366f1;outline:none}[data-theme=dark] .form-select{background-color:#374151;color:#f9fafb;border:1px solid #4b5563}[data-theme=dark] .form-select:focus{border-color:#6366f1}.validation-error{color:red;font-size:12px}.loading-btn{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:4px;border:none;background:#6366f1;color:#fff;font-size:15px;cursor:pointer;transition:background .2s}.loading-btn:hover:not(:disabled){background:#4f46e5}.loading-btn:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{margin-right:6px;vertical-align:middle;animation:spin 1s linear infinite}[data-theme=dark] .loading-btn{background:#6366f1;color:#fff}[data-theme=dark] .loading-btn:hover:not(:disabled){background:#4f46e5}[data-theme=dark] .loading-btn:disabled{background:#374151;color:#9ca3af}.toast{position:fixed;top:24px;right:24px;min-width:220px;max-width:340px;padding:14px 24px 14px 16px;border-radius:8px;color:#fff;font-size:16px;box-shadow:0 2px 12px #0000001f;z-index:99999;display:flex;align-items:center;gap:12px;animation:toast-in .3s}.toast-success{background:#43a047}.toast-error{background:#e74c3c}.toast-info{background:#6366f1}.toast-close{background:none;border:none;color:#fff;font-size:20px;margin-left:8px;cursor:pointer}[data-theme=dark] .toast{box-shadow:0 2px 12px #0000004d}[data-theme=dark] .toast-success{background:#10b981}[data-theme=dark] .toast-error{background:#ef4444}[data-theme=dark] .toast-info{background:#6366f1}@keyframes toast-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.user-context-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.user-context-modal{background:var(--card-bg, white);border-radius:12px;width:100%;max-width:750px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.user-context-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color, #e5e7eb)}.user-context-modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary, #1f2937)}.user-context-modal-close{background:none;border:none;color:var(--text-secondary, #6b7280);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.user-context-modal-close:hover:not(:disabled){background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #1f2937)}.user-context-modal-close:disabled{opacity:.5;cursor:not-allowed}.user-context-modal-content{padding:24px}.user-context-description{color:var(--text-secondary, #6b7280);font-size:14px;line-height:1.5;margin:0 0 24px;padding:12px;background:var(--bg-secondary, #f3f4f6);border-radius:8px;border-left:4px solid var(--client-primary, #6366f1)}.text-center{text-align:center}.user-context-form-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:24px}@media (min-width: 640px){.user-context-form-grid{grid-template-columns:1fr 1fr}}@media (min-width: 768px){.user-context-form-grid{grid-template-columns:1fr 1fr 1fr}}.user-context-field{display:flex;flex-direction:column;gap:6px}.user-context-field label{font-size:14px;font-weight:500;color:var(--text-primary, #1f2937)}.user-context-current{margin:5px 0;padding:10px;background:var(--bg-secondary, #f9fafb);border-radius:8px;border:1px solid var(--border-color, #e5e7eb)}.user-context-current h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary, #1f2937)}.current-context-info{display:flex;flex-direction:column;gap:8px}.context-item{display:flex;align-items:center;gap:8px;font-size:14px}.context-icon{width:20px;text-align:center}.context-label{font-weight:500;color:var(--text-secondary, #6b7280);min-width:70px}.context-value{font-weight:600;color:var(--text-primary, #1f2937)}.user-context-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color, #e5e7eb)}.btn-cancel{padding:8px 16px;background:var(--bg-secondary, #f3f4f6);color:var(--text-secondary, #6b7280);border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel:hover:not(:disabled){background:var(--border-color, #e5e7eb);color:var(--text-primary, #1f2937)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-primary{padding:8px 16px;background:var(--client-primary, #6366f1);color:#fff;border:1px solid var(--client-primary, #6366f1);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--client-primary-dark, #4f46e5);border-color:var(--client-primary-dark, #4f46e5)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.user-context-modal-overlay{padding:16px}.user-context-modal-header{padding:16px 20px}.user-context-modal-content{padding:20px}.user-context-modal-actions{flex-direction:column-reverse}.user-context-modal-actions button{width:100%;justify-content:center}}.navbar{position:fixed;top:0;left:0;right:0;height:64px;background:var(--client-primary, #6366f1);color:#fff;z-index:100;box-shadow:0 2px 4px #0000001a}.navbar-container{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:none;margin:0;padding:0 20px}.navbar-left{display:flex;align-items:center;gap:16px}.mobile-menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s ease}.mobile-menu-toggle:hover{background:rgba(255,255,255,.1)}.navbar-brand{display:flex;align-items:center;gap:12px}.navbar-logo{height:32px;width:auto;object-fit:contain}.navbar-title{font-size:18px;font-weight:600;color:#fff}.navbar-user{position:relative}.user-button{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:none;border-radius:8px;padding:8px 12px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:14px}.user-button:hover{background:rgba(255,255,255,.2)}.user-avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid rgba(255,255,255,.3)}.user-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--card-bg);border-radius:12px;box-shadow:0 8px 25px #00000026;border:1px solid var(--border-color);overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:12px}.user-avatar-large{width:48px;height:48px;border-radius:50%;background:var(--client-primary, #6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}.user-details{flex:1}.user-name-large{font-weight:600;color:var(--text-primary);font-size:14px;margin-bottom:2px}.user-email{color:var(--text-secondary);font-size:12px;margin-bottom:2px}.user-client{color:var(--text-secondary);font-size:11px;background:var(--border-color);padding:2px 6px;border-radius:4px;display:inline-block}.dropdown-divider{height:1px;background:var(--border-color);margin:0}.dropdown-items{padding:8px 0}.dropdown-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;text-align:left;color:var(--text-primary);font-size:14px;cursor:pointer;transition:background-color .2s ease;position:relative}.dropdown-item:hover:not(:disabled){background:var(--bg-secondary)}.dropdown-item:disabled{color:var(--text-secondary);cursor:not-allowed}.dropdown-item.logout{color:#dc2626}.dropdown-item.logout:hover{background:var(--error-bg)}.coming-soon{margin-left:auto;font-size:10px;background:#fbbf24;color:#fff;padding:2px 6px;border-radius:10px;font-weight:500}.dropdown-footer{padding:8px 12px;border-top:1px solid var(--border-color, #e5e7eb);background:var(--bg-secondary, #f8fafc);border-radius:0 0 8px 8px}.system-info{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-secondary, #6b7280)}.version-info{font-weight:600;color:var(--client-primary, #6366f1)}.build-info{font-size:10px;color:var(--text-tertiary, #9ca3af)}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:var(--card-bg);border-top:1px solid var(--border-color);box-shadow:0 4px 6px #0000001a;z-index:99;max-height:calc(100vh - 64px);overflow-y:auto}.mobile-menu-header{padding:16px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:space-between}.mobile-user-info{display:flex;align-items:center;gap:12px;flex:1}.mobile-menu-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.mobile-menu-close:hover{background:var(--border-color);color:var(--text-primary)}.mobile-user-avatar{width:40px;height:40px;border-radius:50%;background:#dadae8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.mobile-user-details{flex:1}.mobile-user-details.clickable{cursor:pointer;padding:4px 8px;border-radius:6px;transition:background-color .2s ease}.mobile-user-details.clickable:hover{background:rgba(0,0,0,.05)}.mobile-user-name{font-size:16px;font-weight:600;color:var(--text-primary)}.mobile-user-role{font-size:14px;color:var(--text-secondary)}.mobile-menu-divider{height:1px;background:var(--border-color)}.mobile-menu-nav{padding:8px 0}.mobile-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;color:var(--text-primary);font-size:16px;text-align:left;cursor:pointer;transition:background-color .2s ease;position:relative}.mobile-menu-item:hover:not(.disabled){background:var(--bg-secondary)}.mobile-menu-item.disabled{color:var(--text-secondary);cursor:not-allowed}.mobile-menu-item.has-children{font-weight:600}.mobile-menu-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.mobile-menu-label{flex:1;font-weight:500}.mobile-menu-arrow{width:16px;height:16px;flex-shrink:0;transition:transform .2s ease;color:var(--text-secondary)}.mobile-menu-arrow.expanded{transform:rotate(180deg)}.mobile-coming-soon{background:#fbbf24;color:#92400e;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.mobile-submenu{background:var(--bg-secondary);border-top:1px solid var(--border-color);animation:mobileSubmenuSlideDown .2s ease-out}@keyframes mobileSubmenuSlideDown{0%{max-height:0;opacity:0}to{max-height:300px;opacity:1}}.mobile-submenu-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 16px 10px 48px;background:none;border:none;color:var(--text-primary);font-size:15px;text-align:left;cursor:pointer;transition:background-color .2s ease;border-left:3px solid transparent}.mobile-submenu-item:hover:not(.disabled){background:var(--bg-primary);border-left-color:var(--client-primary, #6366f1)}.mobile-submenu-item.disabled{color:var(--text-secondary);cursor:not-allowed}.mobile-submenu-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:.8}.mobile-submenu-label{flex:1;font-weight:400}.mobile-menu-footer{padding:16px;background:var(--bg-secondary)}.mobile-client-info{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.mobile-client-id{font-size:14px;color:var(--text-secondary);font-weight:500}.mobile-version{font-size:13px;color:var(--client-primary, #6366f1);font-weight:600;background:var(--bg-primary-light, rgba(99, 102, 241, .1));padding:2px 6px;border-radius:4px}.mobile-env-badge{background:#10b981;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.mobile-build-info{display:flex;justify-content:center}.mobile-build{font-size:11px;color:var(--text-tertiary, #9ca3af);font-style:italic}@media (min-width: 769px){.mobile-menu{display:none}}@media (max-width: 768px){.mobile-menu-toggle{display:flex}.navbar-container{padding:0 16px}.navbar-title{font-size:16px}.user-name{display:none}.user-dropdown{width:260px}}@media (max-width: 480px){.navbar-title{font-size:14px}.user-dropdown{width:240px;right:-20px}}.system-info-modal{background-color:#fff;color:#111827;border:1px solid #e5e7eb}.system-info-modal .info-section{background-color:#f8fafc;color:#374151}.system-info-modal .build-info{color:#6b7280}.system-info-modal .environment-badge.development{background-color:#fef3c7;color:#92400e}.system-info-modal .environment-badge.production{background-color:#dcfce7;color:#166534}.system-info-modal .modal-actions{border-top:1px solid #e5e7eb}.system-info-modal .close-button{background:#6b7280;color:#fff}[data-theme=dark] .system-info-modal{background-color:#1f2937;color:#f9fafb;border:1px solid #374151}[data-theme=dark] .system-info-modal .info-section{background-color:#374151;color:#e5e7eb}[data-theme=dark] .system-info-modal .build-info{color:#9ca3af}[data-theme=dark] .system-info-modal .environment-badge.development{background-color:#451a03;color:#fbbf24}[data-theme=dark] .system-info-modal .environment-badge.production{background-color:#064e3b;color:#34d399}[data-theme=dark] .system-info-modal .modal-actions{border-top:1px solid #4b5563}[data-theme=dark] .system-info-modal .close-button{background:#4b5563;color:#fff}.sidebar{position:fixed;top:64px;left:0;height:calc(100vh - 64px);width:280px;background:var(--sidebar-bg);border-right:1px solid var(--border-color);transition:all .3s ease;z-index:50;display:flex;flex-direction:column;overflow:hidden}.sidebar.collapsed{width:64px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color);min-height:64px;gap:12px}.sidebar-user-header{display:flex;align-items:center;gap:12px;overflow:hidden;flex:1}.user-avatar-header{width:32px;height:32px;border-radius:50%;background:#dadae8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.user-info-header{overflow:hidden;flex:1}.user-info-header.clickable{cursor:pointer;padding:4px 8px;border-radius:6px;transition:background-color .2s ease}.user-info-header.clickable:hover{background:rgba(255,255,255,.1)}.user-name-header{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.user-role-header{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.sidebar-toggle{background:none;border:none;padding:8px;border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.nav-list{list-style:none;margin:0;padding:0}.nav-item{margin-bottom:2px}.nav-link{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;text-align:left;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);font-size:14px;border-radius:0;position:relative}.nav-link:hover:not(.disabled){background:var(--bg-secondary);color:var(--text-primary)}.nav-link.active{background:var(--client-primary, #6366f1);color:#fff}.nav-link.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--client-accent, #a78bfa)}.nav-link.disabled{opacity:.5;cursor:not-allowed}.nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.coming-soon-badge{background:#f59e0b;color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;font-weight:500;flex-shrink:0}[data-theme=dark] .coming-soon-badge{background:#fbbf24;color:#92400e}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.client-info-sidebar{display:flex;align-items:center;gap:8px}.client-badge{background:var(--client-primary, #6366f1);color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.client-id{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px;color:var(--bg-color);font-size:12px}.env-badge{background:#10b981;color:#fff;padding:4px 8px;border-radius:12px;font-size:10px;font-weight:600}.sidebar.collapsed .sidebar-footer{display:none}.sidebar.collapsed .sidebar-header{flex-direction:column;gap:8px;padding:12px 8px}.sidebar.collapsed .sidebar-user-header{justify-content:center;gap:0}.sidebar.collapsed .user-info-header{display:none}.sidebar.collapsed .nav-link{justify-content:center;padding:12px 8px;gap:0}.sidebar.collapsed .nav-label,.sidebar.collapsed .coming-soon-badge{display:none}.sidebar.collapsed .nav-icon{margin:0}.sidebar.collapsed .nav-link{position:relative}.sidebar.collapsed .nav-link:after{content:attr(title);position:absolute;left:100%;top:50%;transform:translateY(-50%);background:var(--card-bg);color:var(--text-primary);padding:6px 12px;border-radius:6px;border:1px solid var(--border-color);font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:1000;margin-left:8px;box-shadow:0 4px 6px #0000001a}.sidebar.collapsed .nav-link:hover:after{opacity:1;visibility:visible}.nav-submenu{list-style:none;margin:0 0 0 36px;padding:4px 0;border-left:2px solid var(--client-primary, #6366f1);background:var(--sidebar-bg, #f8fafc);border-radius:0 0 8px 8px;box-shadow:0 2px 8px #3c3c3c0a;transition:background .2s;max-height:500px;overflow:hidden}.nav-subitem{margin-bottom:2px}.nav-sublink{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px 10px 12px;background:none;border:none;text-align:left;cursor:pointer;color:var(--text-secondary);font-size:13px;border-radius:6px;position:relative;transition:background .2s,color .2s}.nav-sublink:hover:not(.disabled){background:var(--client-primary, #6366f1);color:#fff}.nav-sublink.active{background:var(--client-accent, #a78bfa);color:#fff}.nav-sublink.disabled{opacity:.5;cursor:not-allowed}.nav-submenu:before{content:"";display:block;height:6px}.submenu-arrow{margin-left:auto;transition:transform .2s;font-size:13px;color:var(--text-secondary);display:inline-block}.submenu-arrow.open{transform:rotate(90deg);color:var(--client-primary, #6366f1)}.nav-link.expanded{background:var(--bg-secondary);color:var(--client-primary, #6366f1)}.nav-submenu[style*="display: none"]{max-height:0;padding:0;border:none}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}:root{--login-bg-light: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--login-bg-dark: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);--login-card-bg-light: white;--login-card-bg-dark: #1e293b;--login-text-light: #1f2937;--login-text-dark: #f1f5f9;--login-border-light: #e5e7eb;--login-border-dark: #374151;--login-input-bg-light: white;--login-input-bg-dark: #334155;--login-input-text-light: #1f2937;--login-input-text-dark: #f1f5f9}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--login-bg-light);padding:1rem;transition:background .3s ease}.theme-dark .login-container{background:var(--login-bg-dark)}.login-card{background:var(--login-card-bg-light);border-radius:12px;padding:2rem;box-shadow:0 10px 25px #0003;width:100%;max-width:400px;animation:slideUp .3s ease-out;position:relative;transition:background-color .3s ease,color .3s ease;color:var(--login-text-light)}.theme-dark .login-card{background:var(--login-card-bg-dark);color:var(--login-text-dark);box-shadow:0 10px 25px #0006}.theme-toggle-login{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:1px solid var(--login-border-light);background:var(--login-card-bg-light);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:var(--login-text-light)}.theme-dark .theme-toggle-login{border-color:var(--login-border-dark);background:var(--login-card-bg-dark);color:var(--login-text-dark)}.theme-toggle-login:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000001a}.theme-dark .theme-toggle-login:hover{box-shadow:0 4px 12px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-logo{margin-bottom:1.5rem}.logo-image{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));transition:transform .3s ease}.logo-image:hover{transform:scale(1.05)}.login-header h2{color:var(--login-text-light);margin-bottom:.5rem;font-size:1.8rem;font-weight:600;transition:color .3s ease}.theme-dark .login-header h2{color:var(--login-text-dark)}.login-header p{color:var(--login-text-light);font-size:.9rem;opacity:.7;transition:color .3s ease}.theme-dark .login-header p{color:var(--login-text-dark)}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-weight:500;color:var(--login-text-light)!important;font-size:.9rem;transition:color .3s ease}.theme-dark .form-group label{color:var(--login-text-dark)!important}.field-hint{color:var(--login-text-light);font-size:.75rem;margin-top:.25rem;font-style:italic;opacity:.6;transition:color .3s ease}.theme-dark .field-hint{color:var(--login-text-dark)}.form-group input{padding:.75rem;border:2px solid var(--login-border-light);border-radius:8px;font-size:1rem;transition:all .3s ease;width:100%;background:var(--login-input-bg-light);color:var(--login-input-text-light)}.theme-dark .form-group input{border-color:var(--login-border-dark);background:var(--login-input-bg-dark);color:var(--login-input-text-dark)}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.theme-dark .form-group input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf633}.form-group input:disabled{background-color:var(--login-input-bg-light);opacity:.6;cursor:not-allowed}.theme-dark .form-group input:disabled{background-color:var(--login-input-bg-dark)}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{padding-right:3rem}.password-toggle-btn{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;border-radius:4px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none;color:var(--login-text-light)}.theme-dark .password-toggle-btn{color:var(--login-text-dark)}.password-toggle-btn:hover:not(:disabled){background-color:#0000000d}.theme-dark .password-toggle-btn:hover:not(:disabled){background-color:#ffffff1a}.password-toggle-btn:disabled{cursor:not-allowed;opacity:.5}.error-message{background-color:#fee;color:#c53030;padding:.75rem;border-radius:6px;border:1px solid #feb2b2;font-size:.9rem;text-align:center;transition:all .3s ease}.theme-dark .error-message{background-color:#4c1d1d;color:#fca5a5;border-color:#7f1d1d}.login-button{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:.875rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.theme-dark .login-button{background:linear-gradient(135deg,#8b5cf6 0%,#a855f7 100%)}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.theme-dark .login-button:hover:not(:disabled){box-shadow:0 4px 12px #8b5cf666}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{margin-top:1.5rem;text-align:center}.demo-info{font-size:.8rem;color:var(--login-text-light);background-color:#0000000d;padding:.75rem;border-radius:6px;border-left:4px solid #667eea;transition:all .3s ease;opacity:.8}.theme-dark .demo-info{color:var(--login-text-dark);background-color:#ffffff0d;border-left-color:#8b5cf6}.loading-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(93,100,111,.18);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.eedu-loading-logo{width:64px;height:64px;margin-bottom:1rem;animation:spin 1.2s linear infinite;display:block}.loading-spinner-text{font-size:1.1rem;color:var(--login-text-light);text-align:center;font-weight:500}.theme-dark .loading-spinner-text{color:var(--login-text-dark)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center}.modal-info{background:var(--login-card-bg-light, #fff);color:var(--login-text-light, #222);border-radius:12px;box-shadow:0 8px 32px #0000002e;padding:2rem 1.5rem 1.5rem;max-width:350px;width:90vw;position:relative;animation:slideUp .2s}.theme-dark .modal-info{background:var(--login-card-bg-dark, #1e293b);color:var(--login-text-dark, #f1f5f9)}.modal-close{position:absolute;top:.7rem;right:1rem;background:none;border:none;font-size:2rem;color:#888;cursor:pointer;transition:color .2s;z-index:10}.modal-close:hover{color:#e11d48}.modal-info h3{margin-top:0;margin-bottom:.5rem;font-size:1.3rem;font-weight:700}.modal-info h4{margin-bottom:.5rem;margin-top:1.2rem;font-size:1.05rem}.modal-info ul{padding-left:1.2em;margin:.5em 0}.modal-info ul li{margin-bottom:.3em;font-size:.98em}.modal-info a{color:#6366f1;text-decoration:underline;word-break:break-all}.theme-dark .modal-info a{color:#a5b4fc}@media (max-width: 480px){.login-container{padding:.5rem}.login-card{padding:1.5rem}.theme-toggle-login{top:.75rem;right:.75rem;width:36px;height:36px}.theme-toggle-login svg{width:18px;height:18px}}.entendido-button{background-color:var(--button-bg, #f0f0f0);color:var(--button-text-color, #333);border:none;padding:10px 20px;border-radius:4px;cursor:pointer;transition:background-color .3s ease}.entendido-button:hover{background-color:var(--button-hover-bg, #e0e0e0)}.changelog-pagination{display:flex;align-items:center;padding:1rem;margin-top:2rem}.changelog-pagination button{background:var(--button-bg, #f0f0f0);border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background .3s ease}.changelog-pagination button:hover{background:var(--button-hover-bg, #e0e0e0)}.dashboard-container{min-height:100vh;background-color:var(--bg-color);color:var(--text-color)}.dashboard-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-700) 100%);color:#fff;padding:1.5rem 0;box-shadow:0 2px 10px #0000001a}.header-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1rem}.header-logo{width:40px;height:40px;object-fit:contain;filter:brightness(0) invert(1)}.header-content h1{margin:0;font-size:2rem;font-weight:600}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{font-size:1rem;opacity:.9}.logout-button{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:rgba(255,255,255,.3);transform:translateY(-1px)}.dashboard-main{max-width:1200px;margin:0 auto;padding:2rem 1rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.dashboard-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000000d;border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease;color:var(--text-color)}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 8px 15px #0000001a}.dashboard-card h2,.dashboard-card h3{margin-top:0;color:var(--text-primary)}.dashboard-card h2{font-size:1.5rem;margin-bottom:1rem}.dashboard-card h3{font-size:1.2rem;margin-bottom:1rem;color:var(--primary-color)}.welcome-card{grid-column:span 2;background:linear-gradient(135deg,rgba(102,126,234,.08) 0%,rgba(118,75,162,.08) 100%);border-left:4px solid var(--primary-color)}[data-theme=dark] .welcome-card{background:linear-gradient(135deg,rgba(99,102,241,.15) 0%,rgba(139,92,246,.15) 100%)}.user-details{margin-top:1rem;padding:1rem;background-color:var(--bg-secondary);border-radius:8px}.user-details p{margin:.5rem 0;color:var(--text-secondary)}.admin-badge{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.token-card{border-left:4px solid #28a745}.token-info .token-status{color:#28a745;font-weight:600;margin-bottom:1rem;display:block}.token-details{margin:1rem 0;padding:1rem;background-color:#667eea1a;border-radius:8px;border-left:4px solid #667eea}.token-details p{margin:.5rem 0;font-size:.9rem}.auto-refresh-notice{color:#17a2b8!important;font-weight:600;background-color:#17a2b81a;padding:.5rem;border-radius:6px;border:1px solid rgba(23,162,184,.3)}.token-expired{color:#dc3545!important;font-weight:600;background-color:#dc35451a;padding:.5rem;border-radius:6px;border:1px solid rgba(220,53,69,.3)}.token-preview{background-color:var(--bg-secondary);padding:.75rem;border-radius:6px;font-family:Courier New,monospace;word-break:break-all;color:var(--text-secondary)}.branch-card{border-left:4px solid var(--primary-color)}.branch-card.clickable{cursor:pointer;transition:all .2s ease;position:relative}.branch-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-left-color:var(--client-primary, #6366f1)}.branch-card.clickable:active{transform:translateY(0)}.branch-card.clickable:after{content:"⚙️";position:absolute;top:12px;right:12px;font-size:14px;opacity:0;transition:opacity .2s ease}.branch-card.clickable:hover:after{opacity:1}.branch-card h3{text-shadow:1px 1px 2px rgba(0,0,0,.1)}.branch-info{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.dashboard-card.branch-details{padding:1rem;background-color:#17a2b81a;border-radius:8px}.dashboard-card.branch-details p{margin:.5rem 0;font-size:.9rem}.type-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.7rem;font-weight:500;margin-top:.25rem}.type-badge.user{background-color:#1976d21a;color:#1976d2}.type-badge.course{background-color:#2e7d321a;color:#2e7d32}.type-badge.report{background-color:#f57c001a;color:#f57c00}[data-theme=dark] .type-badge.user{background-color:#6366f133;color:#818cf8}[data-theme=dark] .type-badge.course{background-color:#10b98133;color:#34d399}[data-theme=dark] .type-badge.report{background-color:#fbbf2433;color:#fbbf24}.no-data{text-align:center;padding:2rem;color:var(--text-secondary)}.no-data p{margin:0 0 .5rem;font-size:1rem}.no-data small{color:var(--text-secondary);font-size:.8rem}.stats-card{border-left:4px solid #ffc107}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:1rem}.stat-item{text-align:center;padding:1rem 0}.stat-number{display:block;font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.25rem}.stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.loading,.error{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}.error{color:var(--error-color)}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.header-left{flex-direction:column;gap:.5rem}.header-logo{width:32px;height:32px}.user-info{flex-direction:column;gap:.5rem}.dashboard-grid{grid-template-columns:1fr}.welcome-card{grid-column:span 1}.dashboard-main{padding:1rem}.header-content h1{font-size:1.5rem}}@media (max-width: 480px){.dashboard-card{padding:1rem}.stats-grid{grid-template-columns:1fr}}.user-profile{padding:2rem;max-width:1200px;margin:0 auto;background:var(--bg-color);min-height:calc(100vh - 80px)}.profile-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;background:var(--card-bg);padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color)}.profile-title h1{margin:0;color:var(--text-primary);font-size:2rem;font-weight:700}.profile-title p{margin:.5rem 0 0;color:var(--text-secondary);font-size:1rem}.profile-avatar{flex-shrink:0}.avatar-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700;text-transform:uppercase}.profile-content{background:var(--card-bg);border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color);overflow:hidden}.profile-tabs{display:flex;border-bottom:1px solid var(--border-color)}.tab-button{flex:1;padding:1rem 1.5rem;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem;justify-content:center;transition:all .2s ease;border-bottom:3px solid transparent}.tab-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:var(--primary-bg)}.tab-content{padding:2rem}.section-header h2{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem;font-weight:600}.section-header p{margin:0;color:var(--text-secondary);font-size:.95rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.info-item{padding:1.5rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.info-item label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.025em}.info-value{font-size:1rem;color:var(--text-primary);font-weight:500}.user-type{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.user-type.admin{background:var(--warning-bg);color:var(--warning-color)}.user-type.user{background:rgba(59,130,246,.1);color:#1e40af}[data-theme=dark] .user-type.user{background:rgba(96,165,250,.2);color:#60a5fa}.security-section{max-width:600px}.message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:flex-start;gap:.75rem}.message.success{background:var(--success-bg);border:1px solid var(--success-color);color:var(--success-color)}.message.error{background:var(--error-bg);border:1px solid var(--error-color);color:var(--error-color)}.password-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.password-input-group{position:relative;display:flex;align-items:center}.password-input-group input{width:100%;padding:.75rem 3rem .75rem 1rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;background:var(--card-bg);color:var(--text-primary);transition:border-color .2s ease,box-shadow .2s ease}.password-input-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.password-input-group input.error{border-color:var(--error-color)}.password-input-group input.error:focus{border-color:var(--error-color);box-shadow:0 0 0 3px #ef44441a}.password-input-group input:disabled{background:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.25rem;border-radius:4px;transition:color .2s ease}.password-toggle:hover{color:var(--text-primary)}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.password-hint{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem}.password-requirements{padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;margin-top:.5rem}.requirement-title{font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:.8rem}.requirements-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:.25rem}.requirements-list li{display:flex;align-items:center;font-size:.75rem;color:var(--text-secondary);position:relative;padding-left:1.2rem}.requirements-list li:before{content:"✗";position:absolute;left:0;color:var(--error-color);font-weight:700}.requirements-list li.valid{color:var(--success-color)}.requirements-list li.valid:before{content:"✓";color:var(--success-color)}.error-message{font-size:.75rem;color:var(--error-color);margin-top:.25rem;font-weight:500}.form-actions{margin-top:1rem;display:flex;justify-content:flex-start}.btn-primary{padding:.75rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.btn-primary:hover:not(:disabled){background:var(--color-primary-600, #4338ca);transform:translateY(-1px)}.btn-primary:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none}.loading-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.user-profile{padding:1rem}.profile-header{flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.profile-title h1{font-size:1.5rem}.avatar-circle{width:60px;height:60px;font-size:1.5rem}.tab-content{padding:1.5rem}.info-grid{grid-template-columns:1fr;gap:1rem}.info-item{padding:1rem}.tab-button{padding:.75rem 1rem;font-size:.875rem}.tab-button svg{width:16px;height:16px}}@media (max-width: 480px){.profile-tabs{flex-direction:column}.tab-button{justify-content:flex-start;padding:1rem 1.5rem}.tab-button.active{border-bottom:none;border-left:3px solid var(--primary-color)}.password-input-group input{padding-right:2.5rem}.password-toggle{right:.5rem}.requirements-list{grid-template-columns:1fr}}@media (max-width: 768px){.session-header{flex-direction:column;align-items:flex-start;gap:.5rem}.session-badges{align-self:stretch}.info-row{flex-direction:column;align-items:flex-start;gap:.25rem}.info-label{min-width:auto;font-size:.875rem}.info-value{text-align:left;font-size:.875rem;padding-left:1rem}.session-item{flex-direction:column;gap:1rem}.session-actions{flex-direction:row;justify-content:flex-end}}@media (max-width: 480px){.profile-tabs{flex-direction:column}.tab-button{justify-content:flex-start;padding:.75rem 1rem}.tab-content{padding:1rem}.session-badges{flex-direction:column;gap:.25rem}.session-badges>*{align-self:flex-start}}.sessions-section{max-width:800px}.sessions-actions{display:flex;gap:1rem;margin-bottom:2rem;align-items:center}.btn-secondary{padding:.5rem 1rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover:not(:disabled){background:var(--border-color);transform:translateY(-1px)}.btn-danger{padding:.5rem 1rem;background:var(--error-color);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-danger:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none}.sessions-list{display:flex;flex-direction:column;gap:1rem}.session-item{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.session-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.session-item.current{border-color:var(--primary-color);background:var(--primary-bg)}.session-item.expired{opacity:.7;background:var(--bg-secondary)}.session-icon{font-size:2rem;flex-shrink:0;margin-top:.25rem}.session-details{flex:1}.session-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.session-header h4{margin:0;color:var(--text-primary);font-size:1rem;font-weight:600}.session-badges{display:flex;gap:.5rem;flex-wrap:wrap}.current-badge{background:var(--success-color);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.expired-badge{background:var(--text-secondary);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.mobile-badge{background:var(--primary-color);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.bot-badge{background:var(--warning-color);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.session-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;border-bottom:1px solid var(--border-color)}.info-row:last-child{border-bottom:none}.info-label{font-weight:500;color:var(--text-secondary);min-width:120px}.info-value{color:var(--text-primary);text-align:right;word-break:break-word}.session-info p{margin:0;font-size:.875rem;color:var(--text-secondary)}.session-info strong{color:var(--text-primary)}.session-token{margin-top:.5rem}.session-token small{font-family:Courier New,monospace;background:var(--card-bg);padding:.25rem .5rem;border-radius:4px;border:1px solid var(--border-color);color:var(--text-secondary);word-break:break-all}.session-actions{flex-shrink:0;display:flex;flex-direction:column;gap:.5rem}.btn-danger-small{padding:.375rem .75rem;background:var(--error-color);color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-danger-small:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-danger-small:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none}.no-sessions{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.no-sessions p{margin:0 0 .5rem;font-size:1rem;color:var(--text-primary)}.no-sessions small{color:var(--text-secondary);font-size:.875rem}.no-sessions.error{border:1px solid var(--error-color);background:var(--error-bg, rgba(239, 68, 68, .1))}.no-sessions.error p{color:var(--error-color);font-weight:500}.no-sessions.error small{color:var(--text-secondary);margin-bottom:.5rem;display:block}.no-sessions.error .btn-secondary{background:var(--error-color);color:#fff;border:none;font-size:.875rem;padding:.5rem 1rem}.no-sessions.error .btn-secondary:hover{background:#dc2626}@media (max-width: 768px){.sessions-actions{flex-direction:column;align-items:stretch}.session-item{flex-direction:column;gap:1rem}.session-icon{align-self:flex-start}.session-info{grid-template-columns:1fr}.session-actions{flex-direction:row;justify-content:flex-end}}.logs-list{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.log-item{background:var(--card-bg);border-radius:8px;padding:1rem 1.5rem;box-shadow:0 1px 2px #0000000a;border:1px solid var(--border-color);font-size:1rem;transition:box-shadow .2s}.log-header{display:flex;gap:1.5rem;align-items:center;font-size:.95em;margin-bottom:.3em}.log-level{font-weight:700;color:#4f46e5;text-transform:uppercase;letter-spacing:.04em}.log-date{color:#888;font-size:.93em}.log-module{color:#0ea5e9;font-size:.93em}.log-message{margin-bottom:.2em;color:var(--text-primary)}.log-meta{font-size:.92em;color:#888;display:flex;gap:1.5em}.log-info{border-left:4px solid #4f46e5}.log-error{border-left:4px solid #ef4444}.log-warning{border-left:4px solid #f59e42}.log-debug{border-left:4px solid #22d3ee}.no-logs{margin-top:2rem;text-align:center;color:#888}.user-settings{padding:2rem;max-width:1200px;margin:0 auto;background:var(--bg-color, #f8fafc);min-height:calc(100vh - 80px);color:var(--text-color, #1e293b)}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;background:var(--card-bg, white);padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.settings-title h1{margin:0;color:var(--text-primary, #1e293b);font-size:2rem;font-weight:700}.settings-title p{margin:.5rem 0 0;color:var(--text-secondary, #64748b);font-size:1rem}.settings-icon{flex-shrink:0;color:var(--primary-color, #4f46e5)}.settings-content{display:flex;flex-direction:column;gap:2rem}.message{padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem;background:var(--success-bg);border:1px solid var(--success-color);color:var(--success-color)}.message-content{display:flex;align-items:center;gap:.5rem;font-weight:500}.settings-section{background:var(--card-bg, white);border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.section-header{margin-bottom:2rem}.section-header h2{margin:0 0 .5rem;color:var(--text-primary, #1e293b);font-size:1.5rem;font-weight:600}.section-header p{margin:0;color:var(--text-secondary, #64748b);font-size:.95rem}.theme-selector h3{margin:0 0 .5rem;color:var(--text-primary, #1e293b);font-size:1.25rem;font-weight:600}.theme-description{margin:0 0 2rem;color:var(--text-secondary, #64748b);font-size:.9rem;line-height:1.5}.theme-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.theme-option{border:2px solid var(--border-color, #e2e8f0);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s ease;background:var(--card-bg, white);position:relative}.theme-option:hover{border-color:var(--primary-color, #4f46e5);transform:translateY(-2px);box-shadow:0 4px 12px #4f46e526}.theme-option.active{border-color:var(--primary-color, #4f46e5);background:var(--primary-bg, #faf5ff)}.theme-preview{width:100%;height:120px;border-radius:8px;margin-bottom:1rem;overflow:hidden;border:1px solid #e2e8f0}.light-preview{background:#ffffff}.light-preview .preview-header{height:20px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.light-preview .preview-content{display:flex;height:calc(100% - 20px)}.light-preview .preview-sidebar{width:40px;background:#f1f5f9;border-right:1px solid #e2e8f0}.light-preview .preview-main{flex:1;background:#ffffff}.dark-preview{background:#1e293b}.dark-preview .preview-header{height:20px;background:#334155;border-bottom:1px solid #475569}.dark-preview .preview-content{display:flex;height:calc(100% - 20px)}.dark-preview .preview-sidebar{width:40px;background:#0f172a;border-right:1px solid #475569}.dark-preview .preview-main{flex:1;background:#1e293b}.system-preview{background:linear-gradient(90deg,#ffffff 50%,#1e293b 50%)}.system-preview .preview-header{height:20px;background:linear-gradient(90deg,#f8fafc 50%,#334155 50%);border-bottom:1px solid #94a3b8}.system-preview .preview-content{display:flex;height:calc(100% - 20px)}.system-preview .preview-sidebar{width:40px;background:linear-gradient(90deg,#f1f5f9 50%,#0f172a 50%);border-right:1px solid #94a3b8}.system-preview .preview-main{flex:1;background:linear-gradient(90deg,#ffffff 50%,#1e293b 50%)}.theme-info{display:flex;align-items:center;gap:1rem}.theme-icon{flex-shrink:0;color:var(--text-secondary, #64748b)}.theme-details{flex:1}.theme-name{font-weight:600;color:var(--text-primary, #1e293b);margin-bottom:.25rem}.theme-desc{font-size:.875rem;color:var(--text-secondary, #64748b);line-height:1.4}.current-system{display:block;font-size:.75rem;color:var(--primary-color, #4f46e5);margin-top:.25rem}.theme-check{position:absolute;top:1rem;right:1rem;color:var(--primary-color, #4f46e5);background:var(--card-bg, white);border-radius:50%;padding:.25rem;box-shadow:0 2px 4px #0000001a}.user-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{padding:1.5rem;background:var(--bg-secondary, #f8fafc);border-radius:8px;border:1px solid var(--border-color, #e2e8f0)}.info-item label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary, #475569);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.025em}.info-value{font-size:1rem;color:var(--text-primary, #1e293b);font-weight:500}.user-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.user-badge.admin{background:var(--warning-bg);color:var(--warning-color)}.user-badge.user{background:rgba(59,130,246,.1);color:#1e40af}.theme-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;background:var(--primary-bg, #e0e7ff);color:var(--primary-color, #4f46e5)}[data-theme=dark]{--bg-color: #0f172a;--card-bg: #1e293b;--bg-secondary: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-color: #f1f5f9;--border-color: #475569;--primary-color: #6366f1;--primary-bg: #312e81}[data-theme=dark] .theme-option{background:var(--card-bg)}[data-theme=dark] .theme-option.active{background:var(--primary-bg)}[data-theme=dark] .theme-check{background:var(--card-bg)}[data-theme=dark] .user-badge.admin{background:var(--warning-bg);color:var(--warning-color)}[data-theme=dark] .user-badge.user{background:rgba(96,165,250,.2);color:#60a5fa}[data-theme=light]{--bg-color: #f8fafc;--card-bg: #ffffff;--bg-secondary: #f8fafc;--text-primary: #1e293b;--text-secondary: #64748b;--text-color: #1e293b;--border-color: #e2e8f0;--primary-color: #4f46e5;--primary-bg: #faf5ff}@media (max-width: 768px){.user-settings{padding:1rem}.settings-header{flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.settings-title h1{font-size:1.5rem}.settings-section{padding:1.5rem}.theme-options{grid-template-columns:1fr}.user-info-grid{grid-template-columns:1fr;gap:1rem}.info-item{padding:1rem}}@media (max-width: 480px){.theme-info{flex-direction:column;align-items:flex-start;text-align:left}.theme-preview{height:80px}}.settings-users-page{padding:2rem 1rem;max-width:1200px;margin:0 auto}.settings-users-page h2{margin-bottom:1.5rem}.error-msg{color:#fff;background:#e74c3c;padding:.75rem 1.25rem;border-radius:4px;margin-bottom:1rem}.role-badge{display:inline-block;padding:.2em .7em;border-radius:1em;font-size:.95em;color:#fff;background:#888;text-transform:capitalize}.role-admin{background:#2d8cf0}.role-cashier{background:#67c23a}.role-user{background:#f39c12}.actions-cell{position:relative}.actions-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;transition:background .2s}.actions-btn:hover{background:#f3f4f6}.actions-dropdown{position:fixed!important;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:9999;min-width:140px;padding:4px 0;animation:fadeIn .18s}.dropdown-item{width:100%;padding:10px 18px;background:none;border:none;text-align:left;font-size:15px;color:#222;cursor:pointer;border-radius:0;transition:background .15s,color .15s}.dropdown-item:hover{background:#f3f4f6;color:var(--client-primary, #6366f1)}.dropdown-item:last-child{color:#e74c3c}.dropdown-item:last-child:hover{background:#fdecea;color:#c0392b}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.table{border-collapse:collapse;width:100%}.table th{font-weight:600;text-align:left;color:#374151}.table td{color:#4b5563}.table th,.table td{padding:8px 12px;border-bottom:1px solid #e5e7eb}.table-hover tbody tr:hover{background:#f3f4f6!important;transition:background .2s;cursor:pointer}.table-striped tbody tr:nth-child(odd){background:#fafbfc}.table-striped tbody tr:nth-child(2n){background:#fff}.export-actions-container{display:flex;gap:8px}.button-export{padding:8px 16px;border:none;border-radius:4px;background-color:#d0d0d4;color:#3f3b3b;font-size:14px;cursor:pointer;transition:background-color .2s ease}.button-export:hover{background-color:#93929c}.button-export:disabled{background-color:#d0d0d3;color:#939090;cursor:not-allowed}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa}.App{min-height:100vh}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa}.loading-spinner{font-size:1.2rem;color:#667eea;font-weight:500}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;margin-top:64px;margin-left:280px;padding:20px;background-color:#f8f9fa;min-height:calc(100vh - 64px);transition:margin-left .3s ease}.main-content.sidebar-collapsed{margin-left:64px}.actions-bar{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}@media (max-width: 768px){.main-content,.main-content.sidebar-collapsed{margin-left:0}}@media (max-width: 768px){body{font-size:14px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in-out}.actions-dropdown{background:white;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:4px 0;min-width:180px}.dropdown-item{width:100%;padding:8px 16px;border:none;background:none;text-align:left;cursor:pointer;font-size:14px;color:#374151;display:flex;align-items:center;gap:8px}.dropdown-item:hover{background-color:#f3f4f6;color:#111827}.dropdown-item:active{background-color:#e5e7eb}[data-theme=dark] .actions-dropdown{background:#374151;border:1px solid #4b5563}[data-theme=dark] .dropdown-item{color:#f9fafb}[data-theme=dark] .dropdown-item:hover{background-color:#4b5563;color:#fff}[data-theme=dark] .dropdown-item:active{background-color:#6b7280}.context-info{margin-bottom:16px;padding:8px 12px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#64748b;display:flex;align-items:center;gap:16px;flex-wrap:wrap}[data-theme=dark] .context-info{background-color:#374151;border:1px solid #4b5563;color:#9ca3af}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.18);z-index:10000;display:flex;align-items:center;justify-content:center}.modal-content{background:#ffffff;border-radius:10px;box-shadow:0 8px 32px #0000002e;padding:2rem 1.5rem 1.5rem;min-width:320px;max-width:95vw;position:relative;animation:fadeInModal .18s ease-out;color:#111827}.modal-content h3{margin-top:0;margin-bottom:.5rem;color:inherit}.modal-content textarea{font-size:15px;resize:vertical;background:#ffffff;color:#111827;border:1px solid #d1d5db}.modal-content input{background:#ffffff;color:#111827;border:1px solid #d1d5db}.modal-content input[disabled]{background:#f3f4f6;color:#888;cursor:not-allowed}.modal-content select{background:#ffffff;color:#111827;border:1px solid #d1d5db}.modal-content label{color:inherit}[data-theme=dark] .modal-overlay{background:rgba(0,0,0,.4)}[data-theme=dark] .modal-content{background:#1f2937;color:#f9fafb;border:1px solid #374151}[data-theme=dark] .modal-content textarea,[data-theme=dark] .modal-content input{background:#374151;color:#f9fafb;border:1px solid #4b5563}[data-theme=dark] .modal-content input[disabled]{background:#2d3748;color:#6b7280}[data-theme=dark] .modal-content select{background:#374151;color:#f9fafb;border:1px solid #4b5563}[data-theme=dark] .modal-content input:focus,[data-theme=dark] .modal-content select:focus,[data-theme=dark] .modal-content textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}[data-theme=dark] .modal-content .form-section{background:#374151!important;border:1px solid #4b5563!important}[data-theme=dark] .modal-content .form-section-info{background:#1f2937!important;border:1px solid #374151!important}[data-theme=dark] .modal-content .form-section-blue{background:#1e3a8a!important;border:1px solid #1d4ed8!important}[data-theme=dark] .modal-content .month-checkbox{background:#374151!important;border:1px solid #4b5563!important}[data-theme=dark] .modal-content .month-checkbox.selected{background:#1e40af!important;border:1px solid #2563eb!important}[data-theme=dark] .modal-content .summary-section{background:#374151!important;border:1px solid #4b5563!important;color:#f9fafb!important}[data-theme=dark] .modal-content button{background:#374151;color:#f9fafb;border:1px solid #4b5563}[data-theme=dark] .modal-content button:hover{background:#4b5563}[data-theme=dark] .modal-content button[type=submit]{background:#6366f1;color:#fff;border:1px solid #6366f1}[data-theme=dark] .modal-content button[type=submit]:hover{background:#4f46e5}[data-theme=dark] .rdt_Table{background-color:#1f2937}[data-theme=dark] .rdt_TableHead{background-color:#374151;border-bottom:1px solid #4b5563}[data-theme=dark] .rdt_TableHeadRow{background-color:#374151;color:#f9fafb;border-bottom:1px solid #4b5563}[data-theme=dark] .rdt_TableBody{background-color:#1f2937}[data-theme=dark] .rdt_TableRow{background-color:#1f2937;border-bottom:1px solid #374151;color:#f9fafb}[data-theme=dark] .rdt_TableRow:hover{background-color:#374151}[data-theme=dark] .rdt_TableCell{color:#f9fafb}[data-theme=dark] .rdt_Pagination{background-color:#1f2937;border-top:1px solid #374151;color:#f9fafb}[data-theme=dark] .rdt_Pagination button{background-color:#374151;color:#f9fafb;border:1px solid #4b5563}[data-theme=dark] .rdt_Pagination button:hover{background-color:#4b5563}[data-theme=dark] .rdt_Pagination button:disabled{background-color:#2d3748;color:#6b7280}@keyframes fadeInModal{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}:root{--client-primary: #6366f1;--client-secondary: #8b5cf6;--client-accent: #a78bfa;--color-primary: var(--client-primary);--color-secondary: var(--client-secondary);--color-accent: var(--client-accent);--color-primary-50: color-mix(in srgb, var(--client-primary) 5%, transparent);--color-primary-100: color-mix(in srgb, var(--client-primary) 10%, transparent);--color-primary-200: color-mix(in srgb, var(--client-primary) 20%, transparent);--color-primary-500: var(--client-primary);--color-primary-600: color-mix(in srgb, var(--client-primary) 90%, black);--color-primary-700: color-mix(in srgb, var(--client-primary) 80%, black);--color-primary-800: color-mix(in srgb, var(--client-primary) 70%, black);--color-primary-900: color-mix(in srgb, var(--client-primary) 60%, black);--bg-color: #f8fafc;--card-bg: #ffffff;--sidebar-bg: #f3f4f6;--bg-secondary: #f4f4f4;--text-primary: #1e293b;--text-secondary: #64748b;--text-color: #1e293b;--border-color: #e2e8f0;--primary-color: var(--client-primary, #4f46e5);--primary-bg: #faf5ff;--success-color: #059669;--success-bg: #f0fdf4;--error-color: #dc2626;--error-bg: #fef2f2;--warning-color: #d97706;--warning-bg: #fffbeb}.bg-primary{background-color:var(--color-primary)}.bg-primary-50{background-color:var(--color-primary-50)}.bg-primary-100{background-color:var(--color-primary-100)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.border-primary{border-color:var(--color-primary)}.hover\:bg-primary:hover{background-color:var(--color-primary)}.hover\:text-primary:hover{color:var(--color-primary)}.btn-primary{background-color:var(--color-primary);color:#fff;border:1px solid var(--color-primary);transition:all .2s ease}.btn-primary:hover{background-color:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-secondary{background-color:transparent;color:var(--color-primary);border:1px solid var(--color-primary);transition:all .2s ease}.btn-secondary:hover{background-color:var(--color-primary-50)}*{transition:background-color .2s ease,color .2s ease,border-color .2s ease}[data-theme=dark]{--bg-color: #0f172a;--card-bg: #1e293b;--sidebar-bg: #1e293b;--bg-secondary: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-color: #f1f5f9;--border-color: #475569;--primary-color: var(--client-primary, #6366f1);--primary-bg: #312e81;--success-color: #10b981;--success-bg: #064e3b;--error-color: #ef4444;--error-bg: #7f1d1d;--warning-color: #f59e0b;--warning-bg: #78350f}[data-theme=light]{--bg-color: #f8fafc;--card-bg: #ffffff;--sidebar-bg: #f3f4f6;--bg-secondary: #f4f4f4;--text-primary: #1e293b;--text-secondary: #64748b;--text-color: #1e293b;--border-color: #e2e8f0;--primary-color: var(--client-primary, #4f46e5);--primary-bg: #faf5ff;--success-color: #059669;--success-bg: #f0fdf4;--error-color: #dc2626;--error-bg: #fef2f2;--warning-color: #d97706;--warning-bg: #fffbeb}body{background-color:var(--bg-color);color:var(--text-color);transition:background-color .3s ease,color .3s ease}.navbar{border-bottom:1px solid var(--border-color)}.navbar .user-dropdown-menu{border:1px solid var(--border-color);color:var(--text-color)}.navbar .dropdown-item{color:var(--text-primary)}.navbar .dropdown-item:hover{background-color:var(--bg-secondary)}.sidebar{border-right:1px solid var(--border-color)}.sidebar-item{color:var(--text-secondary)}.sidebar-item:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.sidebar-item.active{background-color:var(--primary-bg);color:var(--primary-color)}.main-content{background-color:var(--bg-color);color:var(--text-color)}input,select,textarea{background-color:var(--card-bg);border:1px solid var(--border-color);color:var(--text-primary)}input:focus,select:focus,textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{box-shadow:0 0 0 3px #6366f11a}.message.success{background-color:var(--success-bg);color:var(--success-color);border-color:var(--success-color)}.message.error{background-color:var(--error-bg);color:var(--error-color);border-color:var(--error-color)}.message.warning{background-color:var(--warning-bg);color:var(--warning-color);border-color:var(--warning-color)}
