:root{--bg-page: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-light: #eff6ff;--success: #16a34a;--warning: #d97706;--danger: #dc2626;font-family:DM Sans,system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg-page)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg-page)}#root{min-height:100vh}.app{max-width:1440px;margin:0 auto;padding:1rem 1.25rem 2.5rem}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:var(--muted)}.top-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 2px #0f172a0a;margin-bottom:1.25rem}.brand{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.brand img{height:40px;width:auto;object-fit:contain}.brand h1{margin:0;font-size:1.15rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.header-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.btn{font-family:inherit;cursor:pointer;border-radius:8px;font-size:.875rem;font-weight:500;padding:.5rem 1rem;border:1px solid var(--border);background:var(--surface);color:var(--text);display:inline-flex;align-items:center;gap:.4rem}.btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1rem 1.1rem;box-shadow:0 1px 2px #0f172a0a;border-left-width:4px}.kpi-card.blue{border-left-color:#3b82f6}.kpi-card.green{border-left-color:#22c55e}.kpi-card.amber{border-left-color:#f59e0b}.kpi-card.red{border-left-color:#ef4444}.kpi-card label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.35rem}.kpi-card strong{font-size:1.4rem;font-weight:700;color:var(--text)}.kpi-card small{display:block;margin-top:.25rem;font-size:.75rem;color:var(--muted)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 2px #0f172a0a;margin-bottom:1rem}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.1rem;border-bottom:1px solid var(--border)}.panel-head h3{margin:0;font-size:.9rem;font-weight:600;color:var(--text)}.panel-body{padding:1rem 1.1rem 1.1rem}.filters{padding:1rem 1.1rem}.filters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.filter-employee-span{grid-column:1 / -1;display:flex;flex-direction:column;gap:.5rem}.table-scroll-tall{max-height:min(70vh,720px)}.filter-input{font-family:inherit;padding:.5rem .65rem;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:.875rem;width:100%}.panel-head-actions{display:flex;align-items:center;gap:.75rem}.doc-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;padding:1rem 1.1rem 1.1rem;max-height:420px;overflow-y:auto}.doc-type-card{text-align:left;font-family:inherit;cursor:pointer;border:1px solid var(--border);border-radius:10px;padding:.85rem 1rem;background:#fff;transition:border-color .15s,box-shadow .15s}.doc-type-card:hover{border-color:#93c5fd;box-shadow:0 2px 8px #2563eb1a}.doc-type-card.active{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 2px #2563eb33}.doc-type-card-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.doc-type-rank{font-size:.65rem;font-weight:700;color:var(--muted);background:#f1f5f9;padding:.1rem .35rem;border-radius:4px}.doc-type-name{font-size:.8rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.doc-type-card strong{display:block;font-size:1.1rem;color:var(--text)}.doc-type-card small{display:block;margin-top:.25rem;font-size:.7rem;color:var(--muted)}.doc-type-bar{margin-top:.5rem;height:4px;background:#f1f5f9;border-radius:4px;overflow:hidden}.doc-type-bar-fill{height:100%;border-radius:4px}.table-scroll-sm{max-height:280px}.viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.viewer-modal{background:#fff;border-radius:12px;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 20px 40px #0f172a26;display:flex;flex-direction:column;gap:.75rem}.viewer-modal h2{margin:0;font-size:1.1rem}.viewer-badge{font-size:.8rem;color:var(--muted);background:#f1f5f9;padding:.35rem .75rem;border-radius:8px}.filters label{display:flex;flex-direction:column;gap:.35rem;font-size:.75rem;font-weight:500;color:var(--muted);min-width:150px}.filters select{font-family:inherit;padding:.5rem .65rem;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font-size:.875rem}.charts-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;margin-bottom:1rem}.chart-span-8,.chart-span-4,.chart-span-6{grid-column:span 12}@media (min-width: 1024px){.chart-span-8{grid-column:span 8}.chart-span-4{grid-column:span 4}.chart-span-6{grid-column:span 6}}.alert-error{padding:1rem 1.1rem;border-radius:10px;background:#fef2f2;border:1px solid #fecaca;color:#991b1b;margin-bottom:1rem;font-size:.9rem}.table-scroll{overflow:auto;max-height:440px}table{width:100%;border-collapse:collapse;font-size:.8rem}th,td{padding:.55rem .75rem;text-align:left;border-bottom:1px solid var(--border)}th{position:sticky;top:0;background:#f8fafc;color:var(--muted);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;z-index:1}tbody tr:hover td{background:#f8fafc}.pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.85rem;border-top:1px solid var(--border)}.meta{font-size:.8rem;color:var(--muted)}.spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
