@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{color:#111827;background:#f5f7fb;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#f5f7fb}button,input,select{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;background:#ffffff;border-right:1px solid #e5e7eb}.brand{display:flex;align-items:center;gap:12px;padding:8px 6px 24px}.brand-mark{display:grid;width:44px;height:44px;place-items:center;border-radius:8px;color:#fff;background:#2563eb;font-weight:800}.brand strong,.brand small{display:block}.brand small{margin-top:3px;color:#6b7280;font-size:12px}.nav-list{display:grid;gap:8px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px;color:#4b5563;background:transparent;border:0;border-radius:8px;text-align:left}.nav-item span{display:grid;width:28px;height:28px;place-items:center;border-radius:7px;background:#f3f4f6;color:#2563eb;font-weight:800;font-size:12px}.nav-item.active,.nav-item:hover{color:#1d4ed8;background:#eff6ff;font-weight:700}.content{width:min(1480px,100%);padding:32px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;padding-bottom:22px;margin-bottom:22px;border-bottom:1px solid #e5e7eb}h1,h2,h3,p{margin-top:0}h1{margin-bottom:8px;color:#0f172a;font-size:32px;letter-spacing:0}h2{margin-bottom:12px;color:#0f172a;font-size:18px}h3{color:#374151;font-size:15px;font-weight:600}p,.page-header small,.panel-title p{color:#6b7280}.home-hero{padding:26px 0 42px}.home-hero h1{font-size:42px;font-weight:800}.home-hero p{max-width:760px;font-size:18px}.landing-grid,.split-grid,.filter-grid{display:grid;gap:20px}.landing-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.split-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:20px}.landing-card,.panel,.metric-card{background:#ffffff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 10px #0f172a0d}.landing-card{display:flex;flex-direction:column;min-height:260px;padding:28px}.landing-card span{display:grid;width:52px;height:52px;place-items:center;margin-bottom:22px;border-radius:8px;color:#1d4ed8;background:#eff6ff;font-weight:800}.landing-card p{flex:1;line-height:1.6}.landing-card button,.primary{width:fit-content;min-height:40px;padding:0 16px;color:#fff;background:#2563eb;border:0;border-radius:8px;font-weight:700}.panel{padding:22px;margin-bottom:20px;overflow:hidden}.panel-title{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}.metric-grid{display:grid;gap:16px;margin-bottom:20px}.metric-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-grid.five{grid-template-columns:repeat(5,minmax(0,1fr))}.metric-card{min-height:112px;padding:18px;border-left:5px solid #2563eb}.metric-card span,.metric-card small{display:block;color:#6b7280;font-size:13px;font-weight:600}.metric-card strong{display:block;margin-top:12px;overflow-wrap:anywhere;color:#0f172a;font-size:24px}.metric-card.tone-green{border-left-color:#10b981}.metric-card.tone-amber{border-left-color:#f59e0b}.metric-card.tone-violet{border-left-color:#7c3aed}.filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.field{display:grid;gap:8px;color:#374151;font-weight:600}select,input[type=date]{min-height:40px;padding:8px 10px;color:#111827;background:#ffffff;border:1px solid #d1d5db;border-radius:8px}select[multiple]{min-height:112px}.inline-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.segmented{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px}.segmented button,.tabs button{min-height:38px;padding:0 14px;color:#4b5563;background:#ffffff;border:1px solid #d1d5db;border-radius:8px;font-weight:700}.segmented button.active,.tabs button.active{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.tabs{display:flex;flex-wrap:wrap;gap:10px;margin:4px 0 20px}.warning{margin-bottom:18px;padding:14px 16px;color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;font-weight:600}.table-wrap{width:100%;overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px;background:#ffffff}table{width:100%;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid #eef2f7;text-align:left;white-space:nowrap}th{color:#475569;background:#f8fafc;font-size:12px;text-transform:uppercase}.bar-list{display:grid;gap:13px}.bar-row{display:grid;grid-template-columns:minmax(130px,1.4fr) minmax(100px,2fr) minmax(92px,auto);gap:12px;align-items:center}.bar-row span{min-width:0;overflow:hidden;color:#334155;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.bar-row strong{color:#0f172a;text-align:right;white-space:nowrap}.bar-track{height:12px;overflow:hidden;background:#e5e7eb;border-radius:999px}.bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#10b981)}.chart-box{border:1px solid #e5e7eb;border-radius:8px;background:#ffffff}.chart-box svg{width:100%;display:block}.chart-box line{stroke:#cbd5e1;stroke-width:1}.chart-box polyline{fill:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.chart-box text{fill:#64748b;font-size:12px}.legend{display:flex;gap:16px;padding:0 18px 16px;color:#475569;font-size:13px;font-weight:600}.legend span{display:flex;gap:6px;align-items:center}.legend i{display:inline-block;width:10px;height:10px;border-radius:50%}.donut-layout{display:grid;grid-template-columns:minmax(180px,260px) minmax(0,1fr);gap:18px;align-items:center}.donut-chart{width:100%;max-width:260px;margin:0 auto}.donut-ring{fill:transparent;stroke:#e5e7eb;stroke-width:6}.donut-segment{fill:transparent;stroke-width:6;transform:rotate(-90deg);transform-origin:center}.donut-center-label{fill:#64748b;font-size:3px;font-weight:700;text-transform:uppercase}.donut-center-value{fill:#0f172a;font-size:3.4px;font-weight:800}.donut-legend{display:grid;gap:10px}.donut-legend div{display:grid;grid-template-columns:12px minmax(0,1fr) auto;gap:8px;align-items:center}.donut-legend i{width:12px;height:12px;border-radius:50%}.donut-legend span{overflow:hidden;color:#334155;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.donut-legend strong{color:#0f172a}.column-chart{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:18px;min-height:260px;align-items:end;padding-top:18px}.column-item{display:grid;grid-template-rows:auto 190px auto;gap:8px;min-width:0;text-align:center}.column-value{color:#0f172a;font-weight:800}.column-track{display:flex;align-items:end;justify-content:center;height:190px;border-radius:8px;background:#f1f5f9}.column-fill{width:56%;min-height:4px;border-radius:7px 7px 0 0}.column-item span{overflow-wrap:anywhere;color:#475569;font-size:13px;font-weight:700}.single-month{display:grid;place-items:center;min-height:220px;margin-bottom:20px;border:1px solid #dbeafe;border-radius:8px;background:#f8fafc}.single-month span{color:#6b7280;font-weight:700;text-transform:uppercase}.single-month strong{color:#0f172a;font-size:44px}.state-box{display:grid;gap:6px;place-items:center;min-height:180px;padding:28px;color:#6b7280;background:#ffffff;border:1px dashed #d1d5db;border-radius:8px;text-align:center}.state-box strong{color:#111827}.state-box.error{color:#991b1b;background:#fef2f2;border-color:#fecaca}@media (max-width: 1100px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.nav-list{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-grid.five,.metric-grid.four,.landing-grid,.split-grid,.filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.content,.sidebar{padding:18px}.page-header,.panel-title{display:grid}.nav-list,.metric-grid.three,.metric-grid.five,.metric-grid.four,.landing-grid,.split-grid,.filter-grid,.bar-row{grid-template-columns:1fr}.bar-row strong{text-align:left}.donut-layout{grid-template-columns:1fr}}.pill-select-group{display:flex;flex-direction:column;gap:8px;margin-bottom:8px;background:#f8fafc;padding:16px;border-radius:10px;border:1px solid #e2e8f0}.pill-select-label{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:#475569;font-weight:700}.pill-select-options{display:flex;flex-wrap:wrap;gap:8px}.pill-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;color:#475569;background:#ffffff;border:1px solid #cbd5e1;border-radius:20px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d}.pill-btn:hover{background:#f1f5f9;color:#1e293b;border-color:#94a3b8;transform:translateY(-1px)}.pill-btn.active{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);color:#fff;border-color:#2563eb;box-shadow:0 4px 6px -1px #2563eb33,0 2px 4px -1px #2563eb1a}.pill-btn-indicator{font-size:11px;font-weight:800;opacity:.9}.pill-btn.active .pill-btn-indicator{color:#a7f3d0}.chart-tooltip{position:absolute;pointer-events:none;background:rgba(15,23,42,.95);color:#f8fafc;padding:12px 14px;border-radius:10px;font-size:12px;box-shadow:0 10px 25px -5px #0000004d,0 8px 10px -6px #0000004d;z-index:9999;width:250px;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-align:left;transition:all .1s ease}.chart-tooltip-header{font-size:13px;font-weight:700;margin-bottom:6px;border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:6px;color:#60a5fa;text-transform:capitalize}.chart-tooltip-body{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.chart-tooltip-body span{color:#94a3b8;font-weight:500}.chart-tooltip-body strong{font-size:14px;color:#34d399}.chart-tooltip-products{margin-top:8px}.tooltip-section-title{color:#94a3b8;font-size:10px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;margin-bottom:4px}.chart-tooltip-products ul{margin:0;padding-left:14px;list-style-type:disc;color:#e2e8f0}.chart-tooltip-products li{margin-bottom:3px;font-size:11px}.tooltip-more-items{list-style-type:none!important;margin-left:-14px;color:#94a3b8;font-style:italic;font-size:10px!important;margin-top:4px}.chart-box circle{transition:all .2s cubic-bezier(.4,0,.2,1)}.chart-box circle:hover{r:8px;stroke-width:4px}
