/* Elm Dirt — Owned Funnel · DASHBOARDS
   Visual command center over the funnel data. Brand tokens match the funnel. */
:root{
  --g:#104817; --g-dark:#0b3010; --gold:#f5a623; --rose:#993c50;
  --ink:#252a32; --muted:#5b6470; --line:#e6e3dc; --bg:#f3f1ea; --card:#fff;
  --good:#1f9d55; --warn:#b45309; --radius:14px;
  --shadow:0 4px 18px rgba(16,72,23,.08); --shadow-lg:0 12px 36px rgba(16,72,23,.14);
  --font:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.45}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 18px}
h1,h2,h3{margin:0;font-weight:700;line-height:1.15}

/* top nav */
.topbar{background:var(--g);color:#fff;box-shadow:var(--shadow)}
.topbar .wrap{display:flex;align-items:center;gap:18px;height:60px}
.topbar .brand{font-weight:800;font-size:18px;letter-spacing:.3px;display:flex;align-items:center;gap:9px}
.topbar .brand .dot{width:11px;height:11px;border-radius:50%;background:var(--gold)}
.topbar nav{display:flex;gap:4px;margin-left:6px;flex-wrap:wrap}
.topbar nav a{padding:8px 14px;border-radius:999px;font-size:14px;font-weight:600;color:#dbe7db;text-decoration:none;transition:background .12s,color .12s}
.topbar nav a:hover{background:rgba(255,255,255,.12);color:#fff}
.topbar nav a.on{background:#fff;color:var(--g)}
.topbar .mock{margin-left:auto;background:var(--gold);color:var(--g-dark);font-size:11px;font-weight:800;letter-spacing:.5px;padding:5px 11px;border-radius:999px;white-space:nowrap}

.page-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:26px 0 6px}
.page-head h1{font-size:26px;color:var(--g)}
.page-head .sub{color:var(--muted);font-size:14px}
.muted{color:var(--muted)}
.section{margin:26px 0}
.section>h2{font-size:15px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:12px}

/* KPI cards */
.kpis{display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}
@media(min-width:720px){.kpis{grid-template-columns:repeat(4,1fr)}}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.kpi .k-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.kpi .k-val{font-size:28px;font-weight:800;color:var(--g);margin-top:4px;line-height:1}
.kpi .k-sub{font-size:12px;color:var(--muted);margin-top:6px}
.kpi.gold .k-val{color:var(--warn)}
/* clickable KPI deck — each card re-drives the hero chart's metric */
.kpi-btn{appearance:none;-webkit-appearance:none;display:block;width:100%;text-align:left;font:inherit;cursor:pointer;position:relative;transition:border-color .12s,box-shadow .12s,transform .06s}
.kpi-btn .k-label{padding-right:66px}
.kpi-btn:hover{border-color:#cdd5c6;box-shadow:var(--shadow-lg)}
.kpi-btn:active{transform:translateY(1px)}
.kpi-btn .k-spark{position:absolute;top:15px;right:15px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:#c7cdc0}
.kpi-btn.active{border-color:var(--g);box-shadow:0 0 0 2px rgba(16,72,23,.18),var(--shadow)}
.kpi-btn.active .k-val,.kpi-btn.active .k-spark{color:var(--g)}
.kpi-btn.gold.active .k-val{color:var(--warn)}

/* card grid */
.grid{display:grid;gap:16px}
@media(min-width:860px){.grid.two{grid-template-columns:1fr 1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px}
.card h3{font-size:15px;color:var(--ink);margin-bottom:4px}
.card .hint{font-size:12px;color:var(--muted);margin-bottom:14px}

/* horizontal bars */
.bars{display:flex;flex-direction:column;gap:11px}
.bar-row{display:grid;grid-template-columns:1fr;gap:4px}
.bar-row .bl{display:flex;justify-content:space-between;font-size:13px}
.bar-row .bl .name{color:var(--ink);font-weight:600}
.bar-row .bl .val{color:var(--muted);font-weight:700}
.bar-track{height:12px;background:#eef0ea;border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:var(--g);transition:width .5s ease}
.bar-fill.gold{background:var(--gold)}
.bar-fill.rose{background:var(--rose)}

/* funnel */
.funnel{display:flex;flex-direction:column;gap:0}
.fstep{padding:5px 0}
.fbar-wrap{display:flex;justify-content:flex-start}
.fbar{height:32px;background:linear-gradient(90deg,var(--g),#1c6a2a);border-radius:8px;min-width:4px;transition:width .5s ease}
.fl{font-size:13px;color:var(--muted);margin:5px 0 0 2px}
.fl .fc{font-weight:800;font-size:16px;color:var(--ink)}
.fl .fkeep{color:var(--g);font-weight:600}
.fdrop{text-align:left;font-size:11px;color:var(--rose);padding:5px 0 0 2px;font-weight:600}
.fkeep{font-size:11px;color:var(--muted);font-weight:700}
.toggle{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);cursor:pointer;user-select:none}

/* rings (donut) */
.rings{display:flex;gap:22px;flex-wrap:wrap;justify-content:space-around}
.ring{text-align:center}
.ring .rlabel{font-size:13px;color:var(--muted);font-weight:600;margin-top:8px;max-width:150px}

/* tables */
.tbl-tools{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.tbl-tools input{flex:1;min-width:180px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font:inherit;font-size:14px}
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;font-size:13.5px;white-space:nowrap}
thead th{text-align:left;background:#f0f2ec;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:11px 14px;border-bottom:1px solid var(--line);position:sticky;top:0}
tbody td{padding:11px 14px;border-bottom:1px solid #f0efe9}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#faf9f4}
td.num,th.num{text-align:right}
.pill{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}
.pill.sub{background:#eaf3ec;color:var(--g)}
.pill.up{background:#fff4e0;color:var(--warn)}
.pill.win{background:var(--g);color:#fff}
.right{text-align:right}
.foot{color:var(--muted);font-size:12px;padding:40px 0 50px;text-align:center}
.foot code{background:#e9e7df;padding:1px 6px;border-radius:5px}
.foot a{color:var(--g);font-weight:600}

/* ---------- global controls (date + funnel filter) ---------- */
.controls{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin:14px 0 6px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:10px 12px}
.controls .dates{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.dpill{border:1px solid var(--line);background:#f7f9f4;color:var(--muted);font:inherit;font-size:13px;font-weight:600;
  padding:7px 13px;border-radius:999px;cursor:pointer;transition:all .12s}
.dpill:hover{background:#eef2e9;color:var(--ink)}
.dpill.on{background:var(--g);border-color:var(--g);color:#fff}
.custom-range{display:inline-flex;gap:6px;align-items:center;margin-left:4px}
.custom-range input{border:1px solid var(--line);border-radius:8px;padding:6px 8px;font:inherit;font-size:13px}
.custom-range span{color:var(--muted)}
.ctl-right{display:flex;gap:10px;align-items:center}
.ctl-sel{border:1px solid var(--line);border-radius:9px;padding:8px 12px;font:inherit;font-size:14px;font-weight:600;color:var(--g);background:#f7f9f4;cursor:pointer}

/* table tools: rows-per-page + pager */
.rows-sel{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);font-weight:600;white-space:nowrap}
.rows-sel select{border:1px solid var(--line);border-radius:8px;padding:6px 8px;font:inherit;font-size:13px;cursor:pointer}
.tbl-count{margin-left:auto;font-size:12.5px}
.pager{display:flex;gap:12px;align-items:center;justify-content:center;padding:14px 0 2px;color:var(--muted);font-size:13px;font-weight:600}
.pager .pg{border:1px solid var(--line);background:var(--card);color:var(--g);font:inherit;font-size:13px;font-weight:700;padding:7px 14px;border-radius:8px;cursor:pointer}
.pager .pg:hover{background:#f0f4ee}
.pager .pg[disabled]{opacity:.4;cursor:default}

/* extra pills + selected row */
.pill.fnl{background:#eef2fb;color:#3a4a7a}
.pill.rep{background:#fce9d6;color:#9a5b1e}
tr.sel,tr.sel td{background:#eef6ea !important;box-shadow:inset 3px 0 0 var(--g)}
.back{color:var(--g);font-weight:700;text-decoration:none;font-size:14px;margin-right:6px}
.back:hover{text-decoration:underline}
.care{display:inline-block;width:12px;color:var(--muted)}

/* ---------- flow map ---------- */
.flowmap{display:flex;align-items:stretch;gap:0;overflow-x:auto;padding:6px 2px 12px}
.fnode{flex:0 0 auto;min-width:160px;max-width:200px;background:#f7f9f4;border:1px solid var(--line);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.fn-ico{font-size:22px;line-height:1}
.fn-label{font-weight:700;font-size:13.5px;color:var(--ink)}
.fn-count{font-size:13px;color:var(--g);font-weight:800}
.fn-count .muted{font-weight:500}
.flink{font-size:12px;color:var(--g);font-weight:700;text-decoration:none;margin-top:2px}
.flink:hover{text-decoration:underline}
.fvars{display:flex;flex-direction:column;gap:2px;margin-top:4px}
.fvars a{font-size:11.5px;color:var(--muted);text-decoration:none}
.fvars a:hover{color:var(--g);text-decoration:underline}
.foffers{display:flex;flex-direction:column;gap:2px;margin-top:4px;font-size:11px;color:var(--muted)}
.farrow{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 4px;min-width:54px}
.fa-line{height:2px;width:100%;background:linear-gradient(90deg,var(--g),#9cc7a4)}
.fa-line:after{content:"▶";color:#9cc7a4;font-size:10px;position:relative;left:calc(50% - 5px);top:-8px}
.fa-drop{font-size:11px;color:var(--rose);font-weight:700;margin-top:4px}

/* ---------- EPC drill ---------- */
.epc-drill{display:flex;flex-direction:column;gap:8px}
.epc-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13.5px}
.epc-head{cursor:pointer;background:#f7f9f4;border:1px solid var(--line);border-radius:10px;padding:11px 14px}
.epc-head:hover{background:#eef2e9}
.epc-metrics{display:flex;gap:18px;align-items:center;color:var(--muted);font-weight:600}
.epc-metrics b{color:var(--g)}
.epc-children{margin:4px 0 6px 22px;display:flex;flex-direction:column;gap:14px;padding:10px 0}
.epc-sub-h{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;margin-bottom:6px}
.epc-leaf{padding:8px 12px;border-bottom:1px solid #f0efe9}
.epc-leaf:last-child{border-bottom:0}

/* ---------- traffic split controls ---------- */
.split-rows{display:flex;flex-direction:column;gap:12px}
.split-row{display:grid;grid-template-columns:1fr 200px 48px;gap:14px;align-items:center}
.split-label{font-size:13.5px;font-weight:600;color:var(--ink)}
.split-row input[type=range]{width:100%;accent-color:var(--g)}
.split-val{font-weight:800;color:var(--g);text-align:right;font-size:14px}
.split-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;flex-wrap:wrap;gap:10px}
.btn-ghost{border:1px solid var(--line);background:#f7f9f4;color:var(--muted);font:inherit;font-size:13px;font-weight:600;padding:8px 14px;border-radius:8px;cursor:pointer}
.btn-ghost:hover{color:var(--ink)}
.btn-go{border:0;background:var(--g);color:#fff;font:inherit;font-size:13px;font-weight:700;padding:9px 18px;border-radius:8px;cursor:pointer}
.btn-go:hover{background:var(--g-dark)}
@media(max-width:560px){.split-row{grid-template-columns:1fr 110px 40px;gap:8px}.epc-metrics{gap:10px;font-size:12px}}

/* ---------- refresh button + last-updated ---------- */
.btn-refresh{border:1px solid var(--g);background:var(--g);color:#fff;font:inherit;font-size:13px;font-weight:700;padding:8px 14px;border-radius:9px;cursor:pointer;white-space:nowrap}
.btn-refresh:hover{background:var(--g-dark)}
.btn-refresh.spin{opacity:.6}
.btn-refresh.spin::before{content:"⟳ ";display:inline-block;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.updated{font-size:12px;color:var(--muted);white-space:nowrap}

/* ---------- time-series chart ---------- */
.chart-card{padding:16px 18px 12px;position:relative}
.chart-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.chart-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.chart-now{font-size:30px;font-weight:800;color:var(--g);line-height:1.1;margin-top:2px;display:flex;align-items:baseline;gap:10px}
.chart-now .up{font-size:14px;font-weight:700;color:var(--good)}
.chart-now .down{font-size:14px;font-weight:700;color:var(--rose)}
.chart-now .muted{font-size:13px;font-weight:600}
.chart-prev{text-align:right;font-size:12px;color:var(--muted);line-height:1.4}
.chart-prev b{font-size:18px;color:#9aa1ad;font-weight:800}
.ts-svg{width:100%;height:auto;display:block;margin-top:4px}
.chart-x{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--muted);margin-top:2px}
.chart-legend{display:inline-flex;align-items:center;gap:6px}
.chart-legend .lc{display:inline-block;width:14px;height:3px;border-radius:2px;margin-left:8px}
.chart-legend .lc.cur{background:var(--g)}
.chart-legend .lc.prev{background:#c4c9be}
/* chart axes + hover crosshair/tooltip */
.ax-y,.ax-x{fill:#9aa295;font-size:10px;font-weight:500}
.ts-cursor{stroke:var(--g);stroke-width:1;stroke-dasharray:3 3;opacity:0;pointer-events:none;transition:opacity .08s}
.ts-focus{fill:#fff;stroke:var(--g);stroke-width:2.5;opacity:0;pointer-events:none;transition:opacity .08s}
.ts-capture{cursor:crosshair}
.ts-tip{position:absolute;z-index:6;pointer-events:none;background:var(--g-dark);color:#fff;border-radius:9px;padding:7px 11px;font-size:12px;line-height:1.4;box-shadow:var(--shadow-lg);white-space:nowrap}
.ts-tip .tt-date{font-weight:700;margin-bottom:3px;font-size:11.5px;opacity:.95}
.ts-tip .tt-row{display:flex;align-items:center;gap:7px}
.ts-tip .tt-row b{font-weight:700}
.ts-tip .tt-row.prev{color:#bcc8b8;font-size:11.5px}
.ts-tip .lc{display:inline-block;width:12px;height:0;border-top:2px solid}
.ts-tip .lc.cur{border-color:#9fe6a6}
.ts-tip .lc.prev{border-color:#bcc8b8;border-top-style:dashed}

/* ---------- recent activity ---------- */
.act-list{display:flex;flex-direction:column;gap:2px;padding:8px 18px}
.act-row{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid #f0efe9}
.act-row:last-child{border-bottom:0}
.act-ico{width:34px;height:34px;border-radius:50%;background:#eef2ec;display:flex;align-items:center;justify-content:center;font-size:16px;flex:0 0 auto}
.act-name{font-size:14px;font-weight:700;color:var(--ink)}
.act-fn{font-size:11px;font-weight:600;color:#3a4a7a;background:#eef2fb;border-radius:999px;padding:1px 8px;margin-left:4px}
.act-what{font-size:12.5px;color:var(--muted)}
