*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f1f5f9;color:#1e293b;font-size:14px}.header{background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;padding:14px 24px;display:flex;align-items:center;gap:14px;box-shadow:0 2px 8px #0003}.header-logo{font-size:22px;font-weight:800;letter-spacing:-.5px}.header-sub{font-size:11px;opacity:.7;margin-top:1px}.header-right{margin-left:auto;display:flex;align-items:center;gap:10px}.header-badge{font-size:12px;opacity:.85;background:#ffffff26;padding:3px 10px;border-radius:20px}.nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 24px;display:flex;overflow-x:auto}.nav-tab{padding:12px 16px;cursor:pointer;border-bottom:3px solid transparent;font-size:13px;font-weight:600;color:#64748b;white-space:nowrap;transition:all .15s}.nav-tab.active{color:#2563eb;border-bottom-color:#2563eb}.nav-tab:hover:not(.active){color:#334155;background:#f8fafc}.filter-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:9px 24px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.filter-label{font-size:12px;font-weight:700;color:#64748b}.filter-bar input[type=date]{padding:5px 9px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;color:#1e293b}.filter-bar input[type=date]:focus{outline:none;border-color:#2563eb}.preset-btn{padding:4px 10px;border:1px solid #e2e8f0;border-radius:5px;font-size:11px;font-weight:600;cursor:pointer;background:#f8fafc;color:#475569;transition:all .15s}.preset-btn:hover{background:#e0e7ff;color:#2563eb;border-color:#2563eb}.preset-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.filter-count{font-size:12px;color:#64748b;margin-left:4px}.filter-sep{color:#e2e8f0;font-size:16px}.main{padding:20px 24px;max-width:1440px;margin:0 auto}.upload-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:65vh;gap:20px}.upload-area{border:2px dashed #cbd5e1;border-radius:14px;padding:50px 70px;text-align:center;background:#fff;cursor:pointer;transition:all .2s;max-width:520px;width:100%}.upload-area:hover,.upload-area.drag-over{border-color:#2563eb;background:#eff6ff}.upload-icon{font-size:48px;margin-bottom:12px}.upload-title{font-size:17px;font-weight:700;margin-bottom:6px}.upload-sub{color:#64748b;font-size:13px;line-height:1.5}.upload-btn{display:inline-block;margin-top:14px;padding:9px 20px;background:#2563eb;color:#fff;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer}.upload-btn:hover{background:#1d4ed8}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:65vh;gap:16px}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite}.loading-text{font-size:14px;color:#64748b}.loading-progress{font-size:12px;color:#94a3b8}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px}.card{background:#fff;border-radius:10px;padding:16px 18px;box-shadow:0 1px 4px #00000012}.card-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.card-value{font-size:24px;font-weight:800;color:#1e293b}.card-sub{font-size:11px;color:#94a3b8;margin-top:3px}.card-accent{border-left:3px solid #2563eb}.card-green{border-left:3px solid #16a34a}.card-orange{border-left:3px solid #ea580c}.card-purple{border-left:3px solid #7c3aed}.panel{background:#fff;border-radius:10px;box-shadow:0 1px 4px #00000012;margin-bottom:18px;overflow:hidden}.panel-head{padding:13px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f1f5f9;gap:12px;flex-wrap:wrap}.panel-head h3{font-size:14px;font-weight:700;white-space:nowrap}.panel-body{padding:18px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}@media (max-width:900px){.grid2{grid-template-columns:1fr}}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:9px 14px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{background:#f1f5f9}th.sort-asc:after{content:" ▲";font-size:9px}th.sort-desc:after{content:" ▼";font-size:9px}td{padding:9px 14px;border-bottom:1px solid #f8fafc;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.muted{color:#94a3b8}.mono{font-family:monospace;font-size:12px}.badge{display:inline-block;padding:2px 7px;border-radius:10px;font-size:11px;font-weight:700}.b-blue{background:#eff6ff;color:#2563eb}.b-green{background:#f0fdf4;color:#16a34a}.b-gray{background:#f1f5f9;color:#64748b}.b-orange{background:#fff7ed;color:#ea580c}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:12px}.fg{display:flex;flex-direction:column;gap:4px}.fg label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.fg input{padding:8px 11px;border:1px solid #e2e8f0;border-radius:7px;font-size:13px}.fg input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn{padding:7px 14px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:5px}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:#f1f5f9;color:#334155;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0}.btn-sm{padding:5px 10px;font-size:12px}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.search{padding:6px 11px;border:1px solid #e2e8f0;border-radius:7px;font-size:13px;width:200px}.search:focus{outline:none;border-color:#2563eb}select.filter{padding:6px 10px;border:1px solid #e2e8f0;border-radius:7px;font-size:13px;background:#fff}.pager{display:flex;align-items:center;gap:5px;padding:10px 14px;border-top:1px solid #f1f5f9;font-size:12px;color:#64748b;flex-wrap:wrap}.pager-btn{padding:3px 8px;border:1px solid #e2e8f0;border-radius:5px;cursor:pointer;background:#fff;font-size:12px}.pager-btn:hover{background:#f1f5f9}.pager-btn.on{background:#2563eb;color:#fff;border-color:#2563eb}.pager-btn:disabled{opacity:.4;cursor:not-allowed}.chart-box{position:relative;height:250px}.detail-row{display:none}.detail-row.open{display:table-row}.detail-inner{background:#f8fafc;padding:12px 18px;font-size:12px}.detail-table{width:100%;border-collapse:collapse;font-size:12px}.detail-table td{padding:5px 10px;border-bottom:1px solid #e2e8f0}.detail-table tr:last-child td{border-bottom:none}.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-warn{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.invoice-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.invoice-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:9px;padding:13px;cursor:pointer;transition:all .15s}.invoice-card:hover{border-color:#2563eb;background:#eff6ff}.invoice-card-nr{font-size:14px;font-weight:800;margin-bottom:3px}.invoice-card-date{font-size:11px;color:#64748b}.invoice-card-meta{font-size:10px;color:#94a3b8;margin-top:5px}.srv-upload{border:2px dashed #e2e8f0;border-radius:9px;padding:18px;background:#fafafa;text-align:center;transition:all .2s}.srv-upload.drag-over{border-color:#2563eb;background:#eff6ff}.bar-wrap{width:80px;background:#f1f5f9;border-radius:3px;height:5px;display:inline-block;vertical-align:middle}.bar{height:100%;background:#2563eb;border-radius:3px}.spin{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-radius:50%;border-top-color:transparent;animation:spin .6s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.odoo-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.odoo-dot.connected{background:#16a34a}.odoo-dot.disconnected{background:#94a3b8}.odoo-dot.error{background:#dc2626}.view{display:none}.view.active{display:block}.chart-box-lg{position:relative;height:200px}.chart-box-xl{position:relative;height:240px}.card-red{border-left:3px solid #dc2626;cursor:pointer}.card-red:hover{box-shadow:0 2px 8px #dc262633}.row-outlier>td{background:#fff7ed!important}.row-outlier:hover>td{background:#ffedd5!important}.row-noref>td{background:#fffbeb!important}.row-noref:hover>td{background:#fef3c7!important}.b-red{background:#fef2f2;color:#dc2626}
