@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--teal:#00a8b0;--teal-light:#e0f7f8;--teal-dark:#008c94;--blue:#2d7dd2;--blue-light:#e8f2fc;--gradient:linear-gradient(135deg, #00a8b0, #2d7dd2);--gradient-subtle:linear-gradient(135deg, #00a8b00f, #2d7dd20a);--bg-base:#f4f6f9;--bg-surface:#fff;--bg-card:#fff;--bg-elevated:#f8f9fb;--bg-hover:#f0f2f5;--bg-sidebar:#fafbfc;--bg-secondary:#f1f3f5;--border:#e2e6ec;--border-light:#eef0f4;--border-focus:#00a8b0;--text-primary:#1a1d21;--text-secondary:#5f6b7a;--text-muted:#8d96a0;--text-inverse:#fff;--success:#10a37f;--success-bg:#e6f5f0;--warning:#d97706;--warning-bg:#fef3c7;--error:#dc2626;--error-bg:#fef2f2;--info:#2563eb;--info-bg:#eff6ff;--purple:#7c3aed;--sidebar-w:260px;--sidebar-w-collapsed:68px;--topbar-h:64px;--radius:10px;--radius-sm:6px;--radius-lg:14px;--shadow-xs:0 1px 2px #0000000a;--shadow:0 1px 6px #0000000f, 0 1px 3px #0000000a;--shadow-md:0 4px 16px #0000000f, 0 1px 4px #0000000a;--shadow-lg:0 8px 30px #00000014;--shadow-glow:0 0 0 3px #00a8b01f;--transition:all .2s ease;--font-sans:"Inter", -apple-system, system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cdd3dc;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8b0bc}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;min-height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:1px 0 8px #00000008}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99;opacity:0;background:#0006;transition:opacity .3s;display:none;position:fixed;inset:0}.sidebar-overlay.active{opacity:1;display:block}.sidebar-brand{border-bottom:1px solid var(--border);padding:24px 20px 16px}.brand-logo{align-items:center;gap:12px;display:flex}.brand-name{letter-spacing:2px;color:var(--text-primary);font-size:16px;font-weight:700}.brand-sub{letter-spacing:1.5px;color:var(--teal);margin-top:1px;font-size:10px;font-weight:600}.brand-powered{letter-spacing:1px;color:var(--text-muted);background:var(--teal-light);border-radius:var(--radius-sm);text-align:center;border:1px solid #00a8b026;margin-top:12px;padding:6px 10px;font-size:8.5px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.nav-item{border-radius:var(--radius);color:var(--text-secondary);transition:var(--transition);cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--teal-light);color:var(--teal-dark);border-left:3px solid var(--teal);font-weight:600}.nav-item svg{flex-shrink:0}.nav-divider{background:var(--border);height:1px;margin:8px 14px}.erp-status{color:var(--text-secondary);align-items:center;gap:8px;font-size:12px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot.online{background:var(--success);animation:2s infinite pulse;box-shadow:0 0 6px #10a37f66}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.sidebar-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.sidebar-collapse-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-surface);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-collapse-btn:hover{background:var(--bg-hover);color:var(--teal);border-color:var(--teal)}.sidebar{transition:width .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar.collapsed .brand-text,.sidebar.collapsed .brand-powered{display:none}.sidebar.collapsed .sidebar-brand{padding:16px 12px}.sidebar.collapsed .brand-logo{justify-content:center}.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-folder-label,.sidebar.collapsed .folder-badge-soon,.sidebar.collapsed .nav-folder-children{display:none}.sidebar.collapsed .nav-item,.sidebar.collapsed .nav-folder-header{justify-content:center;padding:10px}.sidebar.collapsed .nav-folder-header svg:last-child{display:none}.sidebar.collapsed .sidebar-footer{justify-content:center;padding:12px 8px}.sidebar.collapsed .erp-status span{display:none}.sidebar.collapsed .erp-status{justify-content:center}.sidebar.temp-expanded{z-index:100;border-right:2px solid var(--teal);box-shadow:4px 0 24px #00000026}.sidebar.temp-expanded~.main-content,.sidebar.temp-expanded+div+.main-content{margin-left:var(--sidebar-w-collapsed)}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex}.sidebar.collapsed~.main-content,.sidebar.collapsed+div+.main-content{margin-left:var(--sidebar-w-collapsed)}.topbar{height:var(--topbar-h);background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;box-shadow:var(--shadow-xs);justify-content:space-between;align-items:center;gap:16px;padding:0 28px;display:flex;position:sticky;top:0}.hamburger-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:var(--transition);background:0 0;flex-shrink:0;padding:8px;display:none}.hamburger-btn:hover{border-color:var(--teal);color:var(--teal)}.topbar-search{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);max-width:380px;transition:var(--transition);flex:1;align-items:center;gap:10px;padding:8px 14px;display:flex}.topbar-search:focus-within{border-color:var(--teal);box-shadow:var(--shadow-glow);background:var(--bg-surface)}.topbar-search input{color:var(--text-primary);width:100%;font-size:14px;font-family:var(--font-sans);background:0 0;border:none;outline:none}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.topbar-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;padding:8px;display:flex;position:relative}.topbar-btn:hover{border-color:var(--teal);color:var(--teal)}.notif-badge{background:var(--error);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.topbar-user{border-radius:var(--radius);cursor:pointer;transition:var(--transition);align-items:center;gap:10px;margin-left:8px;padding:6px 12px;display:flex}.user-avatar{background:var(--gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 6px #00a8b040}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-primary);white-space:nowrap;font-size:13px;font-weight:600}.user-role{color:var(--text-muted);font-size:11px}.nav-folder{margin:2px 0}.nav-folder-header{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:var(--transition);width:100%;font-size:13px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;align-items:center;gap:10px;padding:9px 14px;display:flex}.nav-folder-header:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-folder-header.disabled{opacity:.5;cursor:not-allowed}.nav-folder-header.disabled:hover{color:var(--text-secondary);background:0 0}.nav-folder-label{text-align:left;flex:1}.folder-badge-soon{letter-spacing:.5px;background:var(--warning-bg);color:var(--warning);text-transform:uppercase;border-radius:3px;padding:2px 6px;font-size:9px;font-weight:700}.nav-folder-children{flex-direction:column;gap:1px;margin-top:2px;padding-left:12px;animation:.2s folderOpen;display:flex}@keyframes folderOpen{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-child{border-left:2px solid var(--border-light);margin-left:4px;border-radius:0 var(--radius) var(--radius) 0!important;padding:8px 14px!important;font-size:13px!important}.nav-child.active{border-left-color:var(--teal)!important}.analytics-blur-wrapper{border-radius:var(--radius-lg);min-height:600px;position:relative;overflow:hidden}.analytics-overlay{z-index:10;-webkit-backdrop-filter:blur(2px);background:#ffffff40;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}[data-theme=dark] .analytics-overlay{background:#0d111759}.analytics-overlay-content{text-align:center;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border:1px solid #ffffff73;max-width:480px;padding:48px 40px;box-shadow:0 8px 32px #0000001f,0 0 0 1px #00a8b014}[data-theme=dark] .analytics-overlay-content{background:#161b22e0;border-color:#ffffff14}.analytics-overlay-icon{background:var(--gradient-subtle);width:88px;height:88px;color:var(--teal);border:1px solid #00a8b026;border-radius:22px;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.analytics-overlay-title{color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:700}.analytics-overlay-text{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.6}.analytics-overlay-badges{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.a-badge{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:6px 14px;font-size:12px;font-weight:500}.analytics-dashboard-preview{filter:blur(5px);pointer-events:none;-webkit-user-select:none;user-select:none;flex-direction:column;gap:20px;padding:20px;display:flex}.adp-kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.adp-kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:4px;padding:20px;display:flex}.adp-kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.adp-kpi-value{color:var(--text-primary);font-size:28px;font-weight:700;font-family:var(--font-mono)}.adp-kpi-change{font-size:12px;font-weight:600}.adp-kpi-change.positive{color:var(--success)}.adp-kpi-change.neutral{color:var(--text-muted)}.adp-charts-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.adp-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.adp-chart-title{color:var(--text-primary);margin-bottom:16px;font-size:14px;font-weight:600}.adp-bar-chart{align-items:flex-end;gap:8px;height:160px;padding-top:8px;display:flex}.adp-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.adp-bar{background:linear-gradient(180deg, var(--teal), #00a8b059);border-radius:4px 4px 0 0;width:100%;transition:height .3s}.adp-bar-label{color:var(--text-muted);margin-top:6px;font-size:10px}.adp-donut-wrapper{align-items:center;gap:24px;display:flex}.adp-donut{flex-shrink:0;width:140px;height:140px;position:relative}.adp-donut-svg{width:100%;height:100%;transform:rotate(-90deg)}.adp-donut-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.adp-donut-number{color:var(--text-primary);font-size:22px;font-weight:700}.adp-donut-text{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:10px}.adp-donut-legend{flex-direction:column;gap:8px;display:flex}.adp-legend-item{color:var(--text-secondary);align-items:center;gap:8px;font-size:12px;display:flex}.adp-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.adp-table{border-collapse:collapse;width:100%;font-size:13px}.adp-table th{text-align:left;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);letter-spacing:.5px;padding:8px 12px;font-size:11px}.adp-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:10px 12px}.adp-overdue{font-weight:600;color:var(--error)!important}.adp-vendor-bars{flex-direction:column;gap:14px;display:flex}.adp-vendor-row{flex-direction:column;gap:4px;display:flex}.adp-vendor-info{justify-content:space-between;font-size:12px;display:flex}.adp-vendor-name{color:var(--text-primary);font-weight:500}.adp-vendor-amt{color:var(--teal);font-weight:600;font-family:var(--font-mono)}.adp-vendor-track{background:var(--bg-elevated);border-radius:4px;height:8px;overflow:hidden}.adp-vendor-fill{background:linear-gradient(90deg, var(--teal), #00a8b080);border-radius:4px;height:100%}.adp-hbar-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.adp-hbar-label{width:110px;color:var(--text-secondary);flex-shrink:0;font-size:12px}.adp-hbar-track{background:var(--bg-elevated);border-radius:5px;flex:1;height:10px;overflow:hidden}.adp-hbar-fill{background:linear-gradient(90deg, var(--teal), #00a8b066);border-radius:5px;height:100%}.adp-hbar-val{color:var(--text-primary);text-align:right;width:30px;font-size:12px;font-weight:600;font-family:var(--font-mono)}.coming-soon-container{justify-content:center;align-items:center;min-height:50vh;padding:24px;display:flex}.coming-soon-card{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:480px;box-shadow:var(--shadow);padding:48px 40px}.coming-soon-icon{background:var(--gradient-subtle);width:80px;height:80px;color:var(--teal);border:1px solid #00a8b026;border-radius:20px;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.coming-soon-title{color:var(--text-primary);margin-bottom:8px;font-size:24px;font-weight:700}.coming-soon-text{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.6}.coming-soon-features{text-align:left;flex-direction:column;gap:10px;display:flex}.cs-feature{color:var(--text-secondary);background:var(--bg-elevated);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px 14px;font-size:13px;display:flex}.cs-dot{background:var(--teal);border-radius:50%;flex-shrink:0;width:6px;height:6px}.page-container{flex:1;padding:28px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-title{color:var(--text-primary);font-size:28px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:14px}.page-header-actions{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.erp-badge{border-radius:var(--radius);background:var(--success-bg);color:var(--success);white-space:nowrap;border:1px solid #10a37f33;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:600;display:flex}.erp-sync{color:var(--text-muted);margin-left:6px;font-weight:400}.btn{border-radius:var(--radius);cursor:pointer;transition:var(--transition);font-size:13px;font-weight:600;font-family:var(--font-sans);white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;display:inline-flex}.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 2px 10px #00a8b040}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 18px #00a8b066}.btn-ghost{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.btn-ghost.accent{color:var(--teal);border-color:#00a8b04d}.btn-danger{background:var(--error-bg);color:var(--error);border:1px solid #dc262633}.btn-danger:hover{background:#dc26261f}.btn-success{background:var(--success-bg);color:var(--success);border:1px solid #10a37f33}.btn-success:hover{background:#10a37f1f}.btn-icon{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;padding:6px;display:inline-flex}.btn-icon:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.badge-count{color:var(--teal-dark);background:var(--teal-light);border-radius:var(--radius-sm);padding:4px 10px;font-size:12px;font-weight:600}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);box-shadow:var(--shadow-xs);align-items:center;gap:16px;padding:20px;display:flex}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:#00a8b04d;transform:translateY(-2px)}.kpi-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-icon.processed{background:var(--success-bg);color:var(--success)}.kpi-icon.pending{background:var(--warning-bg);color:var(--warning)}.kpi-icon.errors{background:var(--error-bg);color:var(--error)}.kpi-data{flex-direction:column;display:flex}.kpi-value{color:var(--text-primary);font-size:32px;font-weight:700;line-height:1}.kpi-label{color:var(--text-secondary);margin-top:4px;font-size:13px}.kpi-trend{white-space:nowrap;border-radius:4px;margin-left:auto;padding:3px 8px;font-size:11px;font-weight:600}.kpi-trend.up{background:var(--success-bg);color:var(--success)}.kpi-trend.warn{background:var(--warning-bg);color:var(--warning)}.kpi-trend.good{background:var(--success-bg);color:var(--success)}.kpi-card.accent{background:var(--gradient-subtle);border-color:#00a8b033}.kpi-accent-content{flex-direction:column;width:100%;display:flex}.kpi-accent-label{letter-spacing:1.5px;color:var(--teal);font-size:10px;font-weight:700}.kpi-accent-value{color:var(--text-primary);margin:4px 0;font-size:36px;font-weight:700}.kpi-accent-sub{color:var(--text-secondary);font-size:12px}.kpi-accent-bar{background:var(--border);border-radius:2px;height:4px;margin-top:10px}.kpi-accent-fill{background:var(--gradient);border-radius:2px;height:100%;transition:width .8s}.charts-row{grid-template-columns:2fr 1fr;gap:16px;margin-bottom:24px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:20px}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:20px;display:flex}.chart-header h3{color:var(--text-primary);font-size:16px;font-weight:600}.chart-legend{color:var(--text-secondary);align-items:center;gap:12px;font-size:12px;display:flex}.legend-dot{border-radius:3px;width:10px;height:10px;margin-right:4px;display:inline-block}.legend-dot.completed{background:var(--teal)}.legend-dot.pending-l{background:var(--warning)}.chart-bars{align-items:flex-end;gap:12px;height:160px;padding-top:10px;display:flex}.bar-group{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.bar-group span{color:var(--text-muted);font-size:11px}.bar-group.highlight span{color:var(--teal);font-weight:600}.bar-stack{flex-direction:column;justify-content:flex-end;align-items:stretch;gap:2px;width:100%;height:140px;display:flex}.bar{transition:var(--transition);border-radius:4px 4px 0 0;min-height:4px}.bar.completed{background:var(--teal)}.bar.pending-b{background:var(--warning);opacity:.7}.bar-group:hover .bar.completed{background:var(--teal-dark)}.vendor-spotlight{text-align:center;padding:12px 0}.vendor-avatar-lg{background:var(--bg-elevated);border:2px solid var(--border);width:56px;height:56px;color:var(--teal);border-radius:14px;justify-content:center;align-items:center;margin:0 auto 12px;font-size:18px;font-weight:700;display:flex}.vendor-spotlight h4{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.vendor-tier{letter-spacing:1.2px;color:var(--teal-dark);background:var(--teal-light);border-radius:4px;padding:3px 10px;font-size:10px;font-weight:700}.vendor-stats-row{justify-content:center;gap:28px;margin-top:16px;display:flex}.vendor-stats-row div{flex-direction:column;display:flex}.stat-label{color:var(--text-muted);font-size:11px}.stat-value{color:var(--text-primary);margin-top:2px;font-size:16px;font-weight:700}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.table-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 22px;display:flex}.table-header h3{color:var(--text-primary);font-size:16px;font-weight:600}.table-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.status-filter-tabs{border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;gap:4px;padding:10px 22px 0;display:flex;overflow-x:auto}.status-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;transition:all .2s;display:flex}.status-tab:hover{color:var(--text-primary);background:var(--bg-hover);border-radius:6px 6px 0 0}.status-tab.active{color:var(--teal);border-bottom-color:var(--teal);font-weight:600}.status-tab.active.pending{color:var(--warning);border-bottom-color:var(--warning)}.status-tab.active.approved{color:var(--success);border-bottom-color:var(--success)}.status-tab.active.processing{color:var(--teal);border-bottom-color:var(--teal)}.status-tab.active.posted{color:var(--info);border-bottom-color:var(--info)}.status-tab.active.rejected{color:var(--error);border-bottom-color:var(--error)}.status-tab-count{background:var(--bg-elevated);min-width:20px;height:20px;color:var(--text-muted);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;transition:all .2s;display:flex}.status-tab.active .status-tab-count{background:var(--teal-light);color:var(--teal-dark)}.status-tab.active.pending .status-tab-count{background:var(--warning-bg);color:var(--warning)}.status-tab.active.approved .status-tab-count{background:var(--success-bg);color:var(--success)}.status-tab.active.posted .status-tab-count{background:var(--blue-light);color:var(--info)}.status-tab.active.rejected .status-tab-count{background:var(--error-bg);color:var(--error)}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:800px}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);background:var(--bg-elevated);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border-light);vertical-align:middle;color:var(--text-primary);padding:14px 16px;font-size:13px}.data-table tr:hover td{background:var(--bg-hover)}.data-table tr:last-child td{border-bottom:none}.vendor-cell{align-items:center;gap:10px;display:flex}.vendor-avatar{color:#fff;background:var(--gradient);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex;box-shadow:0 2px 4px #0000001a}.vendor-avatar.sm{width:34px;height:34px}.vendor-cell .sub{color:var(--text-muted);margin-top:1px;font-size:11px;display:block}.mono{font-family:var(--font-mono);font-size:12px}.amount{font-weight:600;font-family:var(--font-mono);color:var(--text-primary)}.code-badge{font-size:11px;font-family:var(--font-mono);background:var(--blue-light);color:var(--info);white-space:nowrap;border-radius:4px;padding:3px 8px}.vendor-code-badge{font-size:11px;font-family:var(--font-mono);background:var(--teal-light);color:var(--teal-dark);white-space:nowrap;border-radius:4px;padding:3px 8px;font-weight:600}.vendor-code-pending{color:var(--text-muted);font-size:11px;font-style:italic}.confidence{border-radius:4px;padding:3px 8px;font-size:12px;font-weight:600}.confidence.high{background:var(--success-bg);color:var(--success)}.confidence.med{background:var(--warning-bg);color:var(--warning)}.confidence.low{background:var(--error-bg);color:var(--error)}.status-badge{white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.status-badge.pending{background:var(--warning-bg);color:var(--warning)}.status-badge.urgent{background:var(--error-bg);color:var(--error)}.status-badge.draft{background:var(--bg-secondary);color:var(--text-secondary)}.status-badge.approved{background:var(--success-bg);color:var(--success)}.status-badge.processing{background:var(--teal-light);color:var(--teal-dark)}.status-badge.posted{background:var(--blue-light);color:var(--info)}.action-cell{align-items:center;gap:6px;display:flex}.table-footer{color:var(--text-secondary);border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:14px 22px;font-size:13px;display:flex}.pagination{gap:6px;display:flex}.filter-bar{-webkit-overflow-scrolling:touch;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-chip{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:var(--transition);white-space:nowrap;border-radius:20px;padding:7px 14px;font-size:12px;font-weight:500}.filter-chip:hover,.filter-chip.active{background:var(--teal-light);color:var(--teal-dark);border-color:#00a8b04d}.review-layout{grid-template-columns:3fr 2fr;align-items:start;gap:20px;transition:grid-template-columns .35s cubic-bezier(.4,0,.2,1);display:grid}.review-layout:has(.review-right.collapsed){grid-template-columns:1fr 36px;gap:0}.review-left{flex-direction:column;gap:16px;min-width:0;display:flex}.review-right{top:calc(var(--topbar-h) + 16px);flex-direction:row;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;overflow:hidden}.review-right.open{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-xs)}.review-right.collapsed{width:36px;min-width:36px;max-width:36px}.pdf-toggle-strip{background:var(--bg-card);border:none;border-right:1px solid var(--border);cursor:pointer;width:36px;min-width:36px;transition:var(--transition);font-family:var(--font-sans);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:500px;padding:16px 0;display:flex}.review-right.collapsed .pdf-toggle-strip{border:1px solid var(--border);border-radius:var(--radius)}.pdf-toggle-strip:hover{background:var(--bg-hover)}.pdf-toggle-label{writing-mode:vertical-rl;text-orientation:mixed;color:var(--text-primary);white-space:nowrap;letter-spacing:.5px;font-size:12px;font-weight:600}.pdf-toggle-inv{writing-mode:vertical-rl;text-orientation:mixed;color:var(--text-muted);white-space:nowrap;font-size:10px}.pdf-content-panel{flex:1;padding:16px;transition:opacity .25s,width .35s cubic-bezier(.4,0,.2,1);overflow:hidden}.review-right.collapsed .pdf-content-panel{opacity:0;pointer-events:none;width:0;padding:0;overflow:hidden}.preview-layout{grid-template-columns:1fr 1fr;gap:20px;display:grid}.pdf-viewer-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg);min-height:600px;box-shadow:var(--shadow-xs);padding:16px}.pdf-viewer{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:600px;box-shadow:var(--shadow-xs);padding:24px}.pdf-placeholder{border:2px dashed var(--border);border-radius:var(--radius);width:100%;min-height:500px;color:var(--text-muted);background:linear-gradient(#f8f9fb 0%,#f1f3f5 100%);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.pdf-placeholder svg{opacity:.3;color:var(--text-muted)}.meta-panel{flex-direction:column;gap:16px;display:flex}.meta-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:18px}.meta-card h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px;font-size:13px;font-weight:600}.meta-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:8px;padding:8px 0;display:flex}.meta-row:last-child{border-bottom:none}.meta-key{color:var(--text-muted);white-space:nowrap;font-size:13px}.meta-val{color:var(--text-primary);text-align:right;font-size:13px;font-weight:600}.meta-val.mono{font-family:var(--font-mono)}.meta-edit-form{flex-direction:column;gap:8px;display:flex}.edit-row{align-items:center;gap:10px;display:flex}.edit-row label{color:var(--text-muted);white-space:nowrap;min-width:100px;font-size:12px}.edit-row input{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);background:var(--bg-elevated);color:var(--text-primary);transition:var(--transition);flex:1;padding:7px 10px}.edit-row input:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 2px #00a8b026}.line-items-table{width:100%;font-size:13px}.li-header{border-bottom:2px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;gap:8px;padding:8px 0;font-size:11px;font-weight:600;display:flex}.li-row{border-bottom:1px solid var(--border-light);align-items:center;gap:8px;padding:8px 0;display:flex}.li-row:last-child{border-bottom:none}.li-total{border-top:2px solid var(--border);border-bottom:none}.li-cell{align-items:center;display:flex}.li-desc{text-overflow:ellipsis;flex:3;min-width:0;overflow:hidden}.li-qty{flex:.6;justify-content:center}.li-price,.li-amount{flex:1;justify-content:flex-end}.li-action{flex:.4;justify-content:center}.li-input{width:100%;border:1px solid var(--border)!important;background:var(--bg-elevated)!important;color:var(--text-primary)!important;font-size:12px!important;font-family:var(--font-sans)!important;border-radius:4px!important;padding:5px 8px!important}.li-input:focus{outline:none;border-color:var(--teal)!important}.match-indicator{border-radius:var(--radius);align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.match-indicator.matched{background:var(--success-bg);color:var(--success);border:1px solid #10a37f33}.match-indicator.warning{background:var(--warning-bg);color:var(--warning);border:1px solid #d9770633}.action-bar{gap:10px;margin-top:8px;display:flex}.action-bar .btn{flex:1;justify-content:center;padding:12px;font-size:14px}.upload-grid{grid-template-columns:2fr 1fr;gap:20px;display:grid}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;background:var(--bg-card);transition:var(--transition);cursor:pointer;padding:60px 40px}.upload-zone:hover{border-color:var(--teal);background:var(--teal-light)}.upload-zone.drag-over{border-color:var(--teal);background:var(--teal-light);transform:scale(1.01)}.upload-zone svg{opacity:.3;color:var(--text-muted);margin-bottom:16px}.upload-zone h3{color:var(--text-primary);margin-bottom:8px;font-size:18px}.upload-zone p{color:var(--text-muted);font-size:13px}.settings-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.settings-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:22px}.settings-card.full-width{grid-column:1/-1}.settings-card h4{color:var(--text-primary);margin-bottom:12px;font-size:14px;font-weight:600}.settings-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-label{color:var(--text-secondary);font-size:13px}.setup-input{border:1px solid var(--border);background:var(--bg-secondary);font-size:12px;font-family:var(--font-mono);color:var(--text-primary);transition:var(--transition);border-radius:6px;outline:none;max-width:100%;padding:6px 10px}.setup-input:focus{border-color:var(--teal);box-shadow:var(--shadow-glow)}.toggle-switch{background:var(--border);cursor:pointer;width:36px;height:20px;transition:var(--transition);border-radius:10px;flex-shrink:0;position:relative}.toggle-switch.on{background:var(--teal)}.toggle-switch:after{content:"";width:16px;height:16px;transition:var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0000001a}.toggle-switch.on:after{left:18px}.analytics-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.analytics-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:20px}.analytics-card.full{grid-column:1/-1}.analytics-card h3{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:16px;font-size:15px;font-weight:600;display:flex}.premium-gate{position:relative}.premium-gate .premium-content{filter:blur(5px);pointer-events:none;-webkit-user-select:none;user-select:none}.premium-overlay{z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:var(--radius-lg);background:#ffffff80;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.premium-badge{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 48px;display:flex}.premium-icon{background:var(--gradient-subtle);width:56px;height:56px;color:var(--teal);border:1px solid #00a8b033;border-radius:14px;justify-content:center;align-items:center;display:flex}.premium-title{color:var(--text-primary);font-size:18px;font-weight:700}.premium-sub{color:var(--text-secondary);max-width:300px;font-size:13px;line-height:1.5}.btn-premium{border-radius:var(--radius);background:var(--gradient);color:#fff;cursor:pointer;transition:var(--transition);border:none;margin-top:4px;padding:10px 24px;font-size:13px;font-weight:600;box-shadow:0 2px 10px #00a8b040}.btn-premium:hover{transform:translateY(-1px);box-shadow:0 4px 18px #00a8b066}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:48px 24px;display:flex}.empty-icon{color:var(--text-muted);opacity:.4;margin-bottom:16px}.empty-title{color:var(--text-secondary);margin-bottom:6px;font-size:16px;font-weight:600}.empty-subtitle{color:var(--text-muted);max-width:280px;font-size:13px}.main-footer{border-top:1px solid var(--border);color:var(--text-muted);background:var(--bg-surface);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;gap:12px;margin-top:auto;padding:16px 28px;font-size:12px;display:flex}.main-footer strong{color:var(--teal)}.auth-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#f4f6f9f2;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.auth-card{background:var(--bg-surface);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-lg);text-align:center;border-radius:20px;padding:48px 40px;animation:.3s cubic-bezier(.4,0,.2,1) scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.auth-logo{background:var(--gradient);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 24px;display:flex;box-shadow:0 4px 20px #00a8b04d}.auth-title{color:var(--text-primary);margin-bottom:8px;font-size:24px;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:14px;line-height:1.5}.auth-ms-btn{color:#fff;border-radius:var(--radius);cursor:pointer;width:100%;transition:var(--transition);font-size:15px;font-weight:600;font-family:var(--font-sans);background:#2f2f2f;border:none;justify-content:center;align-items:center;gap:12px;padding:14px 24px;display:flex}.auth-ms-btn:hover{background:#1a1a1a;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.auth-ms-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{color:var(--text-muted);align-items:center;gap:12px;margin:24px 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-dev-btn{border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:var(--transition);font-size:12px;font-family:var(--font-sans);align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.auth-dev-btn:hover{border-color:var(--teal);color:var(--teal)}.auth-footer{color:var(--text-muted);margin-top:32px;font-size:11px}.auth-footer strong{color:var(--teal)}.auth-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast{z-index:9999;border-radius:var(--radius);align-items:center;gap:10px;max-width:calc(100vw - 48px);padding:14px 22px;font-size:14px;font-weight:500;animation:.3s slideUp;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 30px #0000001a}.toast.success{background:var(--success-bg);border:1px solid var(--success);color:var(--success)}.toast.error{background:var(--error-bg);border:1px solid var(--error);color:var(--error)}.toast.warning{background:var(--warning-bg);border:1px solid var(--warning);color:var(--warning)}.toast.info{background:var(--info-bg);border:1px solid var(--info);color:var(--info)}.toast.exiting{opacity:0;transition:all .3s;transform:translateY(10px)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}[data-theme=dark]{--bg-base:#111318;--bg-surface:#181b22;--bg-card:#1e222a;--bg-elevated:#252930;--bg-hover:#2a2f38;--bg-sidebar:#14161c;--bg-secondary:#222630;--border:#2e333d;--border-light:#252930;--border-focus:#00c2cb;--text-primary:#d8dee9;--text-secondary:#8892a4;--text-muted:#5c6678;--teal:#00c2cb;--teal-light:#00c2cb1f;--teal-dark:#00a8b0;--blue-light:#2d7dd21f;--gradient-subtle:linear-gradient(135deg, #00c2cb14, #2d7dd20d);--shadow-xs:0 1px 2px #00000040;--shadow:0 1px 6px #0000004d, 0 1px 3px #0003;--shadow-md:0 4px 16px #00000059;--shadow-lg:0 8px 30px #0006;--shadow-glow:0 0 0 3px #00c2cb26;--success:#3fb950;--error:#f85149;--warning:#d29922;--success-bg:#3fb9501f;--warning-bg:#d299221f;--error-bg:#f851491f}[data-theme=dark] .confidence{border:1px solid #0000}[data-theme=dark] .confidence.high{color:#5bda7b;background:linear-gradient(135deg,#3fb9502e,#3fb95014);border-color:#3fb95040}[data-theme=dark] .confidence.med{color:#e5b44c;background:linear-gradient(135deg,#d299222e,#d2992214);border-color:#d2992240}[data-theme=dark] .confidence.low{color:#ff7b73;background:linear-gradient(135deg,#f851492e,#f8514914);border-color:#f8514940}[data-theme=dark] .meta-card,[data-theme=dark] .kpi-card,[data-theme=dark] .chart-card,[data-theme=dark] .table-card{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .kpi-card.accent{background:linear-gradient(135deg,#00c2cb1f,#2d7dd214);border-color:#00c2cb33}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--bg-elevated);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] input:focus,[data-theme=dark] select:focus{border-color:var(--teal);box-shadow:var(--shadow-glow)}[data-theme=dark] .sidebar{background:var(--bg-sidebar);border-right-color:var(--border)}[data-theme=dark] .sidebar-section-label{color:var(--text-muted)}[data-theme=dark] .sidebar-link:hover,[data-theme=dark] .sidebar-link.active{background:#00c2cb14}[data-theme=dark] .topbar{border-bottom-color:var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#181b22d9}[data-theme=dark] .search-input{background:var(--bg-elevated);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .data-table th{background:var(--bg-elevated);border-bottom-color:var(--border);color:var(--text-secondary)}[data-theme=dark] .data-table td{border-bottom-color:var(--border-light)}[data-theme=dark] .data-table tr:hover td{background:var(--bg-hover)}[data-theme=dark] .status-badge{background:var(--bg-elevated)}[data-theme=dark] .vendor-code-badge{color:var(--teal);background:#00c2cb1f}[data-theme=dark] .code-badge{background:var(--bg-elevated);color:var(--text-secondary)}[data-theme=dark] .erp-badge{background:var(--bg-elevated);border-color:var(--border)}[data-theme=dark] .btn-ghost{color:var(--text-secondary);border-color:var(--border)}[data-theme=dark] .btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}[data-theme=dark] .premium-overlay{background:#11131899}[data-theme=dark] .auth-overlay{background:#111318f2}[data-theme=dark] .auth-ms-btn{color:#1a1a1a;background:#f0f0f0}[data-theme=dark] .auth-ms-btn:hover{background:#e0e0e0}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#2e333d}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#3d4350}[data-theme=dark] .notif-dropdown{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .bar.completed{background:var(--teal)}[data-theme=dark] .chart-bars span{color:var(--text-muted)}[data-theme=dark] .pdf-toggle-strip{background:var(--bg-elevated);border-color:var(--border)}[data-theme=dark] .pdf-content-panel{background:var(--bg-card)}[data-theme=dark] .li-header{background:var(--bg-elevated);border-color:var(--border)}[data-theme=dark] .li-row{border-color:var(--border-light)}[data-theme=dark] .li-input{background:var(--bg-elevated);border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .filter-chip{background:var(--bg-elevated);border-color:var(--border);color:var(--text-secondary)}[data-theme=dark] .filter-chip:hover,[data-theme=dark] .filter-chip.active{color:var(--teal);background:#00c2cb1f;border-color:#00c2cb4d}[data-theme=dark] .match-indicator{background:var(--bg-elevated)}.skeleton-block{background:linear-gradient(90deg, var(--bg-elevated) 25%, var(--bg-hover) 50%, var(--bg-elevated) 75%);background-size:200% 100%;border-radius:6px;animation:1.5s ease-in-out infinite shimmer;display:inline-block}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.preview-layout,.review-layout{grid-template-columns:1fr}.review-layout:has(.review-right.collapsed){grid-template-columns:1fr}.review-right{flex-direction:column;position:static}.review-right.collapsed{width:100%;min-width:100%;max-width:100%}.pdf-toggle-strip{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;width:100%;min-width:100%;min-height:auto;padding:10px 16px}.pdf-toggle-label,.pdf-toggle-inv{writing-mode:horizontal-tb}.analytics-grid,.upload-grid,.settings-grid,.charts-row{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{width:280px;transform:translate(-100%);box-shadow:4px 0 24px #00000026}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.hamburger-btn{display:flex}.topbar{padding:0 16px}.topbar-search{min-width:0;max-width:none}.user-info{display:none}.page-container{padding:20px 16px}.page-header{flex-direction:column;gap:12px}.page-header-actions{width:100%}.page-title{font-size:22px}.kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.kpi-value{font-size:24px}.kpi-icon{width:40px;height:40px}.charts-row{grid-template-columns:1fr}.agent-tab-strip{-webkit-overflow-scrolling:touch;padding:0 16px;overflow-x:auto}.agent-tab-strip::-webkit-scrollbar{display:none}.filter-bar{flex-wrap:nowrap;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.table-header{padding:14px 16px}.table-footer{text-align:center;flex-direction:column;padding:12px 16px}.erp-badge{display:none}.main-footer{text-align:center;flex-direction:column;padding:16px}.auth-card{margin:20px;padding:32px 24px}.premium-badge{margin:16px;padding:24px}.action-bar{flex-direction:column}.upload-zone{padding:40px 20px}}@media (max-width:480px){.kpi-grid{grid-template-columns:1fr}.kpi-card{padding:16px}.page-header-actions{flex-direction:column;align-items:stretch}.page-header-actions .btn{justify-content:center}.topbar-search input::placeholder{font-size:12px}.topbar-actions .topbar-btn:not(:first-child):not(:last-child){display:none}.vendor-stats-row{gap:16px}}.extraction-backdrop{justify-content:center;align-items:center;min-height:500px;padding:20px;display:flex}.extraction-card{-webkit-backdrop-filter:blur(24px);text-align:center;background:#ffffffd9;border:1px solid #00c2cb26;border-radius:24px;width:100%;max-width:560px;padding:48px 40px 36px;position:relative;overflow:hidden;box-shadow:0 8px 32px #00c2cb14,0 1px 3px #0000000a,inset 0 1px #fff9}[data-theme=dark] .extraction-card{background:#161b22e6;border-color:#00c2cb33;box-shadow:0 8px 32px #0000004d,0 1px 3px #00c2cb0d}.extraction-orb{filter:blur(60px);opacity:.3;pointer-events:none;border-radius:50%;animation:6s ease-in-out infinite orbFloat;position:absolute}.extraction-orb-1{background:linear-gradient(135deg,#00c2cb,#2d94dd);width:200px;height:200px;animation-delay:0s;top:-60px;right:-40px}.extraction-orb-2{background:linear-gradient(135deg,#2d94dd,#bc8cff);width:150px;height:150px;animation-delay:2s;bottom:-40px;left:-30px}.extraction-orb-3{opacity:.15;background:linear-gradient(135deg,#00c2cb,#3fb950);width:120px;height:120px;animation-delay:4s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes orbFloat{0%,to{transform:translate(0)scale(1)}33%{transform:translate(15px,-10px)scale(1.1)}66%{transform:translate(-10px,15px)scale(.95)}}.extraction-icon{z-index:1;color:#fff;background:linear-gradient(135deg,#00c2cb,#2d94dd);border-radius:20px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;animation:3s linear infinite iconSpin;display:flex;position:relative;box-shadow:0 4px 20px #00c2cb4d}@keyframes iconSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.extraction-title{z-index:1;letter-spacing:-.3px;background:linear-gradient(135deg,#00c2cb,#2d94dd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:22px;font-weight:800;position:relative}.extraction-filename{z-index:1;color:var(--text-muted);word-break:break-all;max-width:400px;margin-bottom:28px;margin-left:auto;margin-right:auto;font-family:SF Mono,Cascadia Code,monospace;font-size:12px;position:relative}.extraction-pipeline{z-index:1;flex-direction:column;gap:6px;margin-bottom:28px;display:flex;position:relative}.extraction-step{border-radius:12px;align-items:center;gap:12px;padding:10px 14px;transition:all .4s cubic-bezier(.16,1,.3,1);animation:.3s both stepSlideIn;display:flex}@keyframes stepSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.extraction-step.done{background:#3fb9500f;border:1px solid #3fb9501f}.extraction-step.active{background:#00c2cb0f;border:1px solid #00c2cb33;box-shadow:0 0 0 1px #00c2cb0d}.extraction-step.pending{opacity:.4;background:0 0;border:1px solid #0000}.extraction-step-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .3s;display:flex}.extraction-step.done .extraction-step-icon{color:#fff;background:linear-gradient(135deg,#3fb950,#2ea043)}.extraction-step.active .extraction-step-icon{color:#fff;background:linear-gradient(135deg,#00c2cb,#2d94dd)}.extraction-step.pending .extraction-step-icon{background:var(--bg-elevated);color:var(--text-muted)}.extraction-step-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.extraction-step-num{font-size:11px;font-weight:700}.extraction-step-content{text-align:left;flex-direction:column;flex:1;gap:1px;display:flex}.extraction-step-label{color:var(--text-primary);font-size:13px;font-weight:500;transition:color .3s}.extraction-step.pending .extraction-step-label{color:var(--text-muted)}.extraction-step.active .extraction-step-label{color:var(--teal);font-weight:600}.extraction-step-processing{color:var(--teal);letter-spacing:.3px;text-transform:uppercase;font-size:10px;font-weight:500;animation:1.5s ease-in-out infinite textPulse}@keyframes textPulse{0%,to{opacity:1}50%{opacity:.5}}.extraction-step-emoji{opacity:.8;flex-shrink:0;font-size:16px}.extraction-progress-wrap{z-index:1;margin-bottom:16px;position:relative}.extraction-progress-track{background:var(--bg-elevated);border-radius:10px;height:8px;position:relative;overflow:hidden}.extraction-progress-fill{background:linear-gradient(90deg,#00c2cb,#2d94dd,#bc8cff) 0 0/200% 100%;border-radius:10px;height:100%;transition:width .4s cubic-bezier(.16,1,.3,1);animation:3s infinite gradientShift;position:relative}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.extraction-progress-glow{filter:blur(4px);background:#ffffff80;border-radius:50%;width:20px;height:12px;position:absolute;top:-2px;right:0}.extraction-progress-meta{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.extraction-progress-label{color:var(--text-muted);font-size:11px;font-weight:500}.extraction-progress-pct{background:linear-gradient(135deg,#00c2cb,#2d94dd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:13px;font-weight:700}.extraction-powered{z-index:1;color:var(--text-muted);margin-top:4px;font-size:11px;position:relative}.extraction-powered strong{color:var(--text-secondary)}.auth-card-modern{-webkit-backdrop-filter:blur(24px);text-align:center;background:#ffffffeb;border:1px solid #00c2cb1a;border-radius:24px;width:90%;max-width:420px;padding:48px 40px 36px;animation:.5s cubic-bezier(.16,1,.3,1) authCardSlide;position:relative;overflow:hidden;box-shadow:0 16px 64px #00000014,0 4px 16px #00c2cb0f,inset 0 1px #fffc}@keyframes authCardSlide{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}[data-theme=dark] .auth-card-modern{background:#161b22f2;border-color:#00c2cb26;box-shadow:0 16px 64px #0006}.auth-accent-bar{background:linear-gradient(90deg,#00c2cb,#2d94dd,#bc8cff,#00c2cb) 0 0/300% 100%;width:100%;height:4px;animation:4s infinite accentShift;position:absolute;top:0;left:0}@keyframes accentShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.auth-logo-modern{background:linear-gradient(135deg,#00c2cb,#2d94dd);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex;box-shadow:0 4px 16px #00c2cb4d}.auth-title-modern{letter-spacing:-.3px;color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:800}.auth-subtitle-modern{color:var(--text-secondary);max-width:320px;margin-bottom:28px;margin-left:auto;margin-right:auto;font-size:13px;line-height:1.6}.auth-error{color:var(--error);text-align:left;background:#f8514914;border:1px solid #f8514926;border-radius:10px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:12px;display:flex}.auth-ms-btn-modern{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 24px;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 2px 8px #00000026}.auth-ms-btn-modern:hover{background:linear-gradient(135deg,#2d2d2d,#3d3d3d);transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.auth-ms-btn-modern:active{transform:translateY(0)}.auth-ms-btn-modern:disabled{opacity:.6;cursor:not-allowed;transform:none}[data-theme=dark] .auth-ms-btn-modern{color:#1a1a1a;background:linear-gradient(135deg,#f0f0f0,#e0e0e0)}[data-theme=dark] .auth-ms-btn-modern:hover{background:linear-gradient(135deg,#fff,#f0f0f0)}.auth-btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}[data-theme=dark] .auth-btn-spinner{border-color:#1a1a1a #0003 #0003}.auth-divider-modern{color:var(--text-muted);align-items:center;gap:12px;margin:20px 0;font-size:12px;display:flex}.auth-divider-modern:before,.auth-divider-modern:after{content:"";background:var(--border);flex:1;height:1px}.auth-dev-btn-modern{border:1px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:500;transition:all .3s;display:flex}.auth-dev-btn-modern:hover{border-color:var(--teal);color:var(--teal);background:#00c2cb0a}.auth-footer-modern{color:var(--text-muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;margin-top:28px;font-size:11px;display:flex}.auth-footer-modern strong{color:var(--teal)}.auth-footer-dot{color:var(--border)}.pdf-loading-state{flex-direction:column;justify-content:center;align-items:center;min-height:500px;padding:40px;display:flex}.pdf-loading-spinner{border:3px solid #00c2cb26;border-top:3px solid var(--teal);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.pdf-error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:40px;display:flex}.notif-dropdown{background:var(--bg-surface);border:1px solid var(--border);z-index:1000;border-radius:14px;width:380px;max-height:480px;animation:.2s notifSlideIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 12px 40px #00000026,0 4px 16px #00000014}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.notif-dropdown-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-mark-read{color:var(--teal);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:12px;font-weight:600;transition:background .15s}.notif-mark-read:hover{background:var(--teal-light)}.notif-dropdown-list{max-height:400px;padding:4px 0;overflow-y:auto}.notif-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:40px 20px;display:flex}.notif-empty p{margin:0;font-size:13px}.notif-item{cursor:pointer;align-items:flex-start;gap:10px;padding:12px 16px;transition:background .15s;display:flex;position:relative}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:#00a8b00a}.notif-icon{flex-shrink:0;margin-top:2px;font-size:16px;line-height:1}.notif-content{flex:1;min-width:0}.notif-title{color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.3}.notif-message{color:var(--text-secondary);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.notif-time{color:var(--text-muted);margin-top:4px;font-size:11px}.notif-dot{background:var(--teal);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.score-badges{align-items:center;gap:8px;display:flex}.score-badge{font-size:12px;font-weight:600;font-family:var(--font-mono);border-radius:20px;align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.score-badge.critical-pass{background:var(--success-bg);color:var(--success)}.score-badge.critical-fail{background:var(--error-bg);color:var(--error);animation:1.5s infinite scorePulse}.score-badge.overall{background:var(--bg-secondary);color:var(--text-secondary)}.score-badge.overall.high{background:var(--success-bg);color:var(--success)}@keyframes scorePulse{0%,to{opacity:1}50%{opacity:.7}}.score-label{font-size:11px;font-weight:500;font-family:var(--font-sans);opacity:.8}.spin-icon{animation:1s linear infinite spin;display:inline-block}.landing-page{z-index:9999;color:#e8ecf4;background:#0a0e1a;font-family:Inter,-apple-system,sans-serif;position:fixed;inset:0;overflow:hidden auto}.landing-bg{pointer-events:none;z-index:0;position:fixed;inset:0}.landing-gradient-orb{filter:blur(100px);opacity:.4;border-radius:50%;position:absolute}.landing-gradient-orb.orb-1{background:radial-gradient(circle,#00c2cb59 0%,#0000 70%);width:600px;height:600px;animation:15s ease-in-out infinite orbFloat1;top:-100px;left:-100px}.landing-gradient-orb.orb-2{background:radial-gradient(circle,#2d94dd4d 0%,#0000 70%);width:500px;height:500px;animation:18s ease-in-out infinite orbFloat2;bottom:-50px;right:-50px}.landing-gradient-orb.orb-3{background:radial-gradient(circle,#8b5cf633 0%,#0000 70%);width:350px;height:350px;animation:20s ease-in-out infinite orbFloat3;top:50%;left:60%}@keyframes orbFloat1{0%,to{transform:translate(0)scale(1)}33%{transform:translate(60px,40px)scale(1.1)}66%{transform:translate(-30px,60px)scale(.95)}}@keyframes orbFloat2{0%,to{transform:translate(0)scale(1)}33%{transform:translate(-50px,-30px)scale(1.05)}66%{transform:translate(40px,-50px)scale(.9)}}@keyframes orbFloat3{0%,to{transform:translate(0)}50%{transform:translate(-60px,30px)}}.landing-grid-overlay{background-image:linear-gradient(#ffffff04 1px,#0000 1px),linear-gradient(90deg,#ffffff04 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.landing-shapes{pointer-events:none;z-index:1;transition:transform .3s ease-out;position:fixed;inset:0}.landing-shape{animation:8s ease-in-out infinite shapeFloat;position:absolute}.shape-1{animation-duration:10s;animation-delay:0s;top:12%;left:8%}.shape-2{animation-duration:12s;animation-delay:-2s;top:25%;right:10%}.shape-3{animation-duration:9s;animation-delay:-4s;bottom:25%;left:5%}.shape-4{animation-duration:11s;animation-delay:-1s;top:60%;right:8%}.shape-5{animation-duration:13s;animation-delay:-3s;bottom:12%;right:20%}@keyframes shapeFloat{0%,to{opacity:.6;transform:translateY(0)rotate(0)}25%{opacity:.8;transform:translateY(-15px)rotate(3deg)}50%{opacity:.5;transform:translateY(5px)rotate(-2deg)}75%{opacity:.7;transform:translateY(-10px)rotate(1deg)}}.landing-content{z-index:2;flex-direction:column;max-width:900px;min-height:100vh;margin:0 auto;padding:24px 24px 48px;display:flex;position:relative}.landing-header{justify-content:space-between;align-items:center;padding:8px 0 32px;display:flex}.landing-logo{align-items:center;gap:12px;display:flex}.landing-logo-name{letter-spacing:2px;color:#fff;font-size:14px;font-weight:800;display:block}.landing-logo-sub{letter-spacing:1.5px;color:#ffffff73;font-size:10px;font-weight:500;display:block}.landing-hero{text-align:center;padding:48px 0 40px;animation:.8s ease-out both fadeInUp}.landing-hero-badge{letter-spacing:.5px;color:var(--teal,#00c2cb);background:#00c2cb14;border:1px solid #00c2cb26;border-radius:20px;align-items:center;gap:8px;margin-bottom:24px;padding:6px 16px;font-size:12px;font-weight:600;display:inline-flex}.landing-badge-dot{background:#00c2cb;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.landing-hero-title{color:#fff;margin:0 0 16px;font-size:clamp(28px,5vw,48px);font-weight:800;line-height:1.15}.landing-gradient-text{background:linear-gradient(135deg,#00c2cb 0%,#2d94dd 50%,#8b5cf6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero-desc{color:#ffffff8c;max-width:520px;margin:0 auto;font-size:16px;line-height:1.7}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-pipeline{justify-content:center;align-items:flex-start;gap:0;padding:32px 0 40px;animation:.8s ease-out .3s both fadeInUp;display:flex}.landing-step{text-align:center;flex:1;max-width:220px}.landing-step-icon{color:#00c2cb;background:#00c2cb1a;border:1px solid #00c2cb33;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 12px;transition:all .3s;display:flex}.landing-step-icon.step-2{color:#2d94dd;background:#2d94dd1a;border-color:#2d94dd33}.landing-step-icon.step-3{color:#3fb950;background:#3fb9501a;border-color:#3fb95033}.landing-step:hover .landing-step-icon{transform:translateY(-4px);box-shadow:0 8px 24px #00c2cb26}.landing-step-num{color:#fff3;letter-spacing:1px;margin-bottom:6px;font-size:11px;font-weight:700}.landing-step h3{color:#fff;margin:0 0 6px;font-size:15px;font-weight:700}.landing-step p{color:#fff6;margin:0;font-size:13px;line-height:1.5}.landing-step-arrow{color:#ffffff26;align-items:center;padding-top:20px;display:flex}.landing-stats{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff08;border:1px solid #ffffff0f;border-radius:16px;justify-content:center;align-items:center;gap:24px;margin-bottom:40px;padding:24px 32px;animation:.8s ease-out .5s both fadeInUp;display:flex}.landing-stat{text-align:center;flex:1}.landing-stat-value{color:#fff;font-variant-numeric:tabular-nums;font-size:28px;font-weight:800}.landing-stat-label{color:#ffffff59;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:11px;font-weight:500}.landing-stat-divider{background:#ffffff14;width:1px;height:40px}.landing-auth-section{justify-content:center;margin-bottom:48px;animation:.8s ease-out .7s both fadeInUp;display:flex}.landing-auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);text-align:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:20px;width:100%;max-width:400px;padding:32px}.landing-signin-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00c2cb 0%,#2d94dd 100%);border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 24px;font-size:15px;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 20px #00c2cb40}.landing-signin-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #00c2cb59}.landing-signin-btn:disabled{opacity:.5;cursor:not-allowed}.landing-auth-note{color:#ffffff59;margin-top:12px;font-size:12px}.landing-dev-btn{color:#fff6;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:8px;width:100%;margin-top:12px;padding:10px;font-size:12px;transition:all .2s;display:block}.landing-dev-btn:hover{color:#fff9;border-color:#fff3}.landing-footer{text-align:center;border-top:1px solid #ffffff0d;margin-top:auto;padding:24px 0;animation:.8s ease-out .9s both fadeInUp}.landing-footer-brand{color:#ffffff59;margin-bottom:12px;font-size:13px}.landing-footer-brand a{color:#00c2cb;font-weight:700;text-decoration:none}.landing-footer-brand a:hover{text-decoration:underline}.landing-footer-badges{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.landing-trust-badge{color:#ffffff4d;background:#ffffff08;border:1px solid #ffffff0f;border-radius:6px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:500;display:inline-flex}@media (max-width:768px){.landing-pipeline{flex-direction:column;align-items:center;gap:20px}.landing-step-arrow{padding:0;transform:rotate(90deg)}.landing-stats{flex-direction:column;gap:16px;padding:20px}.landing-stat-divider{width:60px;height:1px}.landing-hero-title{font-size:28px}.landing-shapes{display:none}.landing-footer-badges{flex-direction:column;align-items:center}}.topbar-user{cursor:pointer;transition:background .2s;border-radius:10px!important}.topbar-user:hover{background:var(--bg-elevated)!important}.user-dropdown{background:var(--bg-card);border:1px solid var(--border);z-index:1000;border-radius:14px;min-width:260px;animation:.2s dropdownSlideIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 16px 48px #0000002e,0 4px 12px #00000014}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.user-dropdown-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px;display:flex}.user-dropdown-role{padding:8px 16px 12px}.role-badge{letter-spacing:.5px;text-transform:uppercase;color:var(--teal);background:#00c2cb1a;border:1px solid #00c2cb33;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-flex}.role-badge.admin{color:#00c2cb;background:linear-gradient(135deg,#00c2cb26,#2d94dd26);border-color:#00c2cb4d}.user-dropdown-divider{background:var(--border);height:1px;margin:0}.user-dropdown-item{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;font-size:13px;font-weight:500;transition:background .15s;display:flex}.user-dropdown-item:hover{background:var(--bg-elevated)}.user-dropdown-item svg{color:var(--text-muted);flex-shrink:0}.user-dropdown-item.signout{color:#e5534b}.user-dropdown-item.signout:hover{background:#e5534b14}.user-dropdown-item.signout svg{color:#e5534b}[data-theme=dark] .user-dropdown{background:#1a1f2e;border-color:#ffffff0f;box-shadow:0 16px 48px #0006,0 4px 12px #0003}[data-theme=dark] .user-dropdown-item:hover{background:#ffffff0d}
