.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--surface-1);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-normal);overflow:hidden;border-right:1px solid var(--border)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:0 20px;height:var(--header-height);border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo{width:36px;height:36px;background:var(--purple-base);box-shadow:var(--purple-glow);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0;transition:all var(--transition-fast)}.sidebar.collapsed .sidebar-logo:hover{transform:scale(1.05);filter:brightness(1.1)}.sidebar.collapsed .sidebar-brand{padding:0;justify-content:center}.sidebar-brand-text{display:flex;flex-direction:column;overflow:hidden;white-space:nowrap}.sidebar-brand-name{font-size:17px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-brand-tagline{font-size:11px;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.sidebar.collapsed .sidebar-brand-text{display:none}.sidebar-toggle{position:absolute;top:22px;right:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);font-size:16px}.sidebar-toggle:hover{background:var(--border-light);color:var(--text-primary)}.sidebar.collapsed .sidebar-toggle{right:50%;transform:translate(50%)}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;position:relative}.sidebar-nav-item:hover{background:var(--border-light);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--purple-base);color:#fff;box-shadow:0 4px 12px #5d5fef33}.sidebar-nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:24px;background:var(--purple-base);border-radius:0 4px 4px 0}.sidebar-nav-icon{font-size:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px}.sidebar-nav-label{overflow:hidden;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar-nav-label{opacity:0;width:0}.sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-nav-item.active:before{left:-12px}.sidebar-nav-item.has-submenu{justify-content:space-between}.sidebar-submenu{display:flex;flex-direction:column;gap:4px;margin-top:4px;margin-bottom:8px;padding-left:12px}.sidebar.collapsed .sidebar-submenu{display:none}.sidebar-nav-item.submenu-item{padding:8px 12px;font-size:13px;border-left:1px solid var(--border-light);border-radius:0 4px 4px 0;margin-left:12px}.sidebar-nav-item.submenu-item.depth-2{margin-left:24px}.sidebar-nav-item.submenu-item.active{border-left:2px solid var(--purple-base);background:var(--bg-secondary);color:var(--purple-base);box-shadow:none}.sidebar-nav-item.submenu-item.active:before{display:none}.submenu-toggle{display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast)}.submenu-toggle.open{transform:rotate(90deg)}.sidebar-footer{padding:16px;border-top:1px solid var(--border-light)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);transition:background var(--transition-fast);cursor:pointer}.sidebar-user:hover{background:var(--border-light)}.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--purple-base),var(--purple-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0;box-shadow:0 4px 8px #5d5fef33}.sidebar-user-info{overflow:hidden;white-space:nowrap}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text-primary)}.sidebar-user-role{font-size:11px;color:var(--text-muted)}.sidebar.collapsed .sidebar-user-info,.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open+.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}.sidebar.collapsed .sidebar-nav-label{opacity:1;width:auto}.sidebar.collapsed .sidebar-brand-text{display:flex}.sidebar.collapsed .sidebar-user-info{display:block}}apps-fileview.texmex_202603050_p0 Sidebar.css Displaying Sidebar.css. .tally-status-popup-fixed{position:absolute!important;top:calc(100% + 8px)!important;right:0!important;width:480px;max-width:90vw;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 48px #00000040;z-index:1001;overflow:hidden;display:flex;flex-direction:column;animation:tallySlideUp .25s ease}@keyframes tallySlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tally-popup-close-icon{background:transparent;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:var(--radius-sm);transition:all .2s}.tally-popup-close-icon:hover{background:var(--surface-3);color:var(--text-primary)}.tally-status-summary{padding:16px;background:var(--surface-2);border-bottom:2px solid var(--border)}.tally-status-summary.connected{border-bottom-color:#10b981}.tally-status-summary.disconnected{border-bottom-color:#ef4444}.tally-status-summary.warning{border-bottom-color:#f59e0b}.tally-status-summary.connecting{border-bottom-color:#9ca3af}.tally-status-dot-inline{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:10px}.tally-status-dot-inline.connected{background:#10b981;box-shadow:0 0 6px #10b98166}.tally-status-dot-inline.disconnected{background:#ef4444;box-shadow:0 0 6px #ef444466}.tally-status-dot-inline.warning{background:#f59e0b;box-shadow:0 0 6px #f59e0b66}.tally-status-dot-inline.connecting{background:#9ca3af;animation:connectingPulse 1.5s ease-in-out infinite}.tally-popup-group-label{padding:14px 16px 6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--surface-1)}.notification-popup-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface-2);border-top:1px solid var(--border)}.notification-popup-footer button{display:flex;align-items:center;gap:6px}@media(max-width:500px){.tally-status-popup-fixed{width:100%;border-radius:0;height:100vh;max-height:100vh}}.header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:var(--surface-1);border-bottom:1px solid var(--border);height:var(--header-height);flex-shrink:0;gap:16px}.header-left{display:flex;align-items:center;gap:14px}.header-mobile-toggle{display:none;width:38px;height:38px;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:22px;color:var(--text-secondary);transition:all var(--transition-fast)}.header-mobile-toggle:hover{background:var(--border-light);color:var(--text-primary)}@media(max-width:768px){.header-mobile-toggle{display:flex}}.header-title-block{display:flex;flex-direction:column}.header-title{font-size:24px;font-weight:600;color:var(--text-primary);letter-spacing:-.4px}.header-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}.header-right{display:flex;align-items:center;gap:12px}.company-dropdown{position:relative}.company-dropdown-btn{display:flex;align-items:center;gap:10px;padding:9px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:200px}.company-dropdown-btn:hover{border-color:var(--purple-base);background:var(--surface-3)}.company-dropdown-btn.open{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef26;background:var(--surface-3)}.company-dropdown-icon{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);background:#5d5fef1f;color:var(--purple-base);font-size:16px;flex-shrink:0}.company-dropdown-name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-dropdown-chevron{font-size:16px;color:var(--text-muted);transition:transform .25s ease;flex-shrink:0}.company-dropdown-chevron.rotated{transform:rotate(180deg)}.company-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:260px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 36px #00000059,0 0 0 1px #ffffff08;z-index:200;overflow:hidden;animation:dropdownSlideIn .2s ease}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.company-dropdown-menu-header{padding:10px 16px 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border-light)}.company-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:transparent;border:none;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left}.company-dropdown-item:hover{background:#5d5fef14}.company-dropdown-item.active{background:#5d5fef1f;color:var(--purple-light)}.company-dropdown-item-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:var(--surface-3);color:var(--text-secondary);font-size:14px;flex-shrink:0}.company-dropdown-item.active .company-dropdown-item-icon{background:#5d5fef33;color:var(--purple-base)}.company-dropdown-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-dropdown-item-check{color:var(--purple-base);font-size:18px;flex-shrink:0}.notification-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border);color:var(--text-secondary);font-size:20px;cursor:pointer;transition:all .2s ease}.notification-btn:hover{background:var(--surface-3);border-color:var(--text-muted);color:var(--text-primary)}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;border-radius:10px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface-1);line-height:1}.notification-container,.tally-status-container{position:relative}.notification-popup{position:absolute;top:calc(100% + 8px);right:0;width:480px;max-height:500px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 10px 40px #00000026;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.notification-popup-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.notification-popup-title{font-size:14px;font-weight:600;color:var(--text-primary)}.notification-header-actions{display:flex;align-items:center;gap:8px}.notification-mark-all-btn{background:none;border:none;color:var(--primary);font-size:12px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background .2s}.notification-mark-all-btn:hover{background:#6366f11a}.notification-clear-all-btn{background:none;border:none;color:#ef4444;font-size:12px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background .2s}.notification-clear-all-btn:hover{background:#ef44441a}.notification-popup-list{overflow-y:auto;flex:1;max-height:440px}.notification-empty{display:flex;align-items:center;justify-content:center;padding:40px 16px;color:var(--text-muted);font-size:13px}.notification-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.notification-item:hover{background:var(--surface-2)}.notification-item.unread{background:#6366f10d;border-left:3px solid var(--primary)}.notification-item.unread:hover{background:#6366f11a}.notification-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.notification-invoice-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.notification-time{font-size:11px;color:var(--text-muted);flex-shrink:0}.notification-error-row{display:flex;align-items:flex-start;gap:8px}.notification-type-badge{flex-shrink:0;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.notification-type-badge.push{background:#ef444426;color:#ef4444}.notification-type-badge.upload{background:#f59e0b26;color:#f59e0b}.notification-error-message{font-size:12px;color:var(--text-secondary);line-height:1.5;word-break:break-word}.notification-voucher{margin-top:6px;font-size:11px;color:var(--text-muted);font-family:monospace}.tally-conn-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid;background:transparent}.tally-conn-btn.green{color:#10b981;border-color:#10b9814d;background:#10b98114}.tally-conn-btn.green:hover{background:#10b98126;border-color:#10b98180}.tally-conn-btn.red{color:#ef4444;border-color:#ef44444d;background:#ef444414}.tally-conn-btn.red:hover{background:#ef444426;border-color:#ef444480}.tally-conn-btn.yellow{color:#f59e0b;border-color:#f59e0b4d;background:#f59e0b14}.tally-conn-btn.yellow:hover{background:#f59e0b26;border-color:#f59e0b80}.tally-conn-btn.gray{color:#9ca3af;border-color:#9ca3af4d;background:#9ca3af14}.tally-conn-btn.gray:hover{background:#9ca3af26;border-color:#9ca3af80}.tally-conn-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tally-conn-dot.green{background:#10b981;box-shadow:0 0 6px #10b98180}.tally-conn-dot.red{background:#ef4444;box-shadow:0 0 6px #ef444480}.tally-conn-dot.yellow{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.tally-conn-dot.gray{background:#9ca3af;animation:connectingPulse 1.5s ease-in-out infinite}@keyframes connectingPulse{0%,to{opacity:1}50%{opacity:.3}}.tally-conn-label{white-space:nowrap}.btn-upload{display:flex;align-items:center;gap:8px;padding:10px 22px;background:var(--purple-base);color:#fff;border-radius:var(--radius-sm);font-size:14px;font-weight:500;transition:all var(--transition-fast);box-shadow:var(--purple-glow)}.btn-upload:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2563eb59;transform:translateY(-1px)}.btn-upload:active{transform:translateY(0)}.btn-upload-icon{font-size:18px;display:flex}.header-file-count{display:flex;align-items:center;gap:6px;padding:6px 14px;background:var(--surface-2);color:var(--purple-light);border-radius:20px;font-size:13px;font-weight:500;border:1px solid var(--border)}@media(max-width:768px){.header{padding:16px 20px}.header-title{font-size:20px}.header-subtitle,.header-file-count,.tally-conn-label{display:none}}.header-search-container{display:flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 16px;width:320px;height:40px;transition:all .2s ease}.header-search-container:focus-within{border-color:var(--purple-base);background:var(--surface-3);box-shadow:0 0 0 3px #5d5fef1a}.header-search-icon{color:var(--text-muted);font-size:18px;margin-right:10px}.header-search-input{background:transparent;border:none;color:var(--text-primary);font-size:14px;width:100%}.header-actions-dashboard{display:flex;align-items:center;gap:16px}.tally-warning-pill{display:flex;align-items:center;gap:8px;background:#ffb5471a;border:1px solid rgba(255,181,71,.3);padding:6px 12px;border-radius:20px;color:#ffb547;font-size:11px;font-weight:700;letter-spacing:.05em}.dot.small{width:6px;height:6px}.dot.yellow{background:#ffb547;box-shadow:0 0 6px #ffb547;border-radius:50%}.icon-btn-circle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);font-size:20px;position:relative}.icon-btn-circle:hover{background:var(--surface-3);color:var(--text-primary)}.dot-badge{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;border:2px solid var(--surface-1)}.dot-badge.red{background:#ef4444}.header-user-profile{display:flex;align-items:center;gap:12px;padding-left:8px;border-left:1px solid var(--border)}.user-details{text-align:right}.user-name{font-size:14px;font-weight:700;color:var(--text-primary)}.user-role{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.05em}.user-avatar-small{width:36px;height:36px;border-radius:10px;overflow:hidden;border:1px solid var(--border)}.user-avatar-small img{width:100%;height:100%;object-fit:cover}.file-table-section{padding:24px 32px;flex:1;overflow:hidden;display:flex;flex-direction:column}.filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.filter-search{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;min-width:180px;max-width:240px;transition:all var(--transition-fast);color:var(--text-muted);font-size:16px}.filter-search:focus-within{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef26}.filter-search svg{flex-shrink:0}.filter-search input{flex:1;font-size:13px;color:var(--text-primary);background:transparent;min-width:0}.filter-search input::placeholder{color:var(--text-muted)}.btn-upload-tally{display:flex;align-items:center;gap:6px;padding:10px 20px;background:transparent;color:var(--success);border:1px solid var(--success);border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.btn-upload-tally:hover:not(:disabled){background:#00c48c1a;transform:translateY(-1px)}.btn-upload-tally:disabled{opacity:.35;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted)}.filter-date-wrapper{position:relative}.filter-date-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-date-btn:hover{background:var(--surface-3);color:var(--text-primary)}.file-table-container th{padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-muted);text-align:left;white-space:nowrap}.text-right{text-align:right!important}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast)}.sortable-header:hover{background:#ffffff0a!important}.header-sort-content{display:flex;align-items:center;justify-content:flex-end;gap:6px}.sort-icon{display:flex;align-items:center;font-size:14px;color:var(--text-muted);transition:all var(--transition-fast)}.sort-icon.asc,.sort-icon.desc{color:var(--purple-light)}.sort-icon.none{opacity:.35}.file-table-container td{background:var(--surface-3);color:var(--text-primary)}.filter-date-btn.active{border-color:var(--purple-base);color:var(--purple-light);background:#5d5fef14}.filter-date-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:50;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px;min-width:240px;box-shadow:0 12px 40px #00000073;animation:scaleIn .15s ease}.filter-date-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.filter-date-chip{padding:5px 12px;font-size:11px;font-weight:500;color:var(--text-secondary);background:var(--surface-3);border-radius:6px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-date-chip:hover{background:#5d5fef1f;color:var(--text-primary)}.filter-date-chip.active{background:var(--purple-base);color:#fff;font-weight:600}.filter-date-custom{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.filter-date-input-group{flex:1;display:flex;flex-direction:column;gap:4px}.filter-date-input-group label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.filter-date-input-group input[type=date]{padding:5px 8px;font-size:12px;color:var(--text-primary);background:var(--surface-1);border:1px solid var(--border);border-radius:6px;font-family:var(--font-body);transition:border-color var(--transition-fast)}.filter-date-input-group input[type=date]:focus{border-color:var(--purple-base);outline:none}.filter-date-input-group input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.filter-date-reset{display:block;width:100%;margin-top:8px;padding:5px;font-size:11px;font-weight:600;color:var(--text-muted);text-align:center;border-radius:6px;transition:all var(--transition-fast)}.filter-date-reset:hover{background:#ff6b6b1a;color:var(--error)}.filter-segment{display:inline-flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:2px;gap:1px}.filter-dropdown-wrapper{display:inline-flex;align-items:center;gap:6px}.filter-dropdown-label{font-size:12px;font-weight:600;color:var(--text-muted);white-space:nowrap}.filter-dropdown{padding:7px 28px 7px 12px;font-size:13px;font-weight:500;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all var(--transition-fast);-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;font-family:var(--font-body);min-width:100px}.filter-dropdown:hover{border-color:var(--purple-base);background-color:var(--surface-3)}.filter-dropdown:focus{outline:none;border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef26}.filter-dropdown option{background:var(--surface-1);color:var(--text-primary);padding:8px}.filter-seg-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;font-size:11px;font-weight:500;color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .18s ease;white-space:nowrap;position:relative}.filter-seg-btn:hover{color:var(--text-primary);background:var(--surface-3)}.filter-seg-btn.active{color:var(--text-primary);background:var(--surface-3);font-weight:700;box-shadow:0 1px 4px #0003}.seg-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.seg-dot.orange{background:#ea580c}.seg-dot.green{background:#059669}.seg-dot.red{background:#dc2626}.seg-dot.amber{background:#d97706}.seg-dot.blue{background:#2563eb}.seg-dot.blue.animated{animation:dotPulse 1.5s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 #2563eb66}50%{box-shadow:0 0 0 4px #2563eb00}}.seg-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;font-size:9px;font-weight:700;color:var(--text-secondary);background:var(--surface-1);border-radius:8px;line-height:1}.filter-seg-btn.active .seg-count{background:var(--purple-deep);color:var(--purple-light)}.filter-selected-badge{padding:5px 12px;font-size:11px;font-weight:700;color:var(--purple-light);background:var(--purple-deep);border-radius:8px;white-space:nowrap;animation:scaleIn .2s ease}.table-container{flex:1;overflow:auto;background:var(--surface-1);border-radius:var(--radius-md) var(--radius-md) 0 0;border:1px solid var(--border);border-bottom:none}.file-table{width:100%;border-collapse:collapse;min-width:560px}.file-table thead{position:sticky;top:0;z-index:2}.file-table th{background:var(--surface-2);padding:16px 20px;text-align:center;font-size:13px;font-weight:500;color:var(--text-secondary);letter-spacing:.3px;border-bottom:1px solid var(--border);white-space:nowrap;font-family:var(--font-body)}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast),color var(--transition-fast)}.sortable-header:hover{background-color:var(--surface-3);color:var(--text-primary)}.header-sort-content{display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.header-sort-content.right{justify-content:flex-end}.file-table td{padding:16px 20px;font-size:14px;font-weight:500;color:var(--text-primary);border-bottom:1px solid var(--border-light);vertical-align:middle}.file-table th.text-center,.file-table td.text-center{text-align:center}.file-table th.text-right,.file-table td.text-right{text-align:right}.file-table tbody tr{transition:background var(--transition-fast)}.file-table tbody tr:hover{background:var(--surface-2)}.file-table tbody tr:last-child td{border-bottom:none}.file-name-cell{display:flex;align-items:center;gap:10px}.file-icon-wrapper{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.file-icon-wrapper.pdf{background:#fef2f2;color:#dc2626}.file-icon-wrapper.image{background:#eff6ff;color:#2563eb}.file-name-text{font-family:Arial,sans-serif;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}.file-size-text{font-size:12px;color:var(--text-muted);margin-top:2px}.invoice-no-wrapper{display:flex;flex-direction:column;gap:2px}.invoice-no-cell{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.invoice-date-cell{font-size:11px;font-weight:400;color:var(--text-muted);white-space:nowrap}.total-cell{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;font-family:var(--font-mono)}.seller-name-cell{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;display:inline-block}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;box-shadow:0 1px 2px #0000000d}.status-badge.success{background:#16a34a1a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.status-badge.uploaded{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.status-badge.ready-to-review{background:#8b5cf61a;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.status-badge.reviewed{background:#16a34a1a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.status-badge.error{background:#dc26261a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.status-badge.processing{background:#fff7ed;color:#ea580c}.status-spinner{width:14px;height:14px;border:2px solid #FDBA74;border-top-color:#ea580c;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.status-icon{font-size:14px;display:flex}.chat-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:#8b5cf6;font-size:18px;transition:all var(--transition-fast)}.chat-btn:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.delete-file-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:18px;transition:all var(--transition-fast)}.delete-file-btn:hover{background:#fef2f2;color:#dc2626}.th-filter{padding:10px 8px!important;position:relative}.th-filter-btn{display:inline-flex;align-items:center;padding:5px 12px;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--surface-3);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s ease;font-family:var(--font-body);letter-spacing:.3px;white-space:nowrap}.th-filter-btn:hover{border-color:var(--purple-base);background-color:var(--surface-2);color:var(--text-primary)}.th-filter-btn.open{border-color:var(--purple-base);box-shadow:0 0 0 2px #5d5fef26;color:var(--text-primary)}.th-filter-btn.active{border-color:var(--purple-base);color:var(--purple-light);background-color:#5d5fef14}.th-filter-popover{position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%);min-width:160px;background:var(--surface-1);border:1px solid var(--border);border-radius:10px;box-shadow:0 12px 36px #0006,0 0 0 1px #ffffff08;z-index:100;overflow:hidden;animation:thFilterSlideIn .18s ease;padding:4px}@keyframes thFilterSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.th-filter-popover-title{padding:8px 12px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.th-filter-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease;text-align:left;border-radius:6px}.th-filter-option:hover{background:#5d5fef14}.th-filter-option.selected{background:#5d5fef1f;color:var(--purple-light);font-weight:600}.th-filter-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.action-cell{display:flex;align-items:center;justify-content:center;gap:4px}.status-select,.tally-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:5px 28px 5px 10px;font-size:12px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.3px;font-family:var(--font-body);background-repeat:no-repeat;background-position:right 8px center;background-size:12px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");outline:none;min-width:100px}.status-select:focus,.tally-select:focus{box-shadow:0 0 0 2px #5d5fef33}.status-select option,.tally-select option{background:var(--surface-1);color:var(--text-primary);font-weight:500;text-transform:none}.status-select.processing{background-color:#ea580c1a;border:1px solid rgba(234,88,12,.3);color:#ea580c}.status-select.success{background-color:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981}.status-select.error{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.tally-select.pending{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:#f59e0b}.tally-select.syncing{background-color:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:#3b82f6}.tally-select.pushed{background-color:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981}.tally-select.failed{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;text-align:center;animation:fadeIn var(--transition-slow)}.empty-state-icon{width:80px;height:80px;border-radius:50%;background:var(--primary-subtle);display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--primary);margin-bottom:20px}.empty-state-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.empty-state-desc{font-size:14px;color:var(--text-secondary);max-width:320px}.loading-row td{padding:16px!important}.loading-shimmer{height:14px;border-radius:4px;background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 50%,var(--border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.table-checkbox{width:16px;height:16px;accent-color:var(--purple-base);cursor:pointer}.row-selected{background:#5d5fef0f!important}.row-selected:hover{background:#5d5fef1a!important}.invoice-type-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 10px;border-radius:12px;letter-spacing:.3px;text-transform:uppercase;box-shadow:0 1px 2px #0000000d}.invoice-type-badge.purchase-voucher{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.invoice-type-badge.sales-voucher{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.invoice-type-badge.credit_note{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.invoice-type-badge.debit_note{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.invoice-type-badge.expense-voucher{background:#8b5cf61a;color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.tally-status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 10px;border-radius:12px;letter-spacing:.3px;text-transform:uppercase;box-shadow:0 1px 2px #0000000d}.tally-status-badge.pending{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.tally-status-badge.pending svg{font-size:14px;color:#f59e0b}.tally-status-badge.syncing{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2);animation:tallyPulse 1.8s ease-in-out infinite}.tally-spinner{width:12px;height:12px;border:2px solid #93C5FD;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes tallyPulse{0%,to{opacity:1;box-shadow:0 0 #3b82f600}50%{opacity:.85;box-shadow:0 0 0 4px #3b82f61f}}.tally-status-badge.pushed{background:#16a34a1a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.tally-status-badge.pushed svg{font-size:14px;color:#10b981}.tally-status-badge.failed{background:#dc26261a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.tally-status-badge.failed svg{font-size:14px;color:#ef4444}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid var(--border);background:var(--surface-1);border-radius:0 0 var(--radius-md) var(--radius-md)}.pagination-left{display:flex;align-items:center;gap:16px}.pagination-info{font-size:13px;color:var(--text-secondary);font-family:var(--font-mono)}.page-size-selector{display:flex;align-items:center;gap:8px}.page-size-label{font-size:12px;color:var(--text-secondary)}.page-size-select{padding:4px 8px;font-size:12px;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;cursor:pointer;transition:border-color var(--transition-fast)}.page-size-select:focus,.page-size-select:hover{border-color:var(--purple-base)}.pagination-btns{display:flex;gap:6px}.pagination-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--surface-3);color:var(--text-primary)}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.file-table-section{padding:16px 20px}.table-toolbar{flex-direction:column;align-items:stretch}.table-search{width:100%}.table-stats{justify-content:center}}.dynamic-table-wrapper{overflow-x:auto;overflow-y:visible;margin:0 -16px;padding:0 16px}.dynamic-table{width:100%;border-collapse:collapse;font-size:13px;min-width:400px;overflow:visible}.dynamic-table thead{overflow:visible}.dynamic-table thead th{background:var(--surface-2);padding:10px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid var(--border);white-space:nowrap;font-family:var(--font-display);position:sticky;top:0;z-index:1;overflow:visible}.header-dropdown-menu{z-index:99999!important}.header-inline-edit{width:100%;padding:2px 6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-family:var(--font-display);color:var(--text-primary);background:var(--surface-1);border:1px solid var(--purple-base);border-radius:var(--radius-sm);outline:none;box-shadow:0 0 0 2px #5d5fef33;min-width:60px}.dynamic-table thead th.numeric{text-align:right}.dynamic-table tbody td{padding:9px 12px;color:var(--text-primary);border-bottom:1px solid var(--border-light);white-space:nowrap}.dynamic-table tbody td.numeric{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.dynamic-table tbody tr:hover{background:var(--surface-3)}.dynamic-table tbody tr:last-child td{border-bottom:none}.dynamic-table .col-sno{width:40px;color:var(--text-muted);font-weight:500}.dt-delete-col{width:36px;min-width:36px;padding:0!important}.dt-delete-cell{width:36px;min-width:36px;padding:4px 6px!important;text-align:center}.dt-delete-btn{background:none;border:none;cursor:pointer;font-size:13px;opacity:0;transition:opacity var(--transition-fast);color:#ef4444;padding:2px 4px;border-radius:var(--radius-sm);line-height:1}.dt-data-row:hover .dt-delete-btn{opacity:1}.dt-confirm-delete{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary);white-space:nowrap}.dt-confirm-yes,.dt-confirm-no{padding:2px 6px;font-size:11px;font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer}.dt-confirm-yes{background:#ef4444;color:#fff}.dt-confirm-no{background:var(--surface-3);color:var(--text-secondary)}.dt-empty-row{text-align:center;color:var(--text-muted);font-size:12px;padding:16px!important;font-style:italic}.dt-add-row-bar{padding:8px 16px 12px;text-align:left}.dt-context-menu{position:fixed;z-index:99999;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000040;min-width:160px;padding:4px 0}.dt-context-menu-item{padding:10px 14px;font-size:13px;font-weight:400;cursor:pointer;color:var(--text-primary);transition:background var(--transition-fast);display:flex;align-items:center;gap:8px}.dt-context-menu-item:hover{background:var(--surface-3)}.dt-context-menu-item.delete{color:#ef4444}.dt-context-menu-item.delete:hover{background:#ef44441a}.cell-edit-input{width:100%;padding:3px 6px;font-size:13px;font-weight:500;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);outline:none;min-width:60px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.cell-edit-input:focus{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef33}.cell-edit-input.numeric{text-align:right}.header-dropdown-wrapper{position:relative;display:inline-block}.header-dropdown-trigger{background:none;border:none;cursor:pointer;font:inherit;color:var(--text-primary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-family:var(--font-display);padding:0;display:flex;align-items:center;gap:4px;white-space:nowrap}.header-dropdown-trigger:hover{color:var(--purple-base)}.header-dropdown-arrow{font-size:9px;opacity:.55;line-height:1}.header-dropdown-menu{position:fixed;z-index:9999;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 32px #00000040;min-width:230px;max-height:340px;overflow-y:auto;padding:4px 0}.header-dropdown-item{padding:10px 14px;font-size:13px;font-weight:400;cursor:pointer;color:var(--text-primary);text-transform:none;letter-spacing:0;white-space:nowrap;transition:background var(--transition-fast);line-height:1.4}.header-dropdown-item:hover{background:var(--surface-3)}.header-dropdown-item.active{color:var(--purple-base);font-weight:600;background:var(--surface-2)}.invoice-data{display:flex;flex-direction:column;gap:20px;padding:20px;background:var(--surface-1);min-height:100%;animation:fadeIn var(--transition-normal)}.invoice-page-block{display:flex;flex-direction:column;gap:16px}.invoice-parties-row{display:flex;gap:20px}.invoice-parties-row>.invoice-section{flex:1;min-width:0}@media(max-width:768px){.invoice-parties-row{flex-direction:column}}.invoice-page-title{font-size:16px;font-weight:600;color:var(--purple-base);padding:8px 16px;background:var(--surface-2);border-radius:var(--radius-sm);border-left:3px solid var(--purple-base)}.invoice-section{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;overflow-x:hidden;overflow-y:visible;box-shadow:0 4px 20px #00000026;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.invoice-section:hover{box-shadow:0 6px 24px #0003}.invoice-section-header{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-primary);letter-spacing:.2px}.invoice-section-header-icon{font-size:16px;display:flex;color:var(--purple-base)}.invoice-section-count{margin-left:auto;font-size:11px;font-weight:500;color:var(--text-muted);background:var(--card-bg);padding:2px 8px;border-radius:10px;text-transform:none;letter-spacing:0}.invoice-section-header.collapsible:hover{background:var(--surface-3)}.invoice-section-chevron{font-size:10px;color:var(--text-muted);margin-left:8px;flex-shrink:0;transition:transform var(--transition-fast)}.invoice-type-select{background:var(--surface-2);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:4px 8px;font-size:13px;font-family:inherit;cursor:pointer}.expense-map-btn{margin-left:8px;padding:3px 10px;font-size:11px;font-weight:600;background:#5d5fef26;color:var(--purple-light, #7879F1);border:1px solid rgba(93,95,239,.3);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;flex-shrink:0;line-height:1}.expense-map-btn:hover{background:var(--purple-base, #5D5FEF);color:#fff;border-color:var(--purple-base, #5D5FEF)}.invoice-section-collapsed-add{padding:8px 18px}.add-row-btn{background:none;border:1px dashed var(--border);color:var(--text-secondary);font-size:12px;font-weight:500;padding:5px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.add-row-btn:hover{border-color:var(--purple-base);color:var(--purple-base);background:#5d5fef0f}.invoice-section-body{padding:14px 16px}.invoice-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px}.invoice-detail-item{display:flex;flex-direction:column;gap:2px}.invoice-detail-item.full-width{grid-column:1 / -1}.invoice-detail-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.invoice-detail-value{font-size:14px;font-weight:500;color:var(--text-primary);word-break:break-word}.invoice-detail-item[data-field*=gstin] .invoice-detail-value,.invoice-detail-item[data-field*=date] .invoice-detail-value,.invoice-detail-item[data-field*=number] .invoice-detail-value{font-family:var(--font-mono)}.invoice-section .invoice-items-body{padding:0;overflow:visible}.invoice-totals-section{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000026}.invoice-total-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border-light);font-size:14px}.invoice-total-row:last-child{border-bottom:none}.invoice-total-label{font-weight:500;color:var(--text-secondary)}.invoice-total-value{font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.invoice-total-add-row{padding:8px 16px 12px;text-align:left}.invoice-total-delete-btn{background:none;border:none;cursor:pointer;font-size:12px;opacity:0;color:#ef4444;padding:2px 4px;border-radius:var(--radius-sm);transition:opacity var(--transition-fast);margin-left:8px;flex-shrink:0;white-space:nowrap}.invoice-total-row:hover .invoice-total-delete-btn{opacity:1}.invoice-bank-entry{position:relative}.invoice-bank-delete-bar{display:flex;justify-content:flex-end;margin-bottom:6px}.invoice-bank-delete-bar .invoice-total-delete-btn{opacity:1;font-size:12px}.invoice-terms-list{list-style:disc;padding-left:20px;font-size:13px;color:var(--text-secondary);line-height:1.7}.invoice-error{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px;text-align:center}.invoice-error-icon{width:48px;height:48px;border-radius:50%;background:var(--error-bg);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--error)}.invoice-error-title{font-size:15px;font-weight:600;color:var(--text-primary)}.invoice-error-desc{font-size:13px;color:var(--text-secondary);max-width:280px}.invoice-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 16px}.invoice-loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.invoice-loading-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.invoice-detail-item.editable{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.invoice-detail-item.editable:hover,.invoice-total-row.editable:hover{background:var(--surface-3)}.inline-edit-input{width:100%;padding:4px 8px;font-size:13px;font-weight:500;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);outline:none;transition:all var(--transition-fast)}.inline-edit-input:focus{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef33}.inline-edit-input.total-edit{text-align:right;font-weight:700;font-size:14px;max-width:160px}.invoice-analysis-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#5d5fef1a;border:1px dashed var(--purple-base);border-radius:var(--radius-sm);color:var(--purple-light);font-size:13px;font-weight:500;margin-bottom:8px}.invoice-analysis-banner .spin{font-size:16px;animation:spin 2s linear infinite}.ai-chat-panel{display:flex;flex-direction:column;height:100%;background:#fff;overflow:hidden;position:relative}.ai-chat-panel.ai-chat-resizing{-webkit-user-select:none;user-select:none}.ai-chat-resize-handle{position:absolute;top:0;left:0;width:6px;height:100%;cursor:col-resize;z-index:20;background:#e2e4ec;display:flex;align-items:center;justify-content:center;transition:background .15s}.ai-chat-resize-handle:after{content:"";display:block;width:3px;height:32px;border-radius:2px;background:#cbd5e1;transition:background .15s}.ai-chat-resize-handle:hover{background:#c7d2fe}.ai-chat-resize-handle:hover:after{background:#5d5fef}.ai-chat-resizing .ai-chat-resize-handle{background:#a5b4fc}.ai-chat-resizing .ai-chat-resize-handle:after{background:#4338ca}.ai-chat-resizing-body{-webkit-user-select:none!important;user-select:none!important;cursor:col-resize!important}.ai-chat-sidebar{position:absolute;top:0;left:0;bottom:0;width:260px;background:#f8f9fc;border-right:1px solid #E2E4EC;z-index:10;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:10px 0 20px #00000014}.ai-chat-sidebar.open{transform:translate(0)}.ai-chat-panel{position:relative}.ai-chat-sidebar-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000026;z-index:9;opacity:0;pointer-events:none;transition:opacity .3s ease}.ai-chat-sidebar.open~.ai-chat-sidebar-backdrop{opacity:1;pointer-events:auto}.ai-chat-main{flex:1;display:flex;flex-direction:column;min-height:0}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 12px 20px;background:#fff;border-bottom:1px solid #E2E4EC;flex-shrink:0}.ai-chat-header-left{display:flex;align-items:center;gap:8px}.ai-chat-header-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#5d5fef,#7879f1);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:10px;color:#fff;box-shadow:0 2px 8px #5d5fef4d}.ai-chat-header-info h3{font-family:var(--font-display);font-size:13px;font-weight:700;color:#1a1a2e}.ai-chat-header-info span{font-size:10px;color:#6b7280}.ai-chat-header-close{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;color:#6b7280;transition:all .15s ease;cursor:pointer}.ai-chat-header-close:hover{background:#f0f0f8;color:#1a1a2e}.ai-chat-header-status{display:flex;align-items:center;gap:4px;font-size:10px;color:#10b981}.ai-chat-header-status:before{content:"";width:5px;height:5px;border-radius:50%;background:#10b981;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.ai-chat-messages{flex:1;overflow-y:auto;padding:14px 14px 14px 20px;display:flex;flex-direction:column;gap:10px;background:#f8f9fc}.ai-chat-msg{display:flex;gap:6px;max-width:95%;animation:msgIn .2s ease}.ai-chat-msg.user{align-self:flex-end;flex-direction:row-reverse}.ai-chat-msg.ai{align-self:flex-start}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-chat-msg-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.ai-chat-msg.ai .ai-chat-msg-avatar{background:linear-gradient(135deg,#5d5fef,#7879f1);color:#fff;font-family:var(--font-display)}.ai-chat-msg.user .ai-chat-msg-avatar{background:#e2e4ec;color:#4a4a68}.ai-chat-msg-body{display:flex;flex-direction:column;gap:2px}.ai-chat-msg-bubble{padding:8px 12px;font-size:12px;line-height:1.5;border-radius:10px}.ai-chat-msg.ai .ai-chat-msg-bubble{background:#fff;border:1px solid #E2E4EC;color:#1a1a2e;border-top-left-radius:4px}.ai-chat-msg.user .ai-chat-msg-bubble{background:linear-gradient(135deg,#5d5fef,#7879f1);border:none;color:#fff;border-top-right-radius:4px}.ai-chat-msg-time{font-size:9px;color:#6b7280;font-family:var(--font-mono);padding:0 4px}.ai-chat-msg.user .ai-chat-msg-time{text-align:right}.ai-chat-status-card{padding:10px 12px;border-radius:8px;display:flex;align-items:flex-start;gap:8px;margin-top:4px}.ai-chat-status-card.success{background:#10b98114;border:1px solid rgba(16,185,129,.2)}.ai-chat-status-card.error{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.ai-chat-status-card svg{font-size:16px;flex-shrink:0;margin-top:1px}.ai-chat-status-card.success svg{color:#10b981}.ai-chat-status-card.error svg{color:#ef4444}.ai-chat-status-card-body{flex:1}.ai-chat-status-card-title{font-size:12px;font-weight:700;color:#1a1a2e;margin-bottom:2px}.ai-chat-status-card-desc{font-size:11px;color:#4a4a68;line-height:1.4}.ai-chat-action-btn{margin-top:4px;padding:3px 8px;font-size:10px;font-weight:600;color:#5d5fef;background:#5d5fef1a;border-radius:4px;transition:all .15s ease}.ai-chat-action-btn:hover{background:#5d5fef2e}.ai-chat-input-area{padding:10px 14px 14px 20px;background:#fff;border-top:1px solid #E2E4EC;flex-shrink:0}.ai-chat-input-wrapper{display:flex;align-items:flex-end;gap:6px;padding:6px 10px;background:#f8f9fc;border:1px solid #E2E4EC;border-radius:10px;transition:all .15s ease}.ai-chat-input-wrapper:focus-within{border-color:#5d5fef;box-shadow:0 0 0 2px #5d5fef1a;background:#fff}.ai-chat-input-wrapper textarea{flex:1;background:transparent;color:#1a1a2e;font-size:12px;font-family:var(--font-body);line-height:1.5;resize:none;min-height:18px;max-height:80px}.ai-chat-input-wrapper textarea::placeholder{color:#9ca3af}.ai-chat-send-btn{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;background:linear-gradient(135deg,#5d5fef,#7879f1);box-shadow:0 2px 8px #5d5fef4d;flex-shrink:0;transition:all .15s ease}.ai-chat-send-btn:hover:not(:disabled){transform:scale(1.08);box-shadow:0 4px 12px #5d5fef66}.ai-chat-send-btn:disabled{opacity:.3;cursor:not-allowed}.ai-chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px}.ai-chat-empty-icon{width:44px;height:44px;border-radius:50%;background:#5d5fef1a;border:1px solid rgba(93,95,239,.15);display:flex;align-items:center;justify-content:center;font-size:20px;color:#5d5fef}.ai-chat-empty h3{font-family:var(--font-display);font-size:14px;font-weight:700;color:#1a1a2e}.ai-chat-empty p{font-size:12px;color:#6b7280;text-align:center;max-width:220px;line-height:1.5}.ai-chat-sidebar-header{padding:16px 14px 12px;display:flex;flex-direction:column;gap:12px}.ai-chat-sidebar-title{display:flex;align-items:center;justify-content:space-between}.ai-chat-sidebar-title h3{font-family:var(--font-display);font-size:13px;font-weight:700;color:#1a1a2e;text-transform:uppercase;letter-spacing:.5px}.ai-chat-new-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;font-size:11px;font-weight:700;color:#fff;background:linear-gradient(135deg,#5d5fef,#7879f1);border-radius:6px;box-shadow:0 2px 8px #5d5fef4d;transition:all .15s ease}.ai-chat-new-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5d5fef66}.ai-chat-search{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#fff;border:1px solid #E2E4EC;border-radius:8px;transition:all .15s ease}.ai-chat-search:focus-within{border-color:#5d5fef;box-shadow:0 0 0 2px #5d5fef26}.ai-chat-search svg{color:#6b7280;font-size:13px}.ai-chat-search input{flex:1;background:transparent;color:#1a1a2e;font-size:12px}.ai-chat-search input::placeholder{color:#9ca3af}.ai-chat-session-list{flex:1;overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:3px}.ai-chat-session-card{display:flex;align-items:center;gap:8px;padding:10px;background:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s ease}.ai-chat-session-card:hover{background:#f0f0f8;border-color:#e2e4ec}.ai-chat-session-card.active{background:#5d5fef14;border-color:#5d5fef33}.ai-chat-session-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;background:#5d5fef1f;color:#5d5fef}.ai-chat-session-card.active .ai-chat-session-icon{background:#5d5fef;color:#fff}.ai-chat-session-info{flex:1;min-width:0}.ai-chat-session-name{font-size:12px;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-chat-session-time{font-size:9px;color:#6b7280;margin-top:2px}.ai-chat-session-delete{width:22px;height:22px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#6b7280;font-size:12px;opacity:0;transition:all .15s ease}.ai-chat-session-card:hover .ai-chat-session-delete{opacity:1}.ai-chat-session-delete:hover{background:#ef444426;color:#ef4444}.ai-chat-cursor{display:inline;animation:aiChatBlink .7s step-end infinite;color:#5d5fef;font-weight:300}@keyframes aiChatBlink{50%{opacity:0}}.ai-chat-scroll-btn{position:absolute;bottom:70px;left:50%;transform:translate(-50%);width:28px;height:28px;border-radius:50%;background:#fff;border:1px solid #E2E4EC;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;font-size:14px;z-index:5;transition:all .15s}.ai-chat-scroll-btn:hover{background:#f0f0f8;border-color:#c7d2fe}.ai-chat-quick-queries{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;justify-content:center;max-width:300px}.ai-chat-quick-btn{background:#fff;border:1px solid #E2E4EC;border-radius:14px;padding:6px 12px;font-size:11px;color:#4a4a68;cursor:pointer;transition:all .15s;white-space:nowrap}.ai-chat-quick-btn:hover{background:#5d5fef14;border-color:#5d5fef4d;color:#5d5fef}.ai-chat-md-content h2,.ai-chat-md-content h3,.ai-chat-md-content h4{margin:6px 0 3px;font-size:12px;font-weight:700;color:#1a1a2e}.ai-chat-md-content p{margin:2px 0}.ai-chat-md-content br{display:block;content:"";margin:2px 0}.ai-chat-md-content strong{font-weight:700;color:#0f172a}.ai-chat-md-content code{background:#f0f0f8;padding:1px 4px;border-radius:3px;font-size:11px;font-family:Menlo,Consolas,monospace}.ai-chat-md-content pre{background:#f0f0f8;padding:8px;border-radius:6px;overflow-x:auto;margin:4px 0}.ai-chat-md-content pre code{background:none;padding:0}.ai-chat-md-content li{margin-left:14px;list-style:disc;padding-left:3px}.ai-chat-md-content table{width:100%;border-collapse:collapse;margin:6px 0;font-size:11px}.ai-chat-md-content th,.ai-chat-md-content td{padding:4px 6px;border:1px solid #E2E4EC;text-align:left}.ai-chat-md-content th{background:#f0f0f8;font-weight:700;white-space:nowrap}.ai-chat-md-content hr{border:none;border-top:1px solid #E2E4EC;margin:6px 0}.tally-chat-panel{display:flex;flex-direction:column;max-width:100vw;height:100vh;position:fixed;top:0;right:0;z-index:1000;background:#fff;border-left:none;box-shadow:-4px 0 24px #00000014;animation:tallyChatSlideIn .25s ease-out;overflow:visible}.tally-chat-panel.tally-chat-resizing{animation:none;transition:none;-webkit-user-select:none;user-select:none}.tally-chat-resize-handle{position:absolute;top:0;left:0;width:10px;height:100%;cursor:col-resize;z-index:1010;background:#edf0f4;display:flex;align-items:center;justify-content:center;transition:background .2s,width .2s;border-right:1px solid #e2e8f0}.tally-chat-resize-handle:hover{background:#dde3f0;width:12px}.tally-chat-resize-grip{display:flex;flex-direction:column;gap:4px;align-items:center}.tally-chat-resize-grip span{display:block;width:4px;height:4px;border-radius:50%;background:#b0b8c9;transition:background .2s}.tally-chat-resize-handle:hover .tally-chat-resize-grip span{background:#5d5fef}.tally-chat-resizing .tally-chat-resize-handle{background:#c7d2fe;width:12px}.tally-chat-resizing .tally-chat-resize-grip span{background:#4338ca}@keyframes tallyChatSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.tally-chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 14px 24px;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#5d5fef,#7c3aed);color:#fff;flex-shrink:0}.tally-chat-header-left{display:flex;align-items:center;gap:10px}.tally-chat-header-avatar{width:32px;height:32px;border-radius:8px;background:#fff3;display:flex;align-items:center;justify-content:center}.tally-chat-header-info h3{font-size:16px;font-weight:600;margin:0;line-height:1.2}.tally-chat-header-info span{font-size:13px;opacity:.8}.tally-chat-header-actions{display:flex;gap:4px}.tally-chat-icon-btn{background:#ffffff26;border:none;color:#fff;width:30px;height:30px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .15s}.tally-chat-icon-btn:hover{background:#ffffff4d}.tally-chat-messages{flex:1;overflow-y:auto;padding:16px 16px 16px 24px;display:flex;flex-direction:column;gap:16px;scroll-behavior:smooth}.tally-chat-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;flex:1}.tally-chat-welcome-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);display:flex;align-items:center;justify-content:center;margin-bottom:16px}.tally-chat-welcome h3{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:6px}.tally-chat-welcome p{font-size:14px;color:#64748b;max-width:300px;line-height:1.5}.tally-chat-company-badge{margin-top:8px;font-size:13px;background:#f1f5f9;padding:4px 12px;border-radius:12px;color:#475569}.tally-chat-quick-queries{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px;justify-content:center;max-width:340px}.tally-chat-quick-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:8px 14px;font-size:14px;color:#475569;cursor:pointer;transition:all .15s;white-space:nowrap}.tally-chat-quick-btn:hover{background:#eef2ff;border-color:#c7d2fe;color:#4338ca}.tally-chat-msg{display:flex;gap:10px;align-items:flex-start}.tally-chat-msg.user{flex-direction:row-reverse}.tally-chat-msg-avatar{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.tally-chat-msg.ai .tally-chat-msg-avatar{background:linear-gradient(135deg,#5d5fef,#7c3aed);color:#fff}.tally-chat-msg.user .tally-chat-msg-avatar{background:#e2e8f0;color:#475569}.tally-chat-msg-body{max-width:85%;display:flex;flex-direction:column;gap:4px}.tally-chat-msg.user .tally-chat-msg-body{align-items:flex-end}.tally-chat-msg-bubble{padding:10px 14px;border-radius:12px;font-size:15px;line-height:1.6;word-break:break-word}.tally-chat-msg.ai .tally-chat-msg-bubble{background:#f8fafc;border:1px solid #e2e8f0;color:#1e293b}.tally-chat-msg.user .tally-chat-msg-bubble{background:linear-gradient(135deg,#5d5fef,#7c3aed);color:#fff}.tally-chat-msg-time{font-size:11px;color:#94a3b8;padding:0 4px}.tally-chat-cursor{display:inline;animation:tallyChatBlink .7s step-end infinite;color:#5d5fef;font-weight:300}@keyframes tallyChatBlink{50%{opacity:0}}.tally-chat-tool-chips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.tally-chat-tool-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:10px;font-size:13px;font-weight:500}.tally-chat-tool-chip.loading{background:#fefce8;border:1px solid #fef08a;color:#92400e}.tally-chat-tool-chip.done{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.tally-chat-spinner{width:10px;height:10px;border:2px solid #fde68a;border-top-color:#d97706;border-radius:50%;animation:tallyChatSpin .6s linear infinite;display:inline-block}@keyframes tallyChatSpin{to{transform:rotate(360deg)}}.tally-chat-md-content h2,.tally-chat-md-content h3,.tally-chat-md-content h4{margin:8px 0 4px;font-size:15px;font-weight:600;color:#1e293b}.tally-chat-md-content p{margin:2px 0}.tally-chat-md-content br{display:block;content:"";margin:2px 0}.tally-chat-md-content strong{font-weight:600;color:#0f172a}.tally-chat-md-content code{background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:13px;font-family:Menlo,Consolas,monospace}.tally-chat-md-content pre{background:#f1f5f9;padding:10px;border-radius:8px;overflow-x:auto;margin:6px 0}.tally-chat-md-content pre code{background:none;padding:0}.tally-chat-md-content li{margin-left:16px;list-style:disc;padding-left:4px}.tally-chat-md-content table{width:100%;border-collapse:collapse;margin:8px 0;font-size:14px}.tally-chat-md-content th,.tally-chat-md-content td{padding:6px 8px;border:1px solid #e2e8f0;text-align:left}.tally-chat-md-content th{background:#f1f5f9;font-weight:600;white-space:nowrap}.tally-chat-md-content hr{border:none;border-top:1px solid #e2e8f0;margin:8px 0}.tally-chat-scroll-btn{position:absolute;bottom:80px;left:50%;transform:translate(-50%);width:32px;height:32px;border-radius:50%;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:16px;z-index:5;transition:all .15s}.tally-chat-scroll-btn:hover{background:#f1f5f9;border-color:#c7d2fe}.tally-chat-input-area{padding:12px 16px 12px 24px;border-top:1px solid #e2e8f0;background:#fff;flex-shrink:0}.tally-chat-input-wrapper{display:flex;align-items:flex-end;gap:8px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:8px 8px 8px 14px;transition:border-color .15s}.tally-chat-input-wrapper:focus-within{border-color:#5d5fef;box-shadow:0 0 0 3px #5d5fef1a}.tally-chat-input-wrapper textarea{flex:1;border:none;background:none;resize:none;font-size:15px;font-family:inherit;line-height:1.5;color:#1e293b;outline:none;max-height:120px}.tally-chat-input-wrapper textarea::placeholder{color:#94a3b8}.tally-chat-send-btn{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,#5d5fef,#7c3aed);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:opacity .15s,transform .15s}.tally-chat-send-btn:hover:not(:disabled){transform:scale(1.05)}.tally-chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.tally-chat-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:999;animation:tallyChatFadeIn .2s ease-out}@keyframes tallyChatFadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:640px){.tally-chat-panel{width:100vw!important}.tally-chat-resize-handle{display:none}}.tally-chat-resizing-body{-webkit-user-select:none!important;user-select:none!important;cursor:col-resize!important}.image-viewer{display:flex;flex-direction:column;flex:1;min-height:0}.image-viewer-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 16px;background:var(--surface-1);border-bottom:1px solid var(--border);flex-shrink:0}.image-viewer-group{display:flex;align-items:center;gap:0;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;overflow:hidden}.image-viewer-group button{width:34px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-right:1px solid var(--border);color:var(--text-secondary);font-size:16px;cursor:pointer;transition:background .15s,color .15s}.image-viewer-group button:last-child{border-right:none}.image-viewer-group button:hover{background:#5d5fef1f;color:var(--primary)}.image-viewer-group button:active{background:#5d5fef38}.image-viewer-group button:disabled{opacity:.3;cursor:not-allowed}.image-viewer-zoom-label{min-width:46px;text-align:center;font-size:12px;font-weight:600;color:var(--text-secondary);font-family:var(--font-mono);padding:0 6px;border-right:1px solid var(--border);height:32px;display:flex;align-items:center;justify-content:center}.image-viewer-count{font-size:11px;color:var(--text-muted)}.image-viewer-scroll{flex:1!important;width:100%!important;height:100%!important;overflow:auto!important;background:#0003;cursor:grab}.image-viewer-scroll:active{cursor:grabbing}.image-viewer-content{width:100%!important;display:flex!important;justify-content:center!important}.image-viewer-images{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px}.image-viewer-images img{width:100%;max-width:100%;border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000004d;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.pdf-viewer{width:100%;height:100%;display:flex;flex-direction:column;background:#525659}.pdf-viewer-toolbar{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;background:#323639;border-bottom:1px solid #444}.pdf-viewer-toolbar button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:#ccc;transition:all .15s}.pdf-viewer-toolbar button:hover:not(:disabled){background:#4a4d50;color:#fff}.pdf-viewer-toolbar button:disabled{opacity:.4;cursor:not-allowed}.pdf-viewer-zoom-label{font-size:12px;color:#fff;min-width:45px;text-align:center;background:#4a4d50;padding:4px 8px;border-radius:4px}.pdf-viewer-separator{width:1px;height:20px;background:#555;margin:0 4px}.pdf-viewer-container{flex:1;overflow:auto;position:relative}.pdf-viewer-iframe{width:100%;height:100%;border:none;display:block}.pdf-viewer-error{display:flex;align-items:center;justify-content:center;height:100%;color:var(--error, #ef4444)}.upload-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.upload-modal{width:520px;max-width:90vw;max-height:85vh;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .2s ease}.upload-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.upload-modal-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary)}.upload-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);font-size:18px;transition:all var(--transition-fast)}.upload-modal-close:hover{background:var(--surface-3);color:var(--text-primary)}.upload-modal-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:20px}.upload-modal-file-list-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.upload-modal-file-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}.upload-modal-file-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.upload-modal-file-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.upload-modal-file-icon.pdf{background:#ff6b6b26;color:var(--error)}.upload-modal-file-icon.image{background:#5d5fef26;color:var(--purple-base)}.upload-modal-file-info{flex:1;min-width:0}.upload-modal-file-name{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-modal-file-size{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.upload-modal-file-remove{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-muted);font-size:14px;flex-shrink:0;transition:all var(--transition-fast)}.upload-modal-file-remove:hover{background:#ff6b6b26;color:var(--error)}.upload-modal-file-tag{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;background:#5d5fef26;color:var(--purple-light);white-space:nowrap}.upload-modal-limit{font-size:12px;color:var(--warning);display:flex;align-items:center;gap:6px}.upload-modal-select{width:100%;padding:10px 36px 10px 14px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.upload-modal-select:focus{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef26;outline:none}.upload-modal-select option{background:var(--surface-1);color:var(--text-primary)}.upload-modal-prompt-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.upload-modal-prompt{width:100%;min-height:80px;max-height:140px;padding:12px 14px;font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);resize:vertical;transition:all var(--transition-fast)}.upload-modal-prompt::placeholder{color:var(--text-muted)}.upload-modal-prompt:focus{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef26;outline:none}.upload-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border);gap:12px}.upload-modal-file-count{font-size:13px;color:var(--text-secondary);font-family:var(--font-mono)}.upload-modal-actions{display:flex;gap:10px}.upload-modal-cancel{padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);transition:all var(--transition-fast)}.upload-modal-cancel:hover{background:var(--surface-3);color:var(--text-primary)}.upload-modal-submit{display:flex;align-items:center;gap:8px;padding:10px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:#fff;background:var(--purple-base);box-shadow:var(--purple-glow);transition:all var(--transition-fast)}.upload-modal-submit:hover{background:var(--purple-light);transform:translateY(-1px)}.upload-modal-submit:disabled{opacity:.5;pointer-events:none}.upload-notification-container{position:fixed;bottom:24px;right:24px;width:400px;max-height:500px;background:#fff;border-radius:16px;box-shadow:0 12px 40px #0000001f,0 4px 12px #00000014;overflow:hidden;z-index:1000;animation:slideInUp .4s cubic-bezier(.16,1,.3,1);border:1px solid rgba(0,0,0,.05)}@keyframes slideInUp{0%{transform:translateY(100px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.upload-notification-header{display:flex;align-items:center;gap:14px;padding:18px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom:1px solid rgba(255,255,255,.15)}.header-icon-wrapper{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff3;border-radius:10px;flex-shrink:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-icon{width:22px;height:22px;animation:floatUpDown 2.5s ease-in-out infinite}@keyframes floatUpDown{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.header-content{display:flex;flex-direction:column;gap:2px;flex:1}.header-title{font-size:15px;font-weight:600;letter-spacing:-.01em}.header-count{font-size:12px;font-weight:400;opacity:.9}.upload-notification-list{max-height:420px;overflow-y:auto;padding:16px;background:#fafafa}.upload-notification-list::-webkit-scrollbar{width:8px}.upload-notification-list::-webkit-scrollbar-track{background:transparent}.upload-notification-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px;border:2px solid #fafafa}.upload-notification-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.upload-notification-item{padding:16px;margin-bottom:12px;border-radius:12px;background:#fff;border:1.5px solid #e5e7eb;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000d}.upload-notification-item:last-child{margin-bottom:0}.upload-notification-item:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.upload-notification-item.uploading{border-left:3px solid #3b82f6;background:linear-gradient(to right,#eff6ff,#fff)}.upload-notification-item.analyzing,.upload-notification-item.done{border-left:3px solid #10b981;background:linear-gradient(to right,#f0fdf4,#fff)}.upload-notification-item.error{border-left:3px solid #ef4444;background:linear-gradient(to right,#fef2f2,#fff)}.upload-item-content{display:flex;flex-direction:column;gap:10px}.upload-item-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.upload-item-name{font-size:14px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;letter-spacing:-.01em}.upload-item-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:20px;animation:scaleIn .3s cubic-bezier(.16,1,.3,1)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.upload-notification-item.analyzing .upload-item-icon,.upload-notification-item.done .upload-item-icon{color:#10b981}.upload-notification-item.error .upload-item-icon{color:#ef4444}.upload-item-status{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280;font-weight:500}.upload-spinner{width:14px;height:14px;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.upload-progress-bar{height:6px;background:#f3f4f6;border-radius:3px;overflow:hidden;position:relative}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative}.upload-progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media(max-width:768px){.upload-notification-container{right:12px;bottom:12px;width:calc(100vw - 24px);max-width:400px}.upload-notification-header{padding:16px}.header-icon-wrapper{width:36px;height:36px}.upload-notification-list{padding:12px}.upload-notification-item{padding:14px}}.company-page-layout{display:flex;position:relative;min-height:100%}.company-list-view{padding:24px 32px;display:flex;flex-direction:column;gap:20px}.company-list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.company-search-box{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:0 14px;max-width:400px;flex:1;transition:all .2s ease}.company-search-box .search-icon{color:var(--text-muted);font-size:18px;flex-shrink:0}.company-search-box input{background:transparent;border:none;color:var(--text-primary);padding:10px 0;width:100%;font-size:14px;transition:all .2s ease}.company-search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;background:#0000004d}.btn-create-company{display:flex;align-items:center;gap:8px;background:#2563eb;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-create-company:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.company-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;text-align:center}.company-empty-state .empty-icon{font-size:56px;color:var(--text-muted);margin-bottom:16px}.company-empty-state h3{margin:0 0 8px;font-size:20px;color:var(--text-primary)}.company-empty-state p{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.company-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding-bottom:24px}.company-card{background:var(--surface-1);border:1px solid rgba(255,255,255,.05);border-radius:12px;overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.company-card:hover{border-color:#5d5fef40;box-shadow:0 4px 16px #0003;transform:translateY(-2px)}.company-card.active{border-color:#3b82f666;box-shadow:0 4px 20px #2563eb26}.card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px;gap:12px}.card-title-group{display:flex;flex-direction:column;gap:8px}.card-company-name{margin:0;font-size:16px;font-weight:600;color:var(--text-primary);line-height:1.4}.cm-status-badge{display:inline-flex;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;width:fit-content}.cm-status-badge.active{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.cm-status-badge.inactive{background:#6b72801a;color:#6b7280;border:1px solid rgba(107,114,128,.2)}.card-actions{display:flex;gap:8px}.action-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);border-radius:8px;padding:8px;cursor:pointer;display:flex;align-items:center;font-size:16px;transition:all .2s}.action-btn:hover{background:var(--surface-3);color:var(--text-primary)}.action-btn.delete:hover{background:#ef44441a;color:#ef4444;border-color:#ef444433}.card-body{padding:0 20px 16px;display:flex;flex-direction:column;gap:8px;flex:1}.detail-row{display:flex;gap:8px;font-size:13px}.detail-label{color:var(--text-muted);min-width:50px}.detail-value{color:var(--text-secondary);font-weight:500}.company-card .card-footer{padding:16px 20px;background:var(--surface-2);border-top:1px solid var(--border)}.btn-switch-company{width:100%;padding:0;background:transparent;border:none;color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-switch-company:hover{color:#60a5fa}.active-indicator{display:flex;align-items:center;gap:6px;justify-content:center;color:#10b981;font-size:13px;font-weight:600}.cm-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:cmFadeIn .2s ease}@keyframes cmFadeIn{0%{opacity:0}to{opacity:1}}.cm-popup{background:#fff;border:1px solid #E5E7EB;border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;animation:cmSlideUp .25s ease;overflow:hidden}@keyframes cmSlideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.spinning{animation:spin 1s linear infinite}.cm-popup-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #E5E7EB;flex-shrink:0}.cm-popup-header h2{font-family:var(--font-display);font-size:17px;font-weight:700;color:#111827;margin:0}.cm-popup-close{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;color:#9ca3af;cursor:pointer;transition:all .15s ease;background:transparent;border:none}.cm-popup-close:hover{background:#f3f4f6;color:#374151}.cm-popup-body{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:24px;background:#fff}.cm-popup-footer{display:flex;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid #E5E7EB;justify-content:flex-end;flex-shrink:0;background:#fff}.cm-popup-section{display:flex;flex-direction:column;gap:14px}.cm-popup-section-title{font-size:12px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.05em;margin:0;padding-bottom:10px;border-bottom:none}.company-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.span-2{grid-column:span 2}.form-group label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.form-group label .required{color:#ef4444;margin-left:2px}.form-group input,.form-group select{padding:12px 14px;background:#f5f3ff;border:1px solid #E5E7EB;border-radius:8px;color:#374151;font-size:14px;transition:all .2s ease;font-family:var(--font-body)}.form-group input::placeholder{color:#9ca3af}.form-group input:focus,.form-group select:focus{outline:none;border-color:#818cf8;box-shadow:0 0 0 3px #818cf826;background:#f5f3ff}.form-group input[readonly],.form-group select:disabled{background:#f5f3ff;border:1px solid #E5E7EB;cursor:default;color:#374151}.form-group input[readonly]:focus,.form-group select:disabled:focus{box-shadow:none;border-color:#e5e7eb}.form-group input[readonly]::placeholder{color:#9ca3af}.cm-popup-view-body{gap:20px}.cm-view-status-row{display:flex;align-items:center;gap:8px}.cm-view-section{display:flex;flex-direction:column;gap:12px}.cm-view-section-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.cm-view-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.cm-view-field{display:flex;flex-direction:column;gap:3px}.cm-view-label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.cm-view-value{font-size:14px;font-weight:500;color:var(--text-primary)}.cm-view-address{font-size:14px;color:var(--text-primary);line-height:1.5}.cm-view-address p{margin:0}.btn-cancel{padding:9px 20px;background:#f3f4f6;color:#374151;border:1px solid #E5E7EB;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#e5e7eb;border-color:#d1d5db}.btn-save{display:flex;align-items:center;gap:6px;padding:9px 20px;background:#6366f1;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover:not(:disabled){background:#4f46e5}.btn-save:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed}.mt-4{margin-top:16px}@media(max-width:768px){.company-form-grid{grid-template-columns:1fr}.form-group.span-2{grid-column:span 1}.cm-view-grid{grid-template-columns:1fr}.cm-popup{max-width:100%;max-height:90vh}}.company-list-view{flex:1;min-width:0;transition:flex .3s ease}.cm-drawer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;pointer-events:none}.cm-drawer.open{pointer-events:all}.cm-drawer-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;transition:background .3s ease}.cm-drawer.open .cm-drawer-backdrop{background:#00000059}.cm-drawer-panel{position:absolute;right:0;top:0;bottom:0;width:380px;max-width:90vw;background:var(--surface-1, #13131F);border-left:1px solid rgba(255,255,255,.07);box-shadow:-8px 0 40px #0006;transform:translate(100%);transition:transform .3s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;overflow:hidden}.cm-drawer.open .cm-drawer-panel{transform:translate(0)}.cm-drawer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;gap:12px}.cm-drawer-title-group{display:flex;align-items:flex-start;gap:12px;min-width:0}.cm-drawer-avatar{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#5d5fef,#7879f1);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #5d5fef4d}.cm-drawer-name{font-size:16px;font-weight:700;color:var(--text-primary, #fff);margin:0 0 6px;line-height:1.3;word-break:break-word}.cm-drawer-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cm-drawer-active-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#10b981;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:20px;padding:2px 8px}.cm-drawer-body{flex:1;overflow-y:auto;padding:16px 20px 24px;display:flex;flex-direction:column;gap:20px}.cm-drawer-body::-webkit-scrollbar{width:4px}.cm-drawer-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.cm-drawer-actions{display:flex;gap:8px;flex-wrap:wrap;padding-bottom:4px}.cm-drawer-action-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-primary, #fff);transition:all .2s;font-family:var(--font-body, sans-serif)}.cm-drawer-action-btn:hover{background:#ffffff1a;border-color:#ffffff2e;transform:translateY(-1px)}.cm-drawer-action-btn.primary{background:#5d5fef26;border-color:#5d5fef4d;color:#7879f1}.cm-drawer-action-btn.primary:hover{background:#5d5fef40;border-color:#5d5fef80;color:#fff}.cm-drawer-action-btn.danger{background:#ef444414;border-color:#ef444433;color:#ef4444}.cm-drawer-action-btn.danger:hover{background:#ef444426;border-color:#ef444459}.company-card.selected{border-color:#5d5fef73!important;box-shadow:0 0 0 2px #5d5fef33,0 4px 20px #0003!important}.um-page{padding:28px 32px;overflow-y:auto;height:100vh;animation:fadeIn .3s ease}.um-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:20px;flex-wrap:wrap}.um-title{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.um-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.um-header-actions{display:flex;gap:10px;flex-shrink:0}.um-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;transition:all var(--transition-fast);cursor:pointer;border:none;white-space:nowrap}.um-btn-primary{background:var(--purple-base);color:#fff;box-shadow:0 0 12px #5d5fef4d}.um-btn-primary:hover{background:var(--purple-light);box-shadow:0 0 20px #5d5fef80;transform:translateY(-1px)}.um-btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.um-btn-secondary{background:var(--surface-3);color:var(--text-primary);border:1px solid var(--border)}.um-btn-secondary:hover{background:var(--surface-2);border-color:var(--purple-base)}.um-btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.um-btn-ghost:hover{background:var(--surface-3);color:var(--text-primary)}.um-btn-danger{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.um-btn-danger:hover{background:#ff6b6b40}.um-btn-success{background:#00c48c26;color:#00c48c;border:1px solid rgba(0,196,140,.3)}.um-btn-success:hover{background:#00c48c40}.um-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.um-kpi-card{display:flex;align-items:center;gap:16px;padding:20px 22px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast);animation:scaleIn .3s ease both}.um-kpi-card:nth-child(2){animation-delay:.05s}.um-kpi-card:nth-child(3){animation-delay:.1s}.um-kpi-card:nth-child(4){animation-delay:.15s}.um-kpi-card:hover{border-color:#5d5fef4d;box-shadow:0 4px 20px #0000004d}.um-kpi-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.um-kpi-icon.total{background:#5d5fef26;color:var(--purple-base)}.um-kpi-icon.active{background:#00c48c26;color:#00c48c}.um-kpi-icon.invited{background:#38bdf826;color:#38bdf8}.um-kpi-icon.suspended,.um-kpi-icon.inactive{background:#ef444426;color:#ef4444}.um-kpi-info{display:flex;flex-direction:column}.um-kpi-count{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--text-primary);line-height:1}.um-kpi-label{font-size:12.5px;color:var(--text-muted);margin-top:4px}.um-templates-shelf{margin-bottom:24px}.um-shelf-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.um-shelf-chips{display:flex;gap:10px;flex-wrap:wrap}.um-template-chip{display:flex;flex-direction:column;gap:2px;padding:12px 18px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.um-template-chip:hover{border-color:var(--purple-base);background:var(--surface-3)}.um-chip-name{font-size:13.5px;font-weight:600;color:var(--text-primary)}.um-chip-count{font-size:11.5px;color:var(--text-muted)}.um-chip-add{display:flex;align-items:center;gap:6px;padding:12px 18px;background:transparent;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--purple-base);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.um-chip-add:hover{border-color:var(--purple-base);background:#5d5fef14}.um-table-container{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.um-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--border)}.um-toolbar-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap;flex:1}.um-toolbar-right{display:flex;gap:8px}.um-filter-tabs{display:flex;gap:4px;background:var(--surface-2);border-radius:var(--radius-sm);padding:3px}.um-filter-tab{padding:6px 14px;border-radius:4px;font-size:12.5px;font-weight:500;color:var(--text-muted);background:transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.um-filter-tab:hover{color:var(--text-secondary)}.um-filter-tab.active{background:var(--purple-base);color:#fff}.um-table-wrapper{overflow-x:auto}.um-table{width:100%;border-collapse:collapse}.um-table thead{background:var(--surface-2)}.um-table th{padding:12px 16px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);text-align:left;white-space:nowrap}.um-th-check{width:44px}.um-table td{padding:14px 16px;border-bottom:1px solid var(--border-light);vertical-align:middle}.um-table tbody tr{transition:background var(--transition-fast)}.um-table tbody tr.clickable{cursor:pointer}.um-table tbody tr.clickable:hover{background:#5d5fef14}.um-table tbody tr:hover{background:#5d5fef0a}.um-table tbody tr.selected{background:#5d5fef14}.um-empty-row{text-align:center;color:var(--text-muted);padding:40px 16px!important;font-size:14px}.um-checkbox{width:16px;height:16px;accent-color:var(--purple-base);cursor:pointer;flex-shrink:0}.um-user-cell{display:flex;align-items:center;gap:12px}.um-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}.um-avatar.lg{width:48px;height:48px;font-size:17px}.um-user-info{display:flex;flex-direction:column}.um-user-name{font-size:13.5px;font-weight:600;color:var(--text-primary)}.um-user-pending{font-size:13.5px;font-style:italic;color:var(--text-muted)}.um-user-last-active{font-size:11.5px;color:var(--text-muted);display:flex;align-items:center;gap:4px;margin-top:2px}.um-contact-cell{display:flex;flex-direction:column;gap:2px}.um-contact-email{font-size:13px;color:var(--text-primary)}.um-contact-phone{font-size:12px;color:var(--text-muted)}.um-template-cell{display:flex;flex-direction:column;gap:4px}.um-template-badge{display:inline-block;padding:3px 10px;background:#5d5fef1f;color:var(--purple-light);border-radius:4px;font-size:12px;font-weight:600}.um-override-indicators{display:flex;gap:4px}.um-override-badge{font-size:11px;font-weight:700;padding:1px 6px;border-radius:3px}.um-override-badge.added{background:#00c48c26;color:#00c48c}.um-override-badge.removed{background:#ff6b6b26;color:#ff6b6b}.um-access-badge{padding:3px 10px;border-radius:4px;font-size:12px;font-weight:600}.um-access-badge.all{background:#00c48c1f;color:#00c48c}.um-access-badge.specific,.um-company-name-tag{display:inline-block;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:500;background:var(--surface-3);border:1px solid var(--border);color:var(--text-secondary)}.um-company-name-tag:hover{border-color:var(--purple-base);color:var(--text-primary)}.um-status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.um-status-badge.active{background:#00c48c26;color:#00c48c}.um-status-badge.invited{background:#38bdf826;color:#38bdf8}.um-status-badge.suspended,.um-status-badge.inactive{background:#ef444426;color:#ef4444}.um-actions-cell{display:flex;gap:4px}.um-icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-secondary);background:transparent;transition:all var(--transition-fast);cursor:pointer}.um-icon-btn:hover{background:var(--surface-3);color:var(--text-primary)}.um-icon-btn.resend:hover{color:#38bdf8;background:#38bdf81a}.um-icon-btn.activate:hover{color:#00c48c;background:#00c48c1a}.um-table-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border)}.um-showing-text{font-size:12.5px;color:var(--text-muted)}.um-pagination{display:flex;gap:4px}.um-page-btn{min-width:32px;height:32px;padding:0 8px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;cursor:pointer;transition:all var(--transition-fast)}.um-page-btn:hover:not(:disabled){background:var(--surface-3)}.um-page-btn.active{background:var(--purple-base);color:#fff}.um-page-btn:disabled{opacity:.3;cursor:not-allowed}.um-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding:20px}.um-modal{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:90vh;width:100%;animation:scaleIn .2s ease;box-shadow:0 20px 60px #00000080}.um-modal-md{max-width:580px}.um-modal-lg{max-width:720px}.um-modal-xl{max-width:920px}.um-create-tpl-fields{display:flex;gap:16px;margin-bottom:8px}.um-rights-matrix-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:20px}.um-matrix-search{position:relative;flex:1;max-width:320px}.um-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:16px;pointer-events:none}.um-matrix-search-input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px 8px 36px;color:var(--text-primary);font-size:13px;outline:none;transition:all .2s}.um-matrix-search-input:focus{border-color:var(--purple-base);background:var(--surface-1);box-shadow:0 0 0 2px #5d5fef1a}.um-rights-matrix{display:flex;flex-direction:column;gap:10px;max-height:none;overflow-y:visible;padding-right:0}.um-rights-matrix.view-only{max-height:none}.um-rights-cat-block{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;overflow:visible;flex-shrink:0;margin-bottom:8px}.um-rights-cat-header{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--surface-3);border-left:4px solid transparent;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.um-rights-cat-expander{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:16px;width:20px;transition:color .2s}.um-rights-cat-header:hover .um-rights-cat-expander{color:var(--text-primary)}.um-rights-cat-header:hover{background:var(--surface-1);filter:contrast(1.1) brightness(1.05);box-shadow:inset 0 0 10px #5d5fef0d}.um-rights-cat-check{display:flex;align-items:center;cursor:pointer}.um-rights-cat-name{font-size:13.5px;font-weight:700;flex:1;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary)}.um-rights-cat-count{font-size:11.5px;font-weight:600;color:var(--text-muted);background:var(--surface-1);padding:3px 10px;border-radius:10px;border:1px solid var(--border)}.um-rights-rows{display:flex;flex-direction:column}.um-rights-row{display:flex;align-items:center;gap:14px;padding:12px 16px 12px 28px;border-top:1px solid var(--border-light);min-height:48px;transition:background .12s}.um-rights-row:hover{background:#5d5fef0d;box-shadow:inset 4px 0 0 var(--purple-base),0 4px 12px #0000001a;padding-left:28px}.um-rights-row-check{display:flex;align-items:center;cursor:pointer;flex-shrink:0}.um-rights-row-label{font-size:13.5px;font-weight:500;color:var(--text-primary);flex:1;min-width:0;opacity:1}.um-rights-row-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}.um-action-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 14px;border-radius:14px;font-size:12px;font-weight:600;text-transform:capitalize;cursor:pointer;border:1px solid var(--border);-webkit-user-select:none;user-select:none;transition:all .15s ease;background:var(--surface-2);color:var(--text-muted);min-width:50px;justify-content:center}.um-action-chip:not(.view):hover{background:#5d5fef1a;color:#fff;border-color:var(--purple-base);transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #5d5fef66}.um-action-chip.on{background:#5d5fef40;color:#a5a6ff;border-color:#5d5fef80;box-shadow:0 0 8px #5d5fef26}.um-action-chip.on:hover{background:#5d5fef59}.um-action-chip.view{cursor:default;padding:4px 12px}.um-action-chip.view.on{background:#00c48c2e;color:#4ade80;border-color:#00c48c59}.um-action-chip.view.off{background:#ff6b6b12;color:var(--text-muted);border-color:transparent;opacity:.4}.um-override-perm-row{display:flex;align-items:center;gap:10px;padding:7px 14px;border-radius:var(--radius-sm);transition:background .1s}.um-override-perm-row:hover{background:var(--surface-2)}.um-override-perm-label{font-size:13px;color:var(--text-secondary);flex:1}.um-override-action-chips{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.um-ovr-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize;cursor:pointer;border:1px solid transparent;-webkit-user-select:none;user-select:none;transition:all .15s ease;background:transparent}.um-ovr-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.um-ovr-chip.state-none{color:var(--text-muted);opacity:.4;border-color:var(--border-light)}.um-ovr-chip.state-none .um-ovr-dot{background:var(--text-muted);opacity:.3}.um-ovr-chip.state-template{color:var(--purple-light, #7879F1);background:#5d5fef1a;border-color:#5d5fef40;opacity:1}.um-ovr-chip.state-template .um-ovr-dot{background:var(--purple-base)}.um-ovr-chip.state-added{color:#00c48c;background:#00c48c1a;border-color:#00c48c40;opacity:1}.um-ovr-chip.state-added .um-ovr-dot{background:#00c48c}.um-ovr-chip.state-removed{color:#ff6b6b;background:#ff6b6b14;border-color:#ff6b6b40;opacity:1}.um-ovr-chip.state-removed .um-ovr-dot{background:#ff6b6b}.um-ovr-chip:hover{transform:scale(1.05);opacity:1!important}.um-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.um-modal-header>div{flex:1}.um-modal-header h2{font-family:var(--font-display);font-size:19px;font-weight:700;color:var(--text-primary);margin:0}.um-modal-subtitle{font-size:13px;color:var(--text-secondary);margin:4px 0 0}.um-modal-close{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.um-modal-close:hover{background:var(--surface-3);color:var(--text-primary)}.um-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.um-modal-footer{display:flex;align-items:center;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}.um-field{margin-bottom:18px}.um-label{display:block;font-size:12.5px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.um-input{width:100%;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;transition:border-color var(--transition-fast)}.um-input:focus{border-color:var(--purple-base);outline:none}.um-input::placeholder{color:var(--text-muted)}.um-invite-section{margin-bottom:28px}.um-invite-section:last-child{margin-bottom:0}.um-invite-section-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.um-invite-section-title svg{font-size:16px;color:var(--purple-base)}.um-invite-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:8px}.um-perm-groups{display:flex;flex-direction:column;gap:12px;max-height:380px;overflow-y:auto;padding-right:4px}.um-perm-group{background:var(--surface-2);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px 14px}.um-perm-group-header{display:flex;align-items:center;gap:10px;cursor:pointer;padding-bottom:8px;border-bottom:1px solid var(--border-light);margin-bottom:8px}.um-perm-cat-name{font-size:13px;font-weight:600;color:var(--text-primary);flex:1}.um-perm-cat-count{font-size:11px;color:var(--text-muted)}.um-perm-list{display:flex;flex-direction:column;gap:6px}.um-perm-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;padding:4px 0 4px 24px;transition:color var(--transition-fast)}.um-perm-item:hover{color:var(--text-primary)}.um-errors{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:16px}.um-error-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#ff6b6b;padding:3px 0}.um-access-tabs{margin-top:16px}.um-tabs-nav{display:flex;gap:4px;background:var(--surface-2);border-radius:var(--radius-sm);padding:3px;margin-bottom:16px}.um-tabs-nav.detail{margin-top:16px}.um-tab-btn{flex:1;padding:8px 14px;border-radius:4px;font-size:13px;font-weight:500;color:var(--text-muted);background:transparent;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.um-tab-btn:hover{color:var(--text-secondary)}.um-tab-btn.active{background:var(--purple-base);color:#fff}.um-tab-badge{font-size:11px;font-weight:700;padding:1px 6px;border-radius:8px;background:#fff3}.um-tab-btn:not(.active) .um-tab-badge{background:var(--surface-3);color:var(--text-muted)}.um-tab-content{min-height:200px}.um-tab-content.detail{max-height:350px;overflow-y:auto}.um-tab-panel{animation:fadeIn .15s ease}.um-toggle-row{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.um-toggle-row:hover{background:var(--surface-2)}.um-all-toggle{background:var(--surface-2);border:1px solid var(--border-light)}.um-toggle-title{font-size:14px;font-weight:600;color:var(--text-primary);display:block}.um-toggle-desc{font-size:12px;color:var(--text-muted);display:block;margin-top:2px}.um-divider{height:1px;background:var(--border-light);margin:12px 0}.um-company-list,.um-page-list{display:flex;flex-direction:column;gap:4px}.um-company-item,.um-page-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.um-company-item:hover,.um-page-item:hover{background:var(--surface-2)}.um-company-item.dimmed,.um-page-item.dimmed{opacity:.4;pointer-events:none}.um-company-info,.um-page-info{display:flex;flex-direction:column}.um-company-name{font-size:13.5px;font-weight:500;color:var(--text-primary)}.um-company-meta{font-size:11.5px;color:var(--text-muted)}.um-page-name{font-size:13.5px;font-weight:500;color:var(--text-primary)}.um-page-desc{font-size:11.5px;color:var(--text-muted);display:block}.um-page-section{margin-bottom:8px}.um-page-section-header{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border-light);margin-bottom:4px}.um-page-section-name{font-size:13px;font-weight:600;color:var(--text-primary);flex:1}.um-template-cards{display:flex;flex-direction:column;gap:10px}.um-template-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;cursor:pointer;transition:all var(--transition-fast)}.um-template-card:hover{border-color:var(--purple-base)}.um-template-card.selected{border-color:var(--purple-base);background:#5d5fef14;box-shadow:0 0 0 1px var(--purple-base)}.um-tpl-card-header{display:flex;align-items:center;justify-content:space-between}.um-tpl-card-name{font-size:14px;font-weight:600;color:var(--text-primary)}.um-tpl-card-count{font-size:12px;color:var(--text-muted)}.um-tpl-card-rights{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:10px}.um-tpl-cat-group{display:flex;flex-direction:column;gap:4px}.um-tpl-cat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.um-tpl-cat-tags{display:flex;flex-wrap:wrap;gap:4px}.um-tpl-tag{padding:3px 8px;border-radius:4px;font-size:11.5px;font-weight:500;background:var(--surface-3);color:var(--text-secondary)}.um-tpl-tag.cat-users{background:#5d5fef1f;color:#7879f1}.um-tpl-tag.cat-listings{background:#00c48c1f;color:#00c48c}.um-tpl-tag.cat-tally{background:#a78bfa1f;color:#a78bfa}.um-tpl-tag.cat-files{background:#38bdf81f;color:#38bdf8}.um-tpl-tag.cat-ai{background:#f472b61f;color:#f472b6}.um-tpl-tag.cat-invoices{background:#ffb5471f;color:#ffb547}.um-template-checklist{display:flex;flex-direction:column;gap:8px}.um-tpl-check-row{display:flex;align-items:flex-start;gap:12px;padding:13px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex-wrap:wrap}.um-tpl-check-row:hover{border-color:var(--purple-base);background:#5d5fef0a}.um-tpl-check-row.selected{border-color:var(--purple-base);background:#5d5fef17;box-shadow:0 0 0 1px var(--purple-base)}.um-radio{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:50%;border:2px solid var(--border);background:var(--surface-3);cursor:pointer;flex-shrink:0;margin-top:2px;transition:all var(--transition-fast);position:relative}.um-radio:checked{border-color:var(--purple-base);background:var(--purple-base);box-shadow:inset 0 0 0 4px var(--surface-2)}.um-tpl-check-info{flex:1;display:flex;flex-direction:column;gap:2px}.um-tpl-check-name{font-size:14px;font-weight:600;color:var(--text-primary)}.um-tpl-check-count{font-size:12px;color:var(--text-muted)}.um-tpl-check-preview{width:100%;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:8px}.um-empty-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:var(--text-muted);font-size:13px;text-align:center}.um-warning-box{display:flex;align-items:center;gap:10px;padding:16px 20px;background:#ffb5471a;border:1px solid rgba(255,181,71,.3);border-radius:var(--radius-sm);color:#ffb547;font-size:14px}.um-override-legend{display:flex;gap:20px;padding:10px 14px;background:var(--surface-2);border-radius:var(--radius-sm);margin-bottom:14px}.um-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.um-legend-dot{width:8px;height:8px;border-radius:50%}.um-legend-item.template .um-legend-dot{background:var(--purple-base)}.um-legend-item.added .um-legend-dot{background:#00c48c}.um-legend-item.removed .um-legend-dot{background:#ff6b6b}.um-legend-item.none .um-legend-dot{background:var(--text-muted);opacity:.3}.um-override-group{margin-bottom:12px}.um-override-cat{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;display:block}.um-override-items{display:flex;flex-direction:column;gap:4px}.um-override-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary);background:transparent;cursor:pointer;transition:all var(--transition-fast);text-align:left}.um-override-btn:hover{background:var(--surface-2)}.um-ovr-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.um-override-btn.state-template .um-ovr-indicator{background:var(--purple-base)}.um-override-btn.state-template{color:var(--text-primary)}.um-override-btn.state-added .um-ovr-indicator{background:#00c48c}.um-override-btn.state-added{color:#00c48c}.um-override-btn.state-removed .um-ovr-indicator{background:#ff6b6b}.um-override-btn.state-removed{color:#ff6b6b}.um-override-btn.state-none .um-ovr-indicator{background:var(--text-muted);opacity:.3}.um-override-btn.state-none{color:var(--text-muted);opacity:.6}.um-ovr-strikethrough{text-decoration:line-through}.um-ovr-tag{font-size:11px;font-weight:700;padding:1px 6px;border-radius:3px;margin-left:auto}.um-override-btn.state-added .um-ovr-tag{background:#00c48c26;color:#00c48c}.um-override-btn.state-removed .um-ovr-tag{background:#ff6b6b26;color:#ff6b6b}.um-access-summary{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--surface-2);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-top:14px;flex-wrap:wrap}.um-summary-item{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-secondary);font-weight:500}.um-summary-item.added{color:#00c48c}.um-summary-item.removed{color:#ff6b6b}.um-edit-user-summary{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface-2);border-radius:var(--radius-sm);margin-bottom:16px}.um-edit-user-info{display:flex;flex-direction:column;gap:2px}.um-edit-user-name{font-size:15px;font-weight:600;color:var(--text-primary)}.um-edit-user-email{font-size:12.5px;color:var(--text-muted)}.um-detail-header{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface-2);border-radius:var(--radius-sm)}.um-detail-info{flex:1;display:flex;flex-direction:column}.um-detail-name{font-size:16px;font-weight:700;color:var(--text-primary)}.um-detail-contact{font-size:12.5px;color:var(--text-muted)}.um-detail-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.um-detail-tag{padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;background:var(--surface-3);color:var(--text-secondary)}.um-detail-tag.template{background:#5d5fef1f;color:var(--purple-light)}.um-detail-tag.added{background:#00c48c26;color:#00c48c}.um-detail-tag.removed{background:#ff6b6b26;color:#ff6b6b}.um-detail-count{font-size:13px;color:var(--text-muted);margin-bottom:14px;font-weight:500}.um-detail-perm-group{margin-bottom:14px}.um-detail-perm-cat{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;display:block}.um-detail-perm-item{display:flex;align-items:center;gap:8px;padding:6px 0 6px 4px;font-size:13px;color:var(--text-primary);transition:opacity var(--transition-fast)}.um-detail-perm-item.dimmed{opacity:.35}.um-perm-check{font-size:16px;flex-shrink:0}.um-perm-check.on{color:#00c48c}.um-perm-check.off{color:var(--text-muted);opacity:.4}.um-micro-tag{font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px;margin-left:4px}.um-micro-tag.added{background:#00c48c26;color:#00c48c}.um-micro-tag.removed{background:#ff6b6b26;color:#ff6b6b}.um-strikethrough{text-decoration:line-through}.um-detail-all-msg{display:flex;align-items:center;gap:10px;padding:16px 20px;background:#00c48c14;border:1px solid rgba(0,196,140,.2);border-radius:var(--radius-sm);color:#00c48c;font-size:14px}.um-detail-company-list{display:flex;flex-direction:column;gap:4px}.um-detail-company{display:flex;align-items:center;gap:10px;padding:8px 4px}.um-detail-company.dimmed{opacity:.35}.um-activity-list{display:flex;flex-direction:column}.um-activity-item{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--border-light)}.um-activity-item:last-child{border-bottom:none}.um-activity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.um-activity-text{flex:1;font-size:13px;color:var(--text-primary)}.um-activity-time{font-size:12px;color:var(--text-muted);white-space:nowrap}.um-toast-container{position:fixed;bottom:24px;right:24px;z-index:1100;display:flex;flex-direction:column;gap:8px}.um-toast{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;animation:scaleIn .2s ease}.um-toast.success{background:#00c48c26;color:#00c48c;border:1px solid rgba(0,196,140,.3)}.um-toast.error{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}@media(max-width:1024px){.um-kpi-row{grid-template-columns:repeat(2,1fr)}.um-invite-fields{grid-template-columns:1fr}}@media(max-width:768px){.um-page{padding:20px 16px}.um-header{flex-direction:column}.um-kpi-row{grid-template-columns:1fr 1fr}.um-toolbar{flex-direction:column;align-items:flex-start}.um-toolbar-left{flex-direction:column;width:100%}.um-search-box{min-width:unset;width:100%}.um-filter-tabs{width:100%;overflow-x:auto}.um-modal{margin:10px}}.um-template-chip.clickable{cursor:pointer;position:relative}.um-template-chip.clickable:hover{border-color:var(--purple-base);background:#5d5fef14;box-shadow:0 0 16px #5d5fef26;transform:translateY(-1px)}.um-chip-users{font-size:11px;color:var(--purple-light);opacity:.7}.um-manage-header-info{display:flex;flex-direction:column;gap:2px}.um-manage-meta{font-size:12.5px;color:var(--text-muted)}.um-manage-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.um-manage-edit-actions{display:flex;gap:6px}.um-btn-sm{padding:6px 12px;font-size:12px}.um-manage-setting{margin-bottom:24px}.um-manage-name-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface-2);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.um-manage-current-name{font-size:15px;font-weight:600;color:var(--text-primary)}.um-manage-name-edit{display:flex;align-items:center;gap:8px}.um-manage-name-edit .um-input{flex:1}.um-manage-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.um-manage-info-item{display:flex;flex-direction:column;gap:4px;padding:14px 16px;background:var(--surface-2);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.um-manage-info-label{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.um-manage-info-value{font-size:20px;font-weight:700;color:var(--text-primary);font-family:var(--font-display)}.um-danger-zone{display:flex;flex-direction:column;gap:16px}.um-danger-card{padding:20px;background:#ff6b6b0a;border:1px solid rgba(255,107,107,.2);border-radius:var(--radius-sm)}.um-danger-card-info h3{font-family:var(--font-display);font-size:15px;font-weight:700;color:#ff6b6b;margin-bottom:6px}.um-danger-card-info p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:16px}.um-danger-card-info strong{color:#ff6b6b}.um-danger-confirm{margin-top:12px;padding:14px 16px;background:#ff6b6b14;border:1px solid rgba(255,107,107,.3);border-radius:var(--radius-sm)}.um-danger-confirm-text{font-size:13px;font-weight:600;color:#ff6b6b;margin-bottom:12px}.um-danger-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.um-tab-btn.danger{color:#ff6b6b99}.um-tab-btn.danger:hover{color:#ff6b6b}.um-tab-btn.danger.active{background:#ff6b6bcc;color:#fff}.um-no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;background:#ffffff05;border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--text-muted);text-align:center;animation:fadeIn .3s ease}.um-no-results svg{font-size:32px;color:var(--purple-base);opacity:.6}.um-no-results span{font-size:14px}.um-no-results strong{color:var(--text-primary)}.um-strength{display:flex;align-items:center;gap:8px;margin-top:6px}.um-strength-bars{display:flex;gap:4px;flex:1}.um-strength-bar{flex:1;height:3px;border-radius:2px;background:#ffffff1a;transition:background .3s ease}.um-strength-bar.filled.weak{background:#ff6b6b}.um-strength-bar.filled.fair{background:#ffb547}.um-strength-bar.filled.good{background:#38bdf8}.um-strength-bar.filled.strong{background:#00c48c}.um-strength-label{font-size:11px;font-weight:600;min-width:44px;text-align:right}.um-modal.confirmation{max-width:480px}.um-delete-warning-icon{width:64px;height:64px;background:#ef44441a;color:#ef4444;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 20px}.um-delete-confirm-text{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:10px}.text-center{text-align:center}.auth-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-color, #0D0D14);overflow:hidden;z-index:9999}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.auth-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.15}.auth-orb-1{width:600px;height:600px;background:radial-gradient(circle,#5D5FEF,transparent 70%);top:-200px;left:-100px;animation:authOrbFloat 12s ease-in-out infinite alternate}.auth-orb-2{width:400px;height:400px;background:radial-gradient(circle,#7879F1,transparent 70%);bottom:-150px;right:-100px;animation:authOrbFloat 9s ease-in-out infinite alternate-reverse}.auth-orb-3{width:300px;height:300px;background:radial-gradient(circle,#4345C8,transparent 70%);top:50%;left:40%;transform:translate(-50%,-50%);animation:authOrbFloat 14s ease-in-out infinite alternate}.auth-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(93,95,239,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(93,95,239,.04) 1px,transparent 1px);background-size:40px 40px}@keyframes authOrbFloat{0%{transform:translate(0) scale(1)}to{transform:translate(30px,20px) scale(1.05)}}.auth-container{position:relative;z-index:1;display:flex;width:min(1100px,96vw);height:min(720px,94vh);background:var(--surface-1, #13131F);border:1px solid rgba(255,255,255,.06);border-radius:24px;overflow:hidden;box-shadow:0 40px 80px #0009,0 0 0 1px #5d5fef26;animation:authContainerIn .5s cubic-bezier(.22,1,.36,1) both}@keyframes authContainerIn{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-brand-panel{flex:0 0 420px;background:linear-gradient(135deg,#0f0f1e,#1a1a35,#0c0c1a);border-right:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden;display:flex;align-items:flex-start;padding:48px 40px}.auth-brand-panel:before{content:"";position:absolute;top:-120px;right:-60px;width:350px;height:350px;background:radial-gradient(circle,rgba(93,95,239,.2) 0%,transparent 70%);pointer-events:none}.auth-brand-panel:after{content:"";position:absolute;bottom:-80px;left:-40px;width:280px;height:280px;background:radial-gradient(circle,rgba(67,69,200,.15) 0%,transparent 70%);pointer-events:none}.auth-brand-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:32px;width:100%}.auth-logo{display:flex;align-items:center;gap:10px}.auth-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#5d5fef,#7879f1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;box-shadow:0 4px 16px #5d5fef66}.auth-logo-text{font-family:var(--font-display, "Sora", sans-serif);font-size:22px;font-weight:700;color:#fff;letter-spacing:-.02em}.auth-logo-text span{color:#7879f1}.auth-brand-tagline h1{font-family:var(--font-display, "Sora", sans-serif);font-size:28px;font-weight:700;line-height:1.25;color:#fff;margin-bottom:12px;letter-spacing:-.03em}.auth-brand-tagline p{font-size:14px;line-height:1.6;color:#ffffff8c}.auth-features{display:flex;flex-direction:column;gap:14px}.auth-feature-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px;transition:background .2s}.auth-feature-item:hover{background:#5d5fef14;border-color:#5d5fef33}.auth-feature-emoji{font-size:18px;flex-shrink:0;margin-top:1px}.auth-feature-title{display:block;font-size:13px;font-weight:600;color:#ffffffe6;margin-bottom:2px}.auth-feature-desc{display:block;font-size:12px;color:#ffffff73}.auth-testimonial{padding:16px;background:#5d5fef1a;border:1px solid rgba(93,95,239,.2);border-radius:12px}.auth-testimonial>p{font-size:13px;font-style:italic;color:#ffffffb3;line-height:1.6;margin-bottom:12px}.auth-testimonial-author{display:flex;align-items:center;gap:10px}.auth-testimonial-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#5d5fef,#7879f1);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.auth-testimonial-name{display:block;font-size:13px;font-weight:600;color:#ffffffe6}.auth-testimonial-role{display:block;font-size:11px;color:#fff6}.auth-form-panel{flex:1;overflow-y:auto;display:flex;align-items:center;justify-content:center;padding:36px 48px}.auth-form-panel::-webkit-scrollbar{width:4px}.auth-form-panel::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.auth-form-slide{width:100%;max-width:400px;animation:authSlideIn .35s cubic-bezier(.22,1,.36,1) both}@keyframes authSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.auth-form-wrapper{display:flex;flex-direction:column;gap:20px}.auth-form-wrapper.signup{gap:16px}.auth-form-header{margin-bottom:4px}.auth-form-header h2{font-family:var(--font-display, "Sora", sans-serif);font-size:26px;font-weight:700;color:var(--text-primary, #fff);letter-spacing:-.02em;margin-bottom:6px}.auth-form-header p{font-size:14px;color:var(--text-muted, rgba(255, 255, 255, .5))}.auth-google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;font-weight:500;color:var(--text-primary, #fff);font-family:var(--font-body, sans-serif);cursor:pointer;transition:all .2s ease}.auth-google-btn:hover{background:#ffffff17;border-color:#ffffff2e;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.auth-google-btn:active{transform:translateY(0)}.auth-google-icon{width:18px;height:18px;flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff14}.auth-divider span{font-size:12px;color:var(--text-muted, rgba(255, 255, 255, .4));white-space:nowrap}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:12px;font-weight:600;color:#ffffffa6;letter-spacing:.04em;text-transform:uppercase}.auth-label-row{display:flex;align-items:center;justify-content:space-between}.auth-forgot-link{font-size:12px;font-weight:500;color:var(--purple-light, #7879F1);background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color .15s}.auth-forgot-link:hover{color:#fff}.auth-input-group{position:relative;display:flex;align-items:center}.auth-input-icon{position:absolute;left:14px;display:flex;align-items:center;font-size:16px;color:#ffffff59;pointer-events:none;transition:color .2s}.auth-input{width:100%;padding:11px 14px 11px 42px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;color:var(--text-primary, #fff);font-family:var(--font-body, sans-serif);transition:all .2s ease}.auth-input::placeholder{color:#ffffff40}.auth-input:focus{border-color:var(--purple-base, #5D5FEF);background:#5d5fef0f;box-shadow:0 0 0 3px #5d5fef1f}.auth-input:focus~.auth-input-icon,.auth-input-group:focus-within .auth-input-icon{color:var(--purple-light, #7879F1)}.auth-field.error .auth-input{border-color:var(--error, #FF6B6B);background:#ff6b6b0a}.auth-eye-btn{position:absolute;right:12px;display:flex;align-items:center;font-size:16px;color:#ffffff4d;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:color .15s}.auth-eye-btn:hover{color:#ffffffb3}.auth-error-msg{font-size:11.5px;color:var(--error, #FF6B6B);display:flex;align-items:center;gap:4px}.auth-strength{display:flex;align-items:center;gap:8px;margin-top:2px}.auth-strength-bars{display:flex;gap:4px;flex:1}.auth-strength-bar{flex:1;height:3px;border-radius:2px;background:#ffffff1a;transition:background .3s ease}.auth-strength-bar.filled.weak{background:#ff6b6b}.auth-strength-bar.filled.fair{background:#ffb547}.auth-strength-bar.filled.good{background:#38bdf8}.auth-strength-bar.filled.strong{background:#00c48c}.auth-strength-label{font-size:11px;font-weight:600;min-width:44px;text-align:right}.auth-strength-label.weak{color:#ff6b6b}.auth-strength-label.fair{color:#ffb547}.auth-strength-label.good{color:#38bdf8}.auth-strength-label.strong{color:#00c48c}.auth-terms{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:#ffffff8c;line-height:1.5}.auth-terms.error{color:var(--error, #FF6B6B)}.auth-terms-check{flex-shrink:0;width:15px;height:15px;margin-top:2px;accent-color:var(--purple-base, #5D5FEF);cursor:pointer}.auth-submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 24px;background:linear-gradient(135deg,#5d5fef,#7879f1);border-radius:10px;font-size:15px;font-weight:600;color:#fff;font-family:var(--font-body, sans-serif);cursor:pointer;border:none;transition:all .2s ease;box-shadow:0 4px 16px #5d5fef59;margin-top:4px;letter-spacing:.01em}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #5d5fef80;background:linear-gradient(135deg,#6567f0,#8a8bf2)}.auth-submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #5d5fef4d}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-submit-btn.loading{pointer-events:none}.auth-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:inline-block;animation:authSpin .7s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.auth-switch-text{text-align:center;font-size:13.5px;color:#ffffff73}.auth-switch-link{background:none;border:none;font-family:inherit;font-size:inherit;font-weight:600;color:var(--purple-light, #7879F1);cursor:pointer;padding:0;transition:color .15s}.auth-switch-link:hover{color:#fff;text-decoration:underline}@media(max-width:760px){.auth-container{flex-direction:column;height:auto;max-height:96vh;border-radius:16px}.auth-brand-panel{flex:0 0 auto;padding:28px 28px 24px;border-right:none;border-bottom:1px solid rgba(255,255,255,.05)}.auth-features,.auth-testimonial{display:none}.auth-brand-tagline h1{font-size:22px}.auth-brand-content{gap:16px}.auth-form-panel{padding:24px 24px 32px}.auth-field-row{grid-template-columns:1fr}}[data-theme=light] .auth-page{background:#f5f5fa}[data-theme=light] .auth-orb-1,[data-theme=light] .auth-orb-2,[data-theme=light] .auth-orb-3{opacity:.07}[data-theme=light] .auth-grid{background-image:linear-gradient(rgba(93,95,239,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(93,95,239,.06) 1px,transparent 1px)}[data-theme=light] .auth-container{background:#fff;border-color:#00000014;box-shadow:0 40px 80px #0000001a,0 0 0 1px #5d5fef1a}[data-theme=light] .auth-brand-panel{background:linear-gradient(135deg,#f0f0ff,#e8e8fa,#f4f4ff);border-right-color:#0000000f}[data-theme=light] .auth-brand-tagline h1,[data-theme=light] .auth-logo-text{color:#13131f}[data-theme=light] .auth-brand-tagline p{color:#6b6b8a}[data-theme=light] .auth-feature-item{background:#5d5fef0f;border-color:#5d5fef1f}[data-theme=light] .auth-feature-item:hover{background:#5d5fef1a;border-color:#5d5fef40}[data-theme=light] .auth-feature-title{color:#13131f}[data-theme=light] .auth-feature-desc{color:#6b6b8a}[data-theme=light] .auth-testimonial{background:#5d5fef0f;border-color:#5d5fef26}[data-theme=light] .auth-testimonial>p{color:#4a4a68}[data-theme=light] .auth-testimonial-name{color:#13131f}[data-theme=light] .auth-testimonial-role{color:#8e8e9f}[data-theme=light] .auth-form-panel::-webkit-scrollbar-thumb{background:#0000001f}[data-theme=light] .auth-form-header h2{color:#13131f}[data-theme=light] .auth-form-header p{color:#8e8e9f}[data-theme=light] .auth-google-btn{background:#f5f5fa;border-color:#0000001a;color:#13131f}[data-theme=light] .auth-google-btn:hover{background:#eeeef6;border-color:#00000026;box-shadow:0 4px 12px #0000000f}[data-theme=light] .auth-divider:before,[data-theme=light] .auth-divider:after{background:#0000001a}[data-theme=light] .auth-divider span{color:#8e8e9f}[data-theme=light] .auth-label{color:#4a4a68}[data-theme=light] .auth-input{background:#f5f5fa;border:1px solid rgba(0,0,0,.12);color:#13131f}[data-theme=light] .auth-input::placeholder{color:#a0a0b8}[data-theme=light] .auth-input:focus{border-color:var(--purple-base, #5D5FEF);background:#fff;box-shadow:0 0 0 3px #5d5fef1f}[data-theme=light] .auth-input-icon,[data-theme=light] .auth-eye-btn{color:#8e8e9f}[data-theme=light] .auth-eye-btn:hover{color:#4a4a68}[data-theme=light] .auth-strength-bar{background:#00000014}[data-theme=light] .auth-terms{color:#6b6b8a}[data-theme=light] .auth-switch-text{color:#8e8e9f}[data-theme=light] .auth-switch-link:hover,[data-theme=light] .auth-forgot-link:hover{color:#13131f}.expense-map-modal{width:680px;max-width:95vw;max-height:82vh;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .2s ease}.expense-map-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0}.expense-map-modal-header h3{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.expense-map-close-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .15s ease}.expense-map-close-btn:hover{color:var(--text-primary)}.expense-map-modal-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:24px}.expense-map-loading,.expense-map-warning{display:flex;align-items:center;gap:8px;font-size:13px;padding:10px 12px;border-radius:var(--radius-sm)}.expense-map-loading{color:var(--text-muted)}.expense-map-warning{color:#ffb547;background:#ffb54714;border:1px solid rgba(255,181,71,.2)}.expense-map-section h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin:0 0 12px}.expense-map-empty{font-size:13px;color:var(--text-muted);padding:8px 0}.expense-map-rows{display:flex;flex-direction:column;gap:2px}.expense-map-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light, rgba(255, 255, 255, .05))}.expense-map-row:last-of-type{border-bottom:none}.expense-map-label{font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-map-select{background:var(--surface-2);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px;font-family:inherit;cursor:pointer;width:100%}.expense-map-select-compact{width:180px;min-width:140px}.expense-map-select:focus{outline:none;border-color:var(--purple-base, #5D5FEF)}.expense-map-select-sm{min-width:140px;width:auto}.expense-map-create-form{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:4px;margin-bottom:4px}.expense-map-input{flex:1;min-width:140px;background:var(--surface-3, rgba(255, 255, 255, .05));border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:5px 10px;font-size:13px;font-family:inherit}.expense-map-input:focus{outline:none;border-color:var(--purple-base, #5D5FEF)}.expense-map-create-submit,.expense-map-create-cancel{background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);padding:5px 8px;cursor:pointer;font-size:15px;display:flex;align-items:center;transition:all .15s ease}.expense-map-create-submit:hover:not(:disabled){background:var(--green, #00C48C);color:#fff;border-color:var(--green, #00C48C)}.expense-map-create-cancel:hover{background:#ff6b6b26;color:#ff6b6b;border-color:#ff6b6b4d}.expense-map-create-submit:disabled{opacity:.5;cursor:not-allowed}.expense-map-create-error{width:100%;font-size:12px;color:#ff6b6b}.expense-map-modal-footer{display:flex;align-items:center;gap:12px;justify-content:flex-end;padding:14px 20px;background:var(--surface-2);border-top:1px solid var(--border);flex-shrink:0}.expense-map-save-error{flex:1;font-size:12px;color:#ff6b6b}.expense-map-cancel-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s ease}.expense-map-cancel-btn:hover{background:var(--surface-3, rgba(255, 255, 255, .05));color:var(--text-primary)}.expense-map-save-btn{background:var(--purple-base, #5D5FEF);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 18px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.expense-map-save-btn:hover:not(:disabled){background:var(--purple-dark, #4345C8)}.expense-map-save-btn:disabled{opacity:.5;cursor:not-allowed}.spin-icon{animation:spin 1s linear infinite}.expense-map-llm-status{margin-bottom:8px}.expense-map-llm-note{font-size:12px;color:var(--text-muted);margin:0 0 10px;padding:6px 10px;background:#5d5fef12;border:1px solid rgba(93,95,239,.18);border-radius:var(--radius-sm)}.expense-map-row-disabled{grid-template-columns:1fr auto auto;opacity:.5;background:#ffffff05;border-radius:var(--radius-sm);padding:8px 10px}.expense-map-label-disabled{color:var(--text-muted);font-style:italic}.expense-map-disabled-msg{font-size:12px;color:var(--text-muted);white-space:nowrap}.expense-map-enable-btn{background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);padding:3px 10px;font-size:12px;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all .15s ease}.expense-map-enable-btn:hover{background:#00c48c1f;color:#00c48c;border-color:#00c48c66}.expense-map-disable-btn-text{opacity:.7}.expense-map-disable-btn-text:hover{background:#ff6b6b1a;color:#ff6b6b;border-color:#ff6b6b4d;opacity:1}.dashboard-page{padding:24px 32px;display:flex;flex-direction:column;gap:24px}.dashboard-header{margin-bottom:8px}.dashboard-main-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.dashboard-tagline{color:var(--text-muted);font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);border-color:var(--purple-light);box-shadow:var(--shadow-card)}.stat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.stat-icon-wrapper{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.stat-icon-wrapper>svg{color:inherit}.status-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700}.status-pill.green{background:#10b9811a;color:#10b981}.status-pill.orange{background:#f59e0b1a;color:#f59e0b}.status-pill.purple{background:#5d5fef1a;color:#5d5fef}.status-pill.red{background:#ef44441a;color:#ef4444}.status-dot{width:6px;height:6px;border-radius:50%}.status-dot.green{background:#10b981}.status-dot.orange{background:#f59e0b}.status-dot.purple{background:#5d5fef}.status-dot.red{background:#ef4444}.stat-label{font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:.05em;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.stat-subtitle{font-size:13px;color:var(--text-muted)}.charts-grid{display:grid;grid-template-columns:1fr;gap:24px}.chart-container{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.chart-title-block{display:flex;align-items:center;gap:16px}.chart-icon-box{width:36px;height:36px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-secondary)}.chart-subtitle{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:.05em}.chart-title{font-size:16px;font-weight:700;color:var(--text-primary)}.chart-filter-btn{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text-secondary)}.bar-chart{display:flex;height:240px;gap:16px;padding-top:20px}.y-axis{display:flex;flex-direction:column;justify-content:space-between;color:var(--text-muted);font-size:12px;padding-bottom:30px}.chart-area{flex:1;display:flex;align-items:flex-end;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:30px;position:relative}.bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}.bar{width:80%;max-width:100px;background:#3d3d33;border-radius:8px 8px 4px 4px;transition:all .3s ease}.bar-wrapper:hover .bar{background:#4a4a3e}.bar-tooltip{position:absolute;top:-24px;font-size:11px;font-weight:700;color:var(--text-primary)}.bar-label{position:absolute;bottom:-28px;font-size:11px;color:var(--text-muted);white-space:nowrap}.horizontal-bar-chart{display:flex;flex-direction:column;gap:20px}.h-bar-row{display:flex;align-items:center;gap:16px}.h-bar-label{width:120px;font-size:13px;color:var(--text-muted)}.h-bar-track{flex:1;height:32px;background:var(--surface-2);border-radius:6px;overflow:hidden}.h-bar-fill{height:100%;border-radius:0 4px 4px 0;transition:width 1s ease-out}.h-bar-value{width:20px;font-size:14px;color:var(--text-primary);text-align:right}.x-axis-horizontal{display:flex;justify-content:space-between;margin-left:136px;padding-top:10px;color:var(--text-muted);font-size:12px}.spin{animation:spin 2s linear infinite}.fade-in{animation:fadeIn .5s ease}.connect-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f3f4f6;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.connect-card{background:#fff;padding:3rem 2.5rem;border-radius:12px;width:380px;text-align:center;box-shadow:0 4px 20px #00000014}.connect-icon{width:56px;height:56px;border-radius:50%;font-size:1.6rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.connect-icon.success{background:#dcfce7;color:#16a34a}.connect-icon.error{background:#fee2e2;color:#dc2626}.connect-spinner{width:56px;height:56px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:connect-spin 1s linear infinite}@keyframes connect-spin{to{transform:rotate(360deg)}}.connect-title{font-size:1.4rem;margin-bottom:.5rem;color:#111827}.connect-message{color:#6b7280;font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.connect-retry-btn{padding:10px 28px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s;width:100%}.connect-retry-btn:hover{background:#1d4ed8}.connect-retry-btn:disabled{opacity:.6;cursor:not-allowed}.connect-auth-form{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.connect-input{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}.connect-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.connect-auth-error{color:#dc2626;font-size:.85rem;margin:0}.connect-toggle{color:#6b7280;font-size:.85rem;margin-top:4px}.connect-toggle-btn{background:none;border:none;color:#2563eb;cursor:pointer;font-size:.85rem;font-weight:600;padding:0}.connect-toggle-btn:hover{text-decoration:underline}.tally-erp-content{width:100%;margin:0;padding:24px 0}.configurations-main-card{background:var(--surface-1);border-radius:12px;border:1px solid var(--border);min-height:750px;margin:24px 60px 0;display:flex;flex-direction:column;overflow:hidden;width:auto}.configs-selection-area{display:flex;flex-direction:column;gap:16px;padding:24px;border-bottom:1px solid var(--border);flex-shrink:0}.select-group{display:flex;flex-direction:column;gap:8px;flex:1}.select-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.content-header{margin-bottom:24px;margin-left:60px;margin-right:60px;display:flex;align-items:center;justify-content:space-between}.content-header h1{font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.custom-dropdown-container{position:relative;width:100%}.custom-dropdown-trigger{width:100%;height:45px;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease}.custom-dropdown-trigger:hover{border-color:#5d5fef66}.custom-dropdown-trigger.open{border-color:var(--purple-base);box-shadow:0 0 0 3px #5d5fef1a}.custom-dropdown-trigger .select-icon{font-size:18px;color:var(--text-muted);transition:transform .3s ease}.custom-dropdown-trigger .select-icon.rotated{transform:rotate(180deg)}.custom-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;width:100%;background:var(--surface-1);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #00000014;padding:8px;z-index:100;display:flex;flex-direction:column;gap:4px}.dropdown-option{padding:10px 16px;border-radius:8px;font-size:14px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.dropdown-option:hover{background:#5d5fef0d;color:var(--text-primary)}.dropdown-option.selected{background:#5d5fef1a;color:var(--purple-base);font-weight:600}.f12-options-group{display:flex;gap:12px;margin-top:8px}.f12-option-btn{padding:10px 20px;background:var(--surface-1);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.f12-option-btn:hover{border-color:var(--purple-base);background:#5d5fef0d}.f12-option-btn.active{background:var(--purple-base);color:#fff;border-color:var(--purple-base)}.config-tally-layout{background:transparent;overflow:hidden;display:flex;flex-direction:column;flex:1}.tally-layout-header{background:var(--bg-secondary);padding:12px 24px;border-bottom:2px solid var(--border);flex-shrink:0}.feature-toggles{display:flex;flex-direction:column;gap:4px}.feature-toggle-item{font-size:13px;color:var(--text-secondary);font-style:italic;display:flex;align-items:center;gap:8px}.toggle-val{font-weight:700;font-style:normal;padding:4px 12px;border-radius:8px;display:inline-block;min-width:50px;text-align:center;font-size:12px;text-transform:uppercase}.toggle-val.yes{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.toggle-val.no{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.toggle-val.yes.active{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.tally-columns-grid{display:grid;grid-template-columns:1fr 1fr;flex:1;height:100%}.tally-column{padding:20px 24px;display:flex;flex-direction:column}.tally-column.divider{border-left:1px solid var(--border)}.tally-section{margin-bottom:24px}.section-title{font-size:15px;font-weight:700;color:#4a5568;margin-bottom:12px;padding-bottom:4px;border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.5px}.tally-row{display:flex;justify-content:space-between;align-items:flex-start;min-height:32px;padding:6px 0;font-size:14px;color:var(--text-primary)}.tally-row.sub{padding-left:24px}.tally-row.sub-2{padding-left:40px}.tally-row:hover{background:#5d5fef08}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 40px;text-align:center;background:transparent}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state p{color:var(--text-muted);font-size:15px}.animate-in{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:900px){.tally-columns-grid{grid-template-columns:1fr}.tally-column.divider{border-left:none;border-top:1px solid var(--border)}}.unique-configs-layout{padding:24px 32px;display:flex;flex-direction:column;gap:24px}.configs-morph-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;max-width:1100px}.morph-card{background:var(--surface-1);border:1px solid var(--border);padding:16px 20px;border-radius:20px 6px;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;flex-direction:column;justify-content:center;cursor:pointer;position:relative;overflow:hidden;min-height:85px;box-shadow:0 4px 10px #00000005}.morph-bg-pattern{position:absolute;right:-15px;bottom:-15px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(93,95,239,.04) 0%,transparent 70%);transition:all .5s ease;z-index:0}.morph-card:hover{border-radius:6px 20px;transform:translateY(-2px);box-shadow:0 8px 16px #5d5fef0f;border-color:#5d5fef4d}.morph-card:hover .morph-bg-pattern{transform:scale(1.2);background:radial-gradient(circle,rgba(93,95,239,.08) 0%,transparent 70%)}.morph-card.active{background:linear-gradient(135deg,var(--purple-base) 0%,#4648d9 100%);color:#fff;border-radius:12px;transform:scale(1.02) translateY(-1px);box-shadow:0 10px 24px #5d5fef40;border-color:transparent}.morph-card.active .morph-bg-pattern{background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);transform:scale(1.6)}.morph-content{display:flex;justify-content:space-between;align-items:center;z-index:1;position:relative;width:100%}.morph-text{display:flex;flex-direction:column;gap:4px;padding-right:12px}.morph-index{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:1px;transition:color .3s ease}.morph-card.active .morph-index{color:#ffffffb3}.morph-label{font-size:14px;font-weight:600;color:var(--text-primary);transition:color .3s ease;line-height:1.3}.morph-card.active .morph-label{color:#fff}.morph-icon-wrapper{width:36px;height:36px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.175,.885,.32,1.275);flex-shrink:0;border:1px solid var(--border)}.morph-card:hover .morph-icon-wrapper{background:#5d5fef14;color:var(--purple-base);border-color:#5d5fef33}.morph-card.active .morph-icon-wrapper{background:#fff;color:var(--purple-base);transform:rotate(360deg);border-color:transparent}.morph-icon{width:16px;height:16px;transition:stroke-dashoffset .4s ease}.morph-icon.check{stroke-dasharray:24;stroke-dashoffset:24;animation:drawCheck .4s forwards .3s}@keyframes drawCheck{to{stroke-dashoffset:0}}.custom-configs-actions{display:flex;align-items:center;gap:16px;padding-top:8px}.custom-save-btn{padding:10px 28px;background:var(--purple-base);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #5d5fef33;text-transform:uppercase;letter-spacing:.5px}.custom-save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #5d5fef4d}.custom-save-btn:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.last-saved-badge{font-size:12px;padding:8px 16px;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:8px;display:flex;align-items:center;gap:8px;color:#059669;box-shadow:0 2px 4px #0596690d}.last-saved-label{font-weight:500;opacity:.8}.last-saved-value{font-weight:700}.save-tick{font-size:10px;margin-left:4px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.custom-configs-grid{grid-template-columns:1fr}}.sync-tally-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,#5d5fef,#7879f1);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #5d5fef40}.sync-tally-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #5d5fef59}.sync-tally-btn:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed;box-shadow:none;opacity:.6}.sync-tally-btn.syncing{background:linear-gradient(135deg,#7879f1,#9b9cf2)}.sync-tally-btn.success{background:linear-gradient(135deg,#059669,#10b981)}.sync-tally-btn .sync-icon{font-size:16px}.sync-tally-btn .sync-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-error-banner{margin:0 60px 16px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;display:flex;align-items:center;gap:8px}.sync-warning-banner{margin:0 60px 16px;padding:12px 16px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;color:#d97706;font-size:14px;display:flex;align-items:center;gap:12px}.sync-warning-banner .sync-hint{font-size:13px;color:#92400e;opacity:.8}.config-loading{margin:0 60px 16px;padding:12px 16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;color:#0284c7;font-size:14px;display:flex;align-items:center;gap:8px}.toggle-val.no{background:linear-gradient(135deg,#f87171,#ef4444);color:#fff}.toggle-val.placeholder{background:#e5e7eb;color:#6b7280}.app-layout{display:flex;width:100%;height:100vh}.app-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;overflow:hidden;transition:margin-left var(--transition-normal);background:var(--bg-color)}.main-scroll-area{flex:1;overflow-y:auto;display:flex;flex-direction:column;position:relative}.app-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.app-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.invoice-view{flex:1;display:flex;overflow:hidden;animation:fadeIn var(--transition-fast)}.file-nav-panel{width:260px;min-width:260px;background:var(--surface-1);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;animation:fadeIn var(--transition-fast)}.file-nav-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:20px;color:var(--text-secondary);transition:all var(--transition-fast);flex-shrink:0}.file-nav-toggle:hover{background:var(--border-light);color:var(--text-primary)}.file-nav-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border-light)}.file-nav-title{font-size:14px;font-weight:600;color:var(--text-primary)}.file-nav-count{font-size:12px;font-weight:500;color:var(--text-muted);background:var(--border-light);padding:2px 8px;border-radius:10px}.file-nav-back{display:flex;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;color:var(--purple-base);border-bottom:1px solid var(--border-light);transition:background var(--transition-fast)}.file-nav-back:hover{background:var(--primary-subtle)}.file-nav-back-icon{font-size:16px;display:flex}.file-nav-list{flex:1;overflow-y:auto;padding:8px}.file-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);margin-bottom:2px}.file-nav-item:hover{background:var(--border-light)}.file-nav-item.active{background:var(--purple-deep);border:1px solid var(--purple-base);box-shadow:var(--purple-glow)}.file-nav-item-icon{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.file-nav-item-icon.pdf{background:#fef2f2;color:#dc2626}.file-nav-item-icon.image{background:#eff6ff;color:#2563eb}.file-nav-item-info{flex:1;min-width:0}.file-nav-item-name{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-nav-item-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.file-nav-item-status{flex-shrink:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:16px}.file-nav-item-status.success{color:var(--success)}.file-nav-item-status.error{color:var(--error)}.file-nav-item-status.processing{color:#ea580c}.invoice-content-panel{flex:1;overflow-y:auto;display:flex;flex-direction:column}.invoice-detail-header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:var(--header-height);background:var(--surface-1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);gap:16px;flex-shrink:0;position:relative;z-index:100}.invoice-detail-header-left{display:flex;align-items:center;gap:14px;min-width:0}.invoice-detail-file-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.invoice-detail-file-icon.pdf{background:#fef2f2;color:#dc2626}.invoice-detail-file-icon.image{background:#eff6ff;color:#2563eb}.invoice-detail-title-block{min-width:0}.invoice-detail-filename{font-size:16px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invoice-detail-meta{font-size:13px;color:var(--text-secondary);margin-top:2px;display:flex;align-items:center;gap:8px}.invoice-detail-status{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600}.invoice-detail-status.success{color:var(--success)}.invoice-detail-status.error{color:var(--error)}.invoice-detail-header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.invoice-detail-preview-btn,.invoice-detail-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:20px;color:var(--text-secondary);transition:all var(--transition-fast)}.invoice-detail-preview-btn:hover,.invoice-detail-close:hover{background:var(--border-light);color:var(--text-primary)}.invoice-detail-preview-btn.active{background:var(--primary-subtle);color:var(--primary)}.invoice-detail-content{flex:1;display:flex;overflow:hidden}.invoice-detail-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-color)}.invoice-detail-scroll-body{flex:1;padding:24px 28px;overflow-y:auto;scroll-behavior:smooth}.invoice-status-bar{display:flex;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:500;border-bottom:1px solid var(--border-light);flex-shrink:0}.invoice-status-bar.updated{background:#00c48c1a;color:#00c48c;border-left:3px solid #00C48C}.invoice-status-bar.pushed{background:#3b82f61a;color:#3b82f6;border-left:3px solid #3b82f6}.invoice-status-bar-icon{font-size:16px;flex-shrink:0}.invoice-detail-content.with-preview .invoice-detail-pane{flex:0 0 60%;max-width:60%}.invoice-detail-content.with-preview.with-chat .invoice-preview-panel{flex:0 0 35%;max-width:35%}.invoice-detail-content.with-preview.with-chat .invoice-detail-pane{flex:0 0 40%;max-width:40%}.invoice-detail-content.with-chat .ai-chat-panel{flex:0 0 25%;max-width:25%;border-left:1px solid var(--border)}.invoice-preview-panel{flex:0 0 40%;max-width:40%;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface-2);animation:slideInRight .25s ease}@keyframes slideInRight{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.invoice-preview-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--surface-1);border-bottom:1px solid var(--border);gap:8px}.invoice-preview-title{font-size:13px;font-weight:500;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.invoice-preview-actions{display:flex;gap:8px;flex-shrink:0}.preview-action-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.preview-action-btn.push{background:#059669;color:#fff}.preview-action-btn.push:hover{background:#047857;box-shadow:0 2px 8px #0596694d;transform:translateY(-1px)}.preview-action-btn.save{background:var(--primary);color:#fff}.preview-action-btn.save:hover{background:var(--primary-hover);box-shadow:0 2px 8px #2563eb4d;transform:translateY(-1px)}.preview-action-btn.nav{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.preview-action-btn.nav:hover:not(:disabled){background:var(--surface-3);color:var(--text-primary)}.preview-action-btn.nav:disabled{opacity:.3;cursor:not-allowed}.notification-container-detail{position:relative;z-index:99999}.notification-detail-btn{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);position:relative}.notification-detail-btn:hover{background:var(--surface-3);color:var(--text-primary)}.notification-badge-detail{position:absolute;top:-6px;right:-6px;min-width:16px;height:16px;padding:0 4px;background:#ef4444;color:#fff;border-radius:8px;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface-1);line-height:1}.notification-popup-detail{position:absolute;top:calc(100% + 8px);right:0;width:420px;max-height:450px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 10px 40px #0003;z-index:99999;overflow:hidden;display:flex;flex-direction:column}.invoice-detail-footer-bar{padding:16px 28px;background:var(--surface-1);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;z-index:10;flex-shrink:0;box-shadow:0 -4px 12px #0000001a}.footer-nav-right{display:flex;align-items:center;gap:10px}.invoice-detail-footer-bar .preview-action-btn{padding:10px 18px;font-size:13px}.chat-badge-btn{position:relative;background:linear-gradient(135deg,#5d5fef,#7879f1);color:#fff}.chat-badge-btn:hover{background:linear-gradient(135deg,#4345c8,#5d5fef);box-shadow:0 4px 12px #5d5fef66;transform:translateY(-1px)}.chat-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--error);color:#fff;font-size:10px;font-weight:700;line-height:18px;text-align:center;font-family:var(--font-mono);box-shadow:0 2px 6px #ff6b6b66;animation:badgePop .3s ease}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.invoice-preview-content{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:8px}.invoice-preview-iframe{width:100%;height:100%;border:none;border-radius:4px;background:#fff}.invoice-preview-image{max-width:100%;height:auto;border-radius:4px;object-fit:contain}.ai-chat-messages{display:flex;flex-direction:column;gap:16px;padding:8px 0}.ai-chat-bubble{display:flex;gap:12px;align-items:flex-start;animation:fadeInUp .3s ease both}.ai-chat-bubble:nth-child(2){animation-delay:.15s}.ai-chat-bubble:nth-child(3){animation-delay:.3s}.ai-chat-bubble:nth-child(4){animation-delay:.45s}.ai-chat-bubble:nth-child(5){animation-delay:.6s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ai-chat-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.ai-chat-avatar.success{background:#059669}.ai-chat-avatar.error{background:#dc2626}.ai-chat-content{flex:1;min-width:0}.ai-chat-sender{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}.ai-chat-text{font-size:14px;line-height:1.6;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--border-light);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);padding:12px 16px}.ai-chat-card{display:flex;gap:12px;padding:16px;border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);border:1px solid}.ai-chat-card.success{background:#00c48c1a;border-color:#00c48c4d}.ai-chat-card.error{background:#ff6b6b1a;border-color:#ff6b6b4d}.ai-chat-card-icon{font-size:24px;display:flex;flex-shrink:0;margin-top:2px}.ai-chat-card.success .ai-chat-card-icon{color:#059669}.ai-chat-card.error .ai-chat-card-icon{color:#dc2626}.ai-chat-card-body{flex:1;min-width:0}.ai-chat-card-title{font-size:15px;font-weight:600;color:#059669;margin-bottom:4px}.ai-chat-card-desc{font-size:14px;line-height:1.5;color:var(--text-primary)}.ai-chat-action-btn{margin-top:10px;padding:8px 16px;font-size:13px;font-weight:600;color:#fff;background:var(--primary);border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:pointer}.ai-chat-action-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb40}.invoice-detail-footer{padding:16px 28px;border-top:1px solid var(--border);background:var(--surface-1);display:flex;align-items:center;gap:10px}.invoice-detail-input-wrapper{flex:1;display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.invoice-detail-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.invoice-detail-input-wrapper input{flex:1;font-size:14px;color:var(--text-primary);background:transparent}.invoice-detail-input-wrapper input::placeholder{color:var(--text-muted)}.invoice-detail-send{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--purple-base);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--transition-fast);flex-shrink:0}.invoice-detail-send:hover{background:var(--primary-hover);transform:scale(1.05)}.invoice-detail-send:disabled{opacity:.5;pointer-events:none}.upload-progress-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:400;display:flex;flex-direction:column;gap:8px;min-width:320px;max-width:480px;width:max-content;pointer-events:none}.upload-progress-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:12px 16px;animation:scaleIn var(--transition-fast)}.upload-progress-item.done{border-color:var(--success)}.upload-progress-item.error{border-color:var(--error)}.upload-progress-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.upload-progress-icon{font-size:18px;display:flex;flex-shrink:0;color:var(--primary)}.upload-progress-item.done .upload-progress-icon{color:var(--success)}.upload-progress-item.error .upload-progress-icon{color:var(--error)}.upload-progress-name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}.upload-progress-label{font-size:12px;color:var(--text-muted);flex-shrink:0}.upload-progress-track{height:4px;background:var(--border);border-radius:99px;overflow:hidden}.upload-progress-fill{height:100%;border-radius:99px;background:var(--primary);transition:width .6s cubic-bezier(.4,0,.2,1),background .3s ease}.upload-progress-fill.done{background:var(--success)}.upload-progress-fill.error{background:var(--error)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:14px;color:var(--text-primary);animation:scaleIn var(--transition-fast)}.toast-icon{font-size:20px;display:flex}.toast-icon.success{color:var(--success)}.toast-icon.error{color:var(--error)}.toast-icon.info{color:#3b82f6}@media(max-width:768px){.app-main{margin-left:0!important}.file-nav-panel{display:none}.invoice-detail-header,.invoice-detail-scroll-body{padding:16px 20px}.invoice-detail-footer{padding:12px 20px}.invoice-detail-content.with-preview{flex-direction:column}.invoice-detail-content.with-preview .invoice-detail-pane{flex:none;max-width:100%}.invoice-preview-panel{flex:none;max-width:100%;height:50vh;border-left:none;border-top:1px solid var(--border)}.toast-container{bottom:16px;right:16px;left:16px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.delete-confirm-modal{width:400px;max-width:90vw;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #00000080;padding:24px;animation:scaleIn .2s ease}.delete-confirm-modal h3{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.delete-confirm-modal p{font-size:14px;color:var(--text-secondary);margin:0 0 24px;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-secondary{padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);background:var(--surface-3);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-4, #444)}.btn-danger{padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);background:var(--error);color:#fff;border:none}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}:root{--purple-base: #5D5FEF;--purple-light: #7879F1;--purple-deep: #4345C8;--success: #00C48C;--warning: #FFB547;--error: #FF6B6B;--ai-blue: #38BDF8;--bg-color: #0D0D14;--surface-1: #13131F;--surface-2: #1A1A2E;--surface-3: #22223A;--font-display: "Sora", sans-serif;--font-body: "Plus Jakarta Sans", sans-serif;--font-mono: "DM Mono", monospace;--primary: var(--purple-base);--primary-hover: var(--purple-light);--text-primary: #FFFFFF;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .5);--border: rgba(255, 255, 255, .1);--border-light: rgba(255, 255, 255, .05);--shadow-card: 0 10px 30px rgba(0, 0, 0, .5);--purple-glow: 0 0 20px rgba(93, 95, 239, .3);--glass-bg: rgba(255, 255, 255, .05);--header-height: 72px;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--transition-fast: .15s ease;--transition-normal: .25s ease}[data-theme=light]{--bg-color: #F5F5FA;--surface-1: #FFFFFF;--surface-2: #F0F0F8;--surface-3: #E4E4F0;--text-primary: #13131F;--text-secondary: #4A4A68;--text-muted: #8E8E9F;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .04);--shadow-card: 0 10px 30px rgba(0, 0, 0, .08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-weight:400;color:var(--text-primary);background:var(--bg-color);line-height:1.5;overflow:hidden}#root{display:flex;height:100vh;width:100vw;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.2;letter-spacing:-.02em}h2{font-family:var(--font-display);font-size:20px;font-weight:600;line-height:1.4}h3{font-family:var(--font-display);font-size:16px;font-weight:600;line-height:1.4}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none;background:none;transition:all var(--transition-fast)}input,textarea{font-family:var(--font-body);outline:none;border:none}a{text-decoration:none;color:inherit}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounceIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}
