@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary:#502172;--primary-light:#7b3fa0;--accent:#ffb300;--background:#f8f9fa;--card-bg:#fff;--text-main:#1a0a2e;--text-muted:#6b5b7b;--border:#5021721a;--sidebar-w:260px}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;max-width:100%;overflow-x:hidden}body{background-color:var(--background);color:var(--text-main);font-family:Inter,sans-serif;line-height:1.5}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-layout{width:100%;min-height:100vh;overflow-x:hidden}.filter-sidebar{width:var(--sidebar-w);color:#fff;z-index:10;background:linear-gradient(#502172 0%,#2e0d47 100%);flex-direction:column;gap:1.5rem;height:100vh;padding:2rem 1.25rem;display:flex;position:fixed;top:0;left:0;overflow-y:auto;box-shadow:4px 0 16px #00000014}.filter-sidebar h2{letter-spacing:.05em;text-transform:uppercase;opacity:.95;margin-bottom:.5rem;font-size:1rem;font-weight:800}.filter-sidebar .filter-group label{letter-spacing:.08em;text-transform:uppercase;color:#ffb300;margin-bottom:.5rem;font-size:.7rem;font-weight:800;display:block}.filter-sidebar .filter-group select{color:#fff;appearance:none;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;outline:none;width:100%;padding:.6rem .75rem;font-size:.85rem}.filter-sidebar .filter-group input{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;outline:none;width:100%;padding:.6rem .75rem;font-size:.85rem}.filter-sidebar .filter-group input:focus{border-color:#ffb300}.filter-sidebar .filter-group input::placeholder{color:#ffffff80}.filter-sidebar .filter-group select:focus{border-color:#ffb300}.filter-sidebar .filter-group select option{color:#1a0a2e;background:#fff}.filter-sidebar .filter-chips{flex-wrap:wrap;gap:.35rem;margin-top:.5rem;display:flex}.filter-sidebar .filter-chip{color:#ffb300;cursor:pointer;background:#ffb3002e;border:1px solid #ffb30059;border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.filter-sidebar .filter-chip:hover{background:#ffb30047}.filter-sidebar .filter-empty{color:#ffffff80;font-size:.7rem;font-style:italic}.main-content{width:calc(100vw - var(--sidebar-w));min-height:100vh;margin-left:var(--sidebar-w);min-width:0;padding:2rem;overflow-x:hidden}@media (max-width:1100px){:root{--sidebar-w:220px}.main-content{padding:1.5rem}}@media (max-width:900px){.filter-sidebar{flex-flow:wrap;gap:1rem;width:100%;height:auto;min-height:auto;padding:1rem;position:relative}.filter-sidebar h2{width:100%;margin-bottom:0}.filter-sidebar .filter-group{flex:220px;min-width:220px}.main-content{width:100%;margin-left:0;padding:1rem}.dashboard-layout{flex-direction:column}}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000000d}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:1.5rem;display:grid}.kpi-card h3{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:600}.kpi-card .value{color:var(--primary);font-size:2rem;font-weight:800}.header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.opportunity-banner{color:#fff;background:linear-gradient(135deg,#502172,#7b3fa0);border-radius:14px;margin-bottom:2rem;padding:2rem}.btn{cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:600;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}.table-container{max-width:100%;margin-top:2rem;overflow-x:auto}.dashboard{min-width:0}.charts-grid{grid-template-columns:1fr 2fr;gap:2rem;min-width:0;margin-bottom:2rem;display:grid}.charts-grid>.card{min-width:0;overflow:hidden}@media (max-width:1400px){.charts-grid{grid-template-columns:1fr}}table{border-collapse:collapse;background:#fff;border-radius:12px;width:100%;overflow:hidden;box-shadow:0 4px 6px #0000000d}th{color:var(--primary);text-align:left;text-transform:uppercase;cursor:pointer;background:#eeeef2;padding:1rem;font-size:.75rem;font-weight:800}td{border-bottom:1px solid var(--border);padding:1rem;font-size:.875rem}tr:hover td{background:#fdf7ff}.badge{border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.badge-ouro{color:#ffb300;background:#fff8e1}.badge-prata{color:#4b5563;background:#f3f4f6}.badge-bronze{color:#c87a3e;background:#fef2f2}.search-input{border:1px solid var(--border);border-radius:8px;outline:none;width:300px;margin-bottom:1rem;padding:.75rem 1rem}.search-input:focus{border-color:var(--primary)}
