:root{color:#172033;letter-spacing:0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f6f8fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans SC,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{background:#f6f8fb;min-width:320px;min-height:100svh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.7}#root{min-height:100svh}.auth-shell{place-items:center;min-height:100svh;padding:24px;display:grid}.auth-panel{background:#fff;border:1px solid #dbe2eb;border-radius:8px;width:min(100%,420px);padding:32px;box-shadow:0 20px 60px #19253814}.auth-mark{color:#0f766e;background:#e7f7f4;border-radius:8px;place-items:center;width:44px;height:44px;margin-bottom:20px;display:grid}.auth-panel h1{margin:0;font-size:30px;line-height:1.15}.auth-panel p{color:#627084;margin:10px 0 24px}.auth-panel form,.auth-panel label{gap:10px;display:grid}.auth-panel form{gap:16px}.auth-panel label{color:#42516a;font-size:13px;font-weight:700}.auth-panel input,.filters input,.filters select{color:#172033;background:#fff;border:1px solid #d5deea;border-radius:8px;min-width:0;height:40px;padding:0 12px}.auth-panel input:focus,.filters input:focus,.filters select:focus{border-color:#2563eb;outline:3px solid #2563eb24}.auth-panel button{color:#fff;background:#172033;border:0;border-radius:8px;height:42px;font-weight:800}.form-error,.error-banner{color:#b42318}.app-shell{grid-template-columns:248px minmax(0,1fr);min-height:100svh;display:grid}.sidebar{background:#fff;border-right:1px solid #dde5ef;height:100svh;padding:22px 16px;position:sticky;top:0}.brand{align-items:center;gap:12px;margin-bottom:28px;display:flex}.brand-mark{color:#fff;background:#172033;border-radius:8px;place-items:center;width:38px;height:38px;font-weight:900;display:grid}.brand strong,.brand span{display:block}.brand strong{font-size:15px}.brand span{color:#748197;font-size:12px}.sidebar nav{gap:6px;display:grid}.sidebar nav button{color:#536179;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;height:42px;padding:0 12px;font-size:14px;font-weight:750;display:flex}.sidebar nav button.active,.sidebar nav button:hover{color:#0f766e;background:#e9f8f5}.dashboard{min-width:0;padding:26px 30px 40px}.topbar{justify-content:space-between;align-items:center;gap:20px;margin-bottom:22px;display:flex}.topbar h1{margin:0;font-size:28px;line-height:1.15}.topbar p{color:#66758c;margin:6px 0 0}.admin-chip{color:#344258;background:#fff;border:1px solid #dbe2eb;border-radius:8px;align-items:center;gap:9px;max-width:420px;height:40px;padding:0 8px 0 12px;font-size:13px;font-weight:700;display:flex}.admin-chip span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.admin-chip button{color:#66758c;background:#f3f6fa;border:0;border-radius:6px;place-items:center;width:28px;height:28px;display:grid}.filters{background:#fff;border:1px solid #dbe2eb;border-radius:8px;grid-template-columns:repeat(5,minmax(120px,1fr));align-items:end;gap:12px;margin-bottom:18px;padding:12px;display:grid}.filters label{color:#64748b;gap:6px;font-size:12px;font-weight:800;display:grid}.select-wrap{display:block;position:relative}.select-wrap select{appearance:none;width:100%}.select-wrap svg{pointer-events:none;color:#64748b;position:absolute;top:13px;right:10px}.error-banner{background:#fffbfa;border:1px solid #fecdca;border-radius:8px;margin-bottom:18px;padding:10px 12px;font-size:14px;font-weight:700}.kpi-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:18px;display:grid}.kpi-card,.chart-panel,.table-panel,.retention-panel,.activity-panel{background:#fff;border:1px solid #dbe2eb;border-radius:8px;box-shadow:0 12px 32px #1823340a}.kpi-card{align-content:center;gap:10px;min-height:106px;padding:16px;display:grid}.kpi-card span{color:#66758c;font-size:12px;font-weight:800}.kpi-card strong{color:#162033;font-size:28px;line-height:1}.kpi-card.is-good{background:#f3fbf9;border-color:#a8e1d6}.dashboard-grid{grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);gap:18px;display:grid}.chart-panel,.table-panel,.retention-panel,.activity-panel{min-width:0;padding:18px}.table-panel{overflow-x:auto}.panel-heading{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.panel-heading h2{margin:0;font-size:17px;line-height:1.2}.panel-heading p{color:#748197;margin:4px 0 0;font-size:13px}.line-chart{width:100%;height:260px}.line-chart path{fill:none;stroke:#edf1f6;stroke-width:1px}.line-chart polyline{fill:none;stroke:#2563eb;stroke-linecap:round;stroke-linejoin:round;stroke-width:3px}.chart-legend{color:#64748b;justify-content:space-between;font-size:12px;font-weight:800;display:flex}table{border-collapse:collapse;width:100%;font-size:13px}th,td{text-align:left;border-bottom:1px solid #eef2f7;padding:10px 8px}th{color:#64748b;text-transform:uppercase;font-size:11px}td{color:#26354a}.retention-grid{gap:8px;display:grid}.retention-header,.retention-row{grid-template-columns:minmax(72px,1fr) repeat(3,76px);align-items:center;gap:8px;display:grid}.retention-header span{color:#64748b;text-transform:uppercase;font-size:11px;font-weight:900}.retention-row span,.retention-row b{border-radius:6px;padding:8px;font-size:12px}.retention-row span{color:#44546b;background:#f6f8fb;font-weight:800}.retention-row b{color:#0f3f39;background:color-mix(in srgb, #14b8a6 calc(var(--heat,0) * 75%), #edf8f6);text-align:center}.activity-list{gap:10px;display:grid}.activity-list span{color:#536179;border:1px solid #eef2f7;border-radius:8px;justify-content:space-between;padding:11px 12px;font-size:13px;font-weight:750;display:flex}.activity-list b{color:#172033}@media (width<=1040px){.app-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #dbe2eb;border-right:0;height:auto;position:static}.sidebar nav{grid-template-columns:repeat(5,minmax(0,1fr))}.dashboard-grid,.filters,.kpi-grid{grid-template-columns:1fr 1fr}}@media (width<=720px){.dashboard{padding:18px}.topbar,.sidebar nav{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.filters,.kpi-grid,.dashboard-grid{grid-template-columns:1fr}.retention-header,.retention-row{grid-template-columns:minmax(48px,1fr) repeat(3,minmax(56px,1fr))}}
