@import"https://fonts.googleapis.com/css2?family=Manrope:wght@500;700;800&display=swap";:root{--bg: #eef3ee;--panel: #f8fbf8;--ink: #0d1b16;--muted: #5f726b;--line: #d8e1dc;--accent: #12735a;--accent-soft: #d8efe7;--danger: #c03d2f;--radius: 18px}*{box-sizing:border-box}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at 0% 0%,#fff 0,#eef3ee 40%),radial-gradient(circle at 100% 100%,#d7e8df 0,#eef3ee 30%)}.shell{max-width:1200px;margin:0 auto;padding:16px;display:grid;gap:14px}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:16px}.auth-card{width:min(420px,100%);background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}.auth-title{margin:8px 0 14px}.auth-form{display:grid;gap:10px}.auth-form input{min-height:52px;padding:14px;font-size:16px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink)}.auth-submit{border:1px solid transparent;border-radius:12px;background:linear-gradient(90deg,#0f5f4c,#12735a);color:#fff;min-height:52px;padding:14px;font:inherit;font-weight:800}.auth-error{margin:0;color:var(--danger);font-size:13px}.app-toolbar{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.profile-actions{display:inline-flex;gap:8px;align-items:center}.profile-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:12px;border:1px solid var(--line);background:#fff}.profile-icon{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;color:#1f8f67;background:#e6f4ed}.profile-name{font-size:13px;color:var(--muted);font-weight:700}.view-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.view-tab{border:1px solid var(--line);background:#fff;color:var(--ink);padding:10px 12px;border-radius:12px;font:inherit;font-weight:800}.view-tab.active{border-color:transparent;background:linear-gradient(90deg,#0f5f4c,#12735a);color:#fff}.logout-btn{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:12px;padding:10px 12px;font:inherit;font-weight:700}.hero{background:linear-gradient(140deg,#f7fcf8,#e7f0ec);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:grid;gap:12px}.kicker{margin:0;color:var(--accent);font-weight:800;letter-spacing:.07em;text-transform:uppercase;font-size:12px}h1{margin:4px 0 0;font-size:clamp(26px,5.2vw,42px);line-height:1.05}.subtitle{margin:8px 0 0;color:var(--muted);font-size:13px}.controls{display:grid;gap:10px}label{display:grid;gap:4px;font-size:13px;color:var(--muted)}input[type=date]{border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);padding:10px 12px;font:inherit}.tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.tab{border:1px solid var(--line);background:#fff;color:var(--ink);padding:10px 12px;border-radius:12px;font:inherit;font-weight:700}.tab.active{border-color:transparent;background:var(--accent);color:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.kpi{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:12px}.kpi p{margin:0;color:var(--muted);font-size:12px}.kpi h2{margin:8px 0 0;font-size:clamp(18px,4.8vw,30px)}.pos{color:var(--accent)}.neg{color:var(--danger)}.content-grid{display:grid;gap:10px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.card h3{margin:0 0 10px;font-size:16px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.card-actions{display:flex;align-items:center;gap:8px}.chart-switch{display:inline-flex;flex-wrap:wrap;gap:6px;margin:0 0 10px}.chart-switch-btn{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:9px;padding:6px 10px;font:inherit;font-size:12px;font-weight:700}.chart-switch-btn.active{border-color:transparent;background:#1f8f67;color:#fff}.metric-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.metric-list li{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:8px 10px;border-radius:12px;background:#fff;border:1px solid var(--line)}.metric-list span{color:var(--muted);font-size:13px}.metric-list strong{font-size:14px}.bars{list-style:none;margin:0;padding:0;display:grid;gap:8px}.bars li{display:grid;gap:5px}.bar-head{display:flex;justify-content:space-between;font-size:12px}.bar-track{height:10px;background:var(--accent-soft);border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#3fa886,#12735a);border-radius:999px}.columns-scroll,.svg-chart-scroll{overflow-x:auto;padding-bottom:4px}.columns-chart{min-width:560px;display:grid;grid-auto-flow:column;grid-auto-columns:44px;gap:10px;align-items:end}.columns-item{display:grid;gap:6px}.columns-plot{height:170px;background:linear-gradient(180deg,#f5f9f6,#edf3ef);border:1px solid var(--line);border-radius:10px;padding:6px}.columns-plot.grouped{display:flex;align-items:flex-end;justify-content:center;gap:4px}.columns-plot.stacked{display:flex;flex-direction:column-reverse;justify-content:flex-start;align-items:stretch;gap:1px}.column-bar{border-radius:4px 4px 2px 2px;min-height:1px}.columns-plot.grouped .column-bar{width:8px;flex:0 0 8px}.columns-plot.stacked .column-bar{width:100%}.columns-footer{display:grid;gap:1px}.columns-value{font-size:11px;font-weight:800;text-align:center}.columns-label{font-size:10px;color:var(--muted);text-align:center}.chart-legend{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px 14px}.legend-item{display:inline-flex;gap:6px;align-items:center;font-size:12px;color:var(--muted)}.legend-dot{width:11px;height:11px;border-radius:3px}.legend-line{width:16px;height:0;border-top:2px solid #34495f;position:relative}.legend-line:after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:#34495f;top:-4px;right:0}.combo-chart,.lines-chart{min-width:560px;width:100%;height:220px}.grid-line{stroke:#dce5e0;stroke-width:1}.axis-label{font-size:9px;fill:#63756d}.combo-line{fill:none;stroke:#304d6a;stroke-width:2.2}.combo-dot{fill:#304d6a}.line-path{fill:none;stroke-width:2.4}.table-scroll{overflow-x:auto}.stops-table{width:100%;border-collapse:collapse;min-width:420px;font-size:12px;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}.stops-table th,.stops-table td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:right;white-space:nowrap}.stops-table th:first-child,.stops-table td:first-child{text-align:left}.stops-table thead th{background:#eef4f0;color:#4f6059;font-weight:800}.stops-table tbody tr:last-child td{border-bottom:0}.donut-wrap{display:grid;gap:12px;align-items:center}.donut{width:min(220px,60vw);aspect-ratio:1 / 1;border-radius:50%;margin:0 auto;display:grid;place-items:center}.donut-hole{width:58%;aspect-ratio:1 / 1;border-radius:50%;background:#fff;display:grid;place-items:center;text-align:center;border:1px solid var(--line)}.donut-hole strong{font-size:18px;line-height:1}.donut-hole span{font-size:11px;color:var(--muted)}.donut-legend{list-style:none;margin:0;padding:0;display:grid;gap:6px}.donut-legend li{display:grid;grid-template-columns:12px 1fr auto;gap:8px;align-items:center;font-size:12px}.donut-dot{width:10px;height:10px;border-radius:2px}.bar-fill--traffic{background:linear-gradient(90deg,#3fa886,#12735a)}.bar-fill--stops{background:linear-gradient(90deg,#3d7ea6,#30558f)}.bar-fill--comms{background:linear-gradient(90deg,#b87d18,#9a5b00)}.bar-fill--sentiment{background:linear-gradient(90deg,#5b8f39,#356f1a)}.bar-fill--rating{background:linear-gradient(90deg,#b84e3a,#8f2f1e)}.combo-chart .bar-fill--traffic{fill:#1f8f67}.combo-chart .bar-fill--stops{fill:#3c6f9e}.combo-chart .bar-fill--comms{fill:#ad7a20}.combo-chart .bar-fill--rating{fill:#b84e3a}.error{color:var(--danger)}@media (min-width: 760px){.hero{grid-template-columns:1.2fr 1fr;align-items:end}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.content-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 759px){.app-toolbar{grid-template-columns:1fr}.profile-actions{justify-content:flex-end}.profile-name{display:none}}
