/* ── CAMPAIGNS: stat cards, filter bar, column toggle, custom metrics, CSV bulk edit, demo banner ── */

/* ── Campaign action progress (Pause/Enable loading bar) ── */
.csb-progress-track{width:140px;height:6px;border-radius:3px;background:color-mix(in srgb,var(--accent) 15%,transparent);overflow:hidden;flex-shrink:0}
.csb-progress-bar{height:100%;width:40%;border-radius:3px;background:var(--accent);animation:csbShimmer 1.2s ease-in-out infinite}
@keyframes csbShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* ── CAMPAIGN STAT CARDS ── */
.cam-stat-grid{
  display:flex;align-items:stretch;gap:14px;
  margin-bottom:20px;
}

/* ── PAGE HEADER BADGE ── */
.cam-count-badge{
  display:inline-flex;align-items:center;justify-content:center;
  margin-left:8px;padding:2px 8px;border-radius:99px;
  font-size:12px;font-weight:600;
  background:var(--accent-bg);color:var(--accent2);
  border:1px solid var(--accent-border);
  vertical-align:middle;
}

/* ── EMPTY STATE ── */
.cam-empty-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 20px;gap:8px;
  position:sticky;left:0;width:100vw;max-width:100%;box-sizing:border-box;
}
.cam-empty-title{font-size:14px;font-weight:600;color:var(--text2)}
.cam-empty-sub{font-size:12px;color:var(--text3)}

/* ── PLATFORM CELL + STATUS DOT + ROW BORDERS ── */
.cam-platform-cell{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--text2)}
.cam-currency-badge{
  display:inline-block;font-size:10px;font-weight:600;color:var(--text2);
  background:color-mix(in srgb, var(--accent) 12%, transparent);
  border-radius:4px;padding:1px 5px;margin-left:6px;
  vertical-align:middle;letter-spacing:0.03em;
}
.cam-status-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ── ROW EXPANSION PANEL ── */
.campaign-row.expanded{background:color-mix(in srgb, var(--accent) 4%, transparent)}
.campaign-row.expanded:hover{background:color-mix(in srgb, var(--accent) 6%, transparent)}
.cam-detail-row td{background:var(--surface2)}
.cam-row-detail{padding:16px 20px 14px}
.cam-detail-grid{
  display:flex;gap:14px;align-items:stretch;
  margin-bottom:12px;flex-wrap:wrap;
}
.cam-detail-chart{
  display:flex;flex-direction:column;gap:4px;
}
.cam-detail-chart-label{
  font-size:9px;text-transform:uppercase;letter-spacing:0.08em;
  color:var(--text3);font-weight:500;
}
.cam-detail-metric{
  display:flex;flex-direction:column;gap:2px;
  padding:10px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;
  min-width:100px;
}
.cam-detail-metric-label{
  font-size:9px;text-transform:uppercase;letter-spacing:0.08em;
  color:var(--text3);font-weight:500;
}
.cam-detail-metric-value{
  font-family:var(--font-display);font-size:18px;font-weight:700;
  color:var(--text);letter-spacing:-0.02em;
}
.cam-detail-meta{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:11px;color:var(--text2);
}
.cam-detail-meta-item{display:inline-flex;align-items:center;gap:5px}

/* ── STICKY TOOLBAR (mirrors portfolio tab) ── */
.cam-sticky{
  position:sticky;top:56px;z-index:10;
  background:var(--header-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  margin-left:-32px;margin-right:-32px;
  padding:12px 32px 0;
  transition:border-color 0.15s;
  border-bottom:1px solid transparent;
}
.cam-sticky::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:1px;background:var(--header-shine);pointer-events:none;
}
.cam-sticky.is-stuck{border-bottom-color:var(--border)}
/* Extend glass zone upward behind the global header so content blurs
   continuously with no visible seam between the two glass layers. */
.cam-sticky.is-stuck::before{
  content:'';position:absolute;top:-56px;left:0;right:0;height:56px;
  background:var(--header-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  z-index:-1;pointer-events:none;
}

/* Horizontal scroll — header (hidden scrollbar) synced with table body */
.cam-header-scroll{overflow-x:auto;scrollbar-width:none}
.cam-header-scroll::-webkit-scrollbar{display:none}
.cam-scroll-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,0.08),0 1px 4px rgba(0,0,0,0.04)}

/* ── CAMPAIGN TABLE CHROME ── */
.cam-table-wrap{
  animation:camTableIn 0.35s ease 0.2s both;
}
@keyframes camTableIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
/* Header row lives inside the sticky wrapper — no separate thead */
.cam-header-row{
  margin-left:-32px;margin-right:-32px;
  padding:0 32px;
}
.cam-header-row table{border-collapse:collapse;table-layout:fixed;min-width:1060px;width:100%}
.cam-header-row thead{background:transparent;border-bottom:none}
.cam-header-row th{padding:10px 8px;text-align:center}
.cam-header-row th:nth-child(2){text-align:left}/* Campaign Name stays left */
#campaigns-table td{text-align:center}
#campaigns-table td[data-col="name"]{text-align:left}
.cam-header-row th.num,#campaigns-table td.num{text-align:center}
#campaigns-table td[data-col="platform"] svg{margin:0 auto}

/* Table body background */
#panel-campaigns tbody{
  background:var(--surface);
}
#panel-campaigns tbody tr:first-child td{border-top:none}
#panel-campaigns .campaign-row:nth-child(even){background:color-mix(in srgb, var(--surface2) 30%, transparent)}
#panel-campaigns .campaign-row:nth-child(even):hover{background:var(--surface2)}
#panel-campaigns .campaign-row.selected:nth-child(even){background:var(--accent-bg)}
#panel-campaigns .campaign-row{transition:background 0.12s}
#panel-campaigns{padding-bottom:100vh}

/* ── FROZEN FIRST COLUMN (checkbox + campaign name) ── */
/* Split-header: frozen header cells are rendered OUTSIDE the scroll container
   by CampaignFrozenHeader — they have no background and sit directly on the
   glass from .cam-sticky, identical to non-frozen header cells. */
.cam-header-wrap{position:relative}
.cam-header-frozen{
  position:absolute;left:0;top:0;bottom:0;z-index:2;
  display:flex;align-items:stretch;pointer-events:auto;
  width:calc(40px + var(--ccol-name, 220px));
  box-shadow:4px 0 8px -4px color-mix(in srgb, var(--text) 15%, transparent);
}
/* Clip the scroll container's left edge so scrolled header text never
   enters the frozen zone — the frozen header covers it transparently. */
.cam-header-wrap .cam-header-scroll{
  clip-path:inset(0 0 0 calc(40px + var(--ccol-name, 220px)));
}
.cam-frozen-cell{
  display:flex;align-items:center;position:relative;
  padding:10px 8px;box-sizing:border-box;
  font-size:10px;font-weight:500;color:var(--text3);
  letter-spacing:0.08em;text-transform:uppercase;
  white-space:nowrap;
}
.cam-frozen-cb{justify-content:center;width:40px;flex-shrink:0}
.cam-frozen-name{flex:1;cursor:pointer;text-align:left;white-space:nowrap}
.cam-frozen-name:hover{color:var(--text)}
/* Sort icon rules for frozen header (components.css scopes to th) */
.cam-frozen-name.sort-asc .sort-icon::after{content:'↑';color:var(--accent2);margin-left:4px;font-size:11px}
.cam-frozen-name.sort-desc .sort-icon::after{content:'↓';color:var(--accent2);margin-left:4px;font-size:11px}
.cam-frozen-name:not(.sort-asc):not(.sort-desc) .sort-icon::after{content:'↕';color:var(--text3);margin-left:4px;opacity:0.4;font-size:11px}
/* Body: checkbox cell */
#campaigns-table td.cb-cell{position:sticky;left:0;z-index:2;background:var(--surface)}
/* Body: name cell */
#campaigns-table td[data-col="name"]{position:sticky;left:40px;z-index:2;background:var(--surface)}
/* Even rows */
#panel-campaigns .campaign-row:nth-child(even) td.cb-cell,
#panel-campaigns .campaign-row:nth-child(even) td[data-col="name"]{
  background:color-mix(in srgb, var(--surface2) 30%, var(--surface));
}
/* Hover (all rows) */
#panel-campaigns .campaign-row:hover td.cb-cell,
#panel-campaigns .campaign-row:hover td[data-col="name"]{background:var(--surface2)}
/* Selected rows */
#panel-campaigns .campaign-row.selected td.cb-cell,
#panel-campaigns .campaign-row.selected td[data-col="name"]{background:var(--accent-bg)}
/* Expanded rows */
#panel-campaigns .campaign-row.expanded td.cb-cell,
#panel-campaigns .campaign-row.expanded td[data-col="name"]{
  background:color-mix(in srgb, var(--accent) 4%, var(--surface));
}
#panel-campaigns .campaign-row.expanded:hover td.cb-cell,
#panel-campaigns .campaign-row.expanded:hover td[data-col="name"]{
  background:color-mix(in srgb, var(--accent) 6%, var(--surface));
}
/* Body freeze divider shadow */
#campaigns-table td[data-col="name"]{
  box-shadow:4px 0 8px -4px color-mix(in srgb, var(--text) 15%, transparent);
}

/* ── CAMPAIGNS UNIFIED TOOLBAR ── */
#panel-campaigns .page-header{margin-bottom:14px}
.cam-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;margin-bottom:8px;flex-wrap:wrap;
}
.cam-toolbar-left{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1;min-width:0}
.cam-toolbar-right{display:flex;align-items:center;gap:4px;flex-shrink:0}
.cam-toolbar-sep{width:1px;height:18px;background:var(--border);margin:0 4px;flex-shrink:0}

/* ── QUICK SEARCH ── */
.cam-quick-search{
  width:200px;padding:7px 12px;
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  font-family:var(--font-ui);font-size:12px;color:var(--text);
  outline:none;transition:border-color 0.15s;
}
.cam-quick-search::placeholder{color:var(--text3)}
.cam-quick-search:focus{border-color:var(--accent)}
.port-quick-search{width:170px;font-size:11px;padding:5px 10px}
.port-filter-pills{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.port-filter-pill{
  display:inline-flex;align-items:center;gap:3px;
  padding:3px 6px 3px 8px;border-radius:99px;font-size:11px;font-weight:500;
  background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent2);
  animation:chipIn 0.15s ease;
}
.port-filter-pill-x{
  background:none;border:none;cursor:pointer;font-size:13px;line-height:1;
  color:var(--accent2);opacity:0.6;padding:0 2px;font-family:inherit;
  transition:opacity 0.1s;
}
.port-filter-pill-x:hover{opacity:1}
/* ── PORTFOLIO FILTER DROPDOWN (compact sizing for toolbar) ── */
#port-filter-add-wrap .filter-type-select,
#port-filter-add-wrap .filter-value-select{padding:5px 10px}
#port-filter-add-wrap .btn-add-filter-confirm{padding:4px 8px}

/* ── FILTER BAR (now inside cam-toolbar-left) ── */
.filter-add-wrap{display:flex;align-items:center;gap:6px;position:relative}

/* ── FILTER BUTTON (matches header-control style) ── */
.btn-filter{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 10px;border-radius:10px;
  font-family:var(--font-ui);font-size:12px;font-weight:500;
  cursor:pointer;border:none;
  background:transparent;color:var(--text2);
  transition:background 0.15s,color 0.15s;white-space:nowrap;letter-spacing:0.01em;
}
.btn-filter:hover{background:color-mix(in srgb,var(--accent) 6%,var(--surface2));color:var(--text)}
.btn-filter.open{color:var(--accent2);background:color-mix(in srgb,var(--accent) 11%,transparent)}
/* Active type shown as a tinted label chip */
.btn-filter-label{
  display:inline-flex;align-items:center;gap:4px;
  color:var(--accent2);
}

/* ── FILTER TYPE MENU (portal popover) ── */
@keyframes filterMenuIn{from{opacity:0;transform:translateY(-4px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.filter-type-menu{
  position:fixed;z-index:400;
  background:var(--modal-bg);border:1px solid var(--border2);
  border-radius:12px;padding:5px;
  min-width:160px;
  box-shadow:var(--shadow-xl);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  animation:filterMenuIn 0.14s cubic-bezier(0.22,1,0.36,1);
}
.filter-type-menu::before{
  content:'';position:absolute;top:0;left:12px;right:12px;height:1px;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 35%,transparent),transparent);
  pointer-events:none;
}
.filter-type-menu-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:8px;
  font-size:12px;color:var(--text2);cursor:pointer;
  transition:background 0.1s,color 0.1s;
  border:none;background:none;width:100%;text-align:left;
  font-family:var(--font-ui);
}
.filter-type-menu-item:hover{background:color-mix(in srgb,var(--accent) 8%,var(--surface2));color:var(--text)}
.filter-type-menu-item svg{flex-shrink:0;color:var(--text3)}
.filter-type-menu-item:hover svg{color:var(--accent2)}

/* Legacy native-select kept for backward compat fallback */
.filter-type-select{
  padding:7px 10px;background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;font-size:11px;color:var(--text2);
  outline:none;cursor:pointer;transition:border-color 0.15s;
}
.filter-type-select:focus{border-color:var(--accent)}
.filter-value-wrap{
  display:flex;align-items:center;gap:6px;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;overflow:hidden;transition:border-color 0.15s;
}
.filter-value-wrap:focus-within{border-color:var(--accent)}
.filter-value-input{
  padding:7px 10px;background:transparent;border:none;
  font-size:11px;color:var(--text);
  outline:none;width:160px;
}
.filter-value-select{
  padding:7px 10px;background:transparent;border:none;
  font-size:11px;color:var(--text);
  outline:none;cursor:pointer;width:160px;
}
.fsel-trigger.filter-value-fsel{
  padding:6px 10px;font-size:11px;min-width:140px;
}
.btn-add-filter-confirm{
  padding:6px 10px;background:var(--accent);color:white;
  border:none;border-radius:6px;
  font-size:11px;cursor:pointer;transition:background 0.15s;white-space:nowrap;
}
.btn-add-filter-confirm:hover{background:var(--accent2)}
.filter-chips{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.filter-chip{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--accent-bg);border:1px solid var(--accent-border);
  color:var(--accent2);padding:4px 10px;border-radius:20px;
  font-size:11px;animation:chipIn 0.18s cubic-bezier(0.22,1,0.36,1);
}
@keyframes chipIn{from{opacity:0;transform:scale(0.85)}to{opacity:1;transform:scale(1)}}
.filter-chip-label{color:var(--text3);margin-right:2px}
.filter-chip-remove{
  background:none;border:none;color:var(--text3);cursor:pointer;
  font-size:14px;line-height:1;padding:0 2px;border-radius:3px;
  transition:color 0.12s;
}
.filter-chip-remove:hover{color:var(--red)}
.filter-results-count{font-size:11px;color:var(--text3);margin-left:4px}

/* ── RESULTS COUNT ── */
.cam-results-count{
  font-size:11px;color:var(--text3);
  white-space:nowrap;flex-shrink:0;
  display:inline-flex;align-items:center;gap:3px;
}
.cam-results-count strong{color:var(--text2);font-weight:600}

/* ── TOTALS ROW ── */
#campaigns-table tr.cam-totals-row td{
  font-weight:700;font-size:12px;
  background:color-mix(in srgb,var(--accent) 5%,var(--surface));
  border-bottom:2px solid var(--accent-border);
  border-top:none;
}
#campaigns-table tr.cam-totals-row td.cb-cell{
  background:color-mix(in srgb,var(--accent) 5%,var(--surface));
  position:sticky;left:0;z-index:2;
}
#campaigns-table tr.cam-totals-row td[data-col="name"]{
  background:color-mix(in srgb,var(--accent) 5%,var(--surface));
  position:sticky;left:40px;z-index:2;
  color:var(--text2);font-size:11px;text-transform:uppercase;letter-spacing:0.06em;
}
.cam-totals-label{
  display:flex;align-items:center;gap:6px;
}
.cam-totals-n{
  font-size:9.5px;font-weight:500;color:var(--text3);letter-spacing:0;text-transform:none;
  background:var(--surface3);border-radius:6px;padding:1px 6px;
}

/* ── SPARKLINE TOOLTIP ── */
.cam-spark-tip{
  position:fixed;z-index:9999;pointer-events:none;
  background:var(--surface);border:1px solid var(--border);
  border-radius:8px;box-shadow:var(--shadow-lg);
  padding:7px 10px;font-size:11px;white-space:nowrap;
}
.cam-spark-tip-title{
  font-weight:600;color:var(--text);
  margin-bottom:5px;padding-bottom:4px;border-bottom:1px solid var(--border);
}
.cam-spark-tip-row{
  display:flex;justify-content:space-between;gap:16px;margin-top:3px;
}
.cam-spark-tip-label{color:var(--text3)}
.cam-spark-tip-val{font-weight:500;color:var(--text);font-variant-numeric:tabular-nums}

/* ── CLICK-TO-FILTER CELLS ── */
.cam-cell-filterable{cursor:pointer;transition:opacity 0.1s}
.cam-cell-filterable:hover{opacity:0.75}
.cam-filter-from-cell{
  display:inline-flex;align-items:center;gap:4px;
}

/* ── COLUMN TOGGLE + METRICS BUTTON ── */
.col-toggle-wrap{position:relative}
.btn-columns{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:10px;
  font-family:var(--font-ui);font-size:12px;font-weight:500;
  cursor:pointer;border:none;
  background:transparent;color:var(--text2);
  transition:background 0.15s,color 0.15s;white-space:nowrap;letter-spacing:0.01em;
}
/* Match header-control accent hover (date picker, appearance, etc.) */
.btn-columns:hover{background:color-mix(in srgb,var(--accent) 6%,var(--surface2));color:var(--text)}
.btn-columns.open{color:var(--accent2);background:color-mix(in srgb,var(--accent) 11%,transparent)}
/* ── TWO-COLUMN METRIC PICKER ── */
@keyframes popIn{from{opacity:0;transform:translateY(-6px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.col-picker{
  background:var(--modal-bg);border:1px solid var(--border2);
  border-radius:14px;padding:0;
  width:560px;max-width:calc(100vw - 32px);z-index:300;
  box-shadow:var(--shadow-xl);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  animation:popIn 0.15s cubic-bezier(0.22,1,0.36,1);
}
.col-picker::before{
  content:'';
  position:absolute;top:0;left:14px;right:14px;height:1px;z-index:1;
  background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 35%, transparent), transparent);
  pointer-events:none;
}
.col-picker-header{
  padding:12px 16px 10px;
  border-bottom:1px solid var(--border);
}
.col-picker-title{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text3);
}
.col-picker-body{
  display:flex;gap:0;
  min-height:min(320px,var(--picker-body-max,480px));max-height:var(--picker-body-max,480px);
}
.col-picker-col{
  flex:1;display:flex;flex-direction:column;
  min-width:0;padding:10px 12px;
}
.col-picker-divider{
  width:1px;background:var(--border);
  flex-shrink:0;margin:10px 0;
}
.col-picker-search-wrap{
  position:relative;margin-bottom:8px;
}
.col-picker-search-icon{
  position:absolute;left:9px;top:50%;transform:translateY(-50%);
  color:var(--text3);pointer-events:none;
}
.col-picker-search{
  width:100%;padding:6px 8px 6px 28px;
  border:1px solid var(--border2);border-radius:8px;
  background:var(--surface2);color:var(--text);
  font-size:11.5px;font-family:inherit;
  transition:border-color 0.15s;box-sizing:border-box;
}
.col-picker-search:focus{outline:none;border-color:var(--accent)}
.col-picker-search::placeholder{color:var(--text3)}
.col-picker-col-header{
  font-size:9.5px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--text3);
  margin-bottom:6px;display:flex;align-items:center;gap:6px;
}
.col-picker-count{
  background:var(--surface3);border-radius:10px;
  padding:1px 6px;font-size:9px;color:var(--text2);
  font-weight:500;text-transform:none;letter-spacing:0;
}
.col-picker-list{
  flex:1;overflow-y:auto;
  scrollbar-width:none;
}
.col-picker-list:hover{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.col-picker-empty{
  font-size:11px;color:var(--text3);
  padding:12px 6px;text-align:center;
  font-style:italic;
}
.col-picker-item{
  display:flex;align-items:center;gap:8px;
  padding:6px 6px;border-radius:7px;cursor:default;
  transition:background 0.1s;user-select:none;
  min-height:32px;
}
.col-picker-item--available{
  cursor:pointer;
}
.col-picker-item--available:hover{background:var(--surface2)}
.col-picker-item:not(.col-picker-item--locked):not(.col-picker-item--available):hover{background:var(--surface2)}
.col-picker-item--locked{opacity:0.55;cursor:default}
.col-picker-item--dragging{opacity:0.35}
.col-picker-label{
  flex:1;font-size:12px;color:var(--text2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.col-picker-item--available:hover .col-picker-label,
.col-picker-item:not(.col-picker-item--locked):not(.col-picker-item--available):hover .col-picker-label{color:var(--text)}
.col-picker-drag-handle{
  flex-shrink:0;cursor:grab;padding:2px;
  border-radius:4px;display:flex;align-items:center;
  color:var(--text3);transition:color 0.1s;
}
.col-picker-drag-handle:hover{color:var(--text2)}
.col-picker-drag-handle:active{cursor:grabbing}
.col-picker-drag-icon{display:block}
.col-picker-lock-icon{
  flex-shrink:0;color:var(--text3);opacity:0.7;
}
.col-picker-placeholder{
  border:1.5px dashed var(--border2);border-radius:7px;
  margin:2px 0;background:color-mix(in srgb,var(--accent) 5%,transparent);
  box-sizing:border-box;
}
.col-picker-ghost{
  cursor:grabbing;
  transition:top 0.18s cubic-bezier(0.22,1,0.36,1), opacity 0.18s;
}

/* Category badges */
.col-picker-badge{
  flex-shrink:0;font-size:9px;font-weight:500;
  border-radius:4px;padding:2px 6px;white-space:nowrap;
  letter-spacing:0.03em;
}
.col-picker-badge--property{
  background:var(--surface3);color:var(--text3);
  border:1px solid var(--border);
}
.col-picker-badge--performance{
  background:color-mix(in srgb,var(--green) 14%,transparent);
  color:var(--green);border:1px solid color-mix(in srgb,var(--green) 25%,transparent);
}
.col-picker-badge--delivery{
  background:var(--accent-bg);color:var(--accent2);
  border:1px solid var(--accent-border);
}
.col-picker-badge--custom{
  background:color-mix(in srgb,var(--amber) 14%,transparent);
  color:var(--amber);border:1px solid color-mix(in srgb,var(--amber) 30%,transparent);
}

.col-picker-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px 12px;
  border-top:1px solid var(--border);
  gap:12px;
}
.col-picker-hint{
  font-size:10px;color:var(--text3);white-space:nowrap;
}

/* ── CUSTOM METRICS BUILDER ── */
.cm-builder{
  width:680px;background:var(--modal-bg);
  border:1px solid var(--border2);border-radius:14px;
  box-shadow:var(--shadow-xl);z-index:300;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  animation:popIn 0.18s cubic-bezier(0.34,1.18,0.64,1);
}
.cm-builder::before{
  content:'';
  position:absolute;top:0;left:14px;right:14px;height:1px;z-index:1;
  background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 35%, transparent), transparent);
  pointer-events:none;
}
.cm-builder-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px 10px;border-bottom:1px solid var(--border);
}
.cm-builder-close{
  background:none;border:none;color:var(--text3);cursor:pointer;
  padding:4px;border-radius:5px;display:flex;align-items:center;
  transition:color 0.1s,background 0.1s;
}
.cm-builder-close:hover{color:var(--text);background:var(--surface2)}
.cm-builder-body{display:flex;min-height:min(280px,var(--cm-body-max,560px));max-height:var(--cm-body-max,560px)}

/* Left list */
.cm-builder-list{
  width:210px;flex-shrink:0;display:flex;flex-direction:column;
  border-right:1px solid var(--border);overflow:hidden;
}
.cm-list-new{
  display:flex;align-items:center;gap:6px;
  margin:10px 10px 6px;padding:6px 10px;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;font-size:12px;color:var(--text2);
  cursor:pointer;transition:background 0.1s,border-color 0.15s,color 0.1s;
  white-space:nowrap;
}
.cm-list-new:hover{background:var(--surface3);color:var(--text)}
.cm-list-new--active{border-color:var(--accent);color:var(--accent2);background:var(--accent-bg)}
.cm-list-items{
  flex:1;overflow-y:auto;padding:4px 8px 8px;
  scrollbar-width:none;
}
.cm-list-items:hover{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.cm-list-empty{font-size:11px;color:var(--text3);padding:12px 8px;font-style:italic;text-align:center}
.cm-list-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 8px;border-radius:8px;cursor:pointer;
  border:1px solid transparent;
  transition:background 0.1s,border-color 0.1s;
}
.cm-list-item:hover{background:var(--surface2)}
.cm-list-item--selected{background:var(--accent-bg);border-color:var(--accent-border)}
.cm-vis-dot{
  width:8px;height:8px;border-radius:50%;
  border:1.5px solid var(--border2);background:transparent;
  flex-shrink:0;padding:0;cursor:pointer;
  transition:background 0.15s,border-color 0.15s;
}
.cm-vis-dot--on{background:var(--green);border-color:var(--green)}
.cm-list-item-content{flex:1;min-width:0}
.cm-list-item-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cm-list-item-formula{font-size:10px;color:var(--text3);font-family:var(--font-mono);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Editor panel */
.cm-builder-divider{width:1px;background:var(--border);flex-shrink:0}
.cm-builder-editor{
  flex:1;display:flex;flex-direction:column;
  padding:14px 16px 12px;overflow-y:auto;gap:14px;
  scrollbar-width:none;min-width:0;
}
.cm-builder-editor:hover{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.cm-editor-none{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  color:var(--text3);font-size:12px;text-align:center;gap:6px;
  opacity:0.6;
}
.cm-editor-field{display:flex;flex-direction:column;gap:0}
.cm-editor-label{
  font-size:9.5px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text3);display:block;margin-bottom:6px;
}
.cm-format-currency-hint{font-weight:400;text-transform:none;letter-spacing:0}
.cm-editor-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cm-editor-label-row .cm-editor-label{margin-bottom:0}
.cm-editor-input{
  width:100%;padding:7px 10px;box-sizing:border-box;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;font-size:12px;color:var(--text);
  outline:none;transition:border-color 0.15s;
}
.cm-editor-input:focus{border-color:var(--accent)}
.cm-editor-input::placeholder{color:var(--text3)}

/* Formula pills */
.cm-formula-pills{
  display:flex;flex-wrap:wrap;gap:5px;align-items:center;
  min-height:38px;padding:7px 10px;
  background:var(--surface2);border:1px solid var(--border2);border-radius:8px;
}
.cm-formula-empty{font-size:11px;color:var(--text3);font-style:italic}
.cm-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:5px;
  font-size:11px;font-weight:500;white-space:nowrap;line-height:1.4;
}
.cm-pill--metric{
  background:var(--accent-bg);color:var(--accent2);
  border:1px solid var(--accent-border);
}
.cm-pill--op{
  background:var(--surface3);color:var(--text2);
  border:1px solid var(--border2);
  cursor:pointer;font-family:var(--font-mono);font-size:13px;
  padding:2px 7px;transition:background 0.1s,color 0.1s;
}
.cm-pill--op:hover{background:color-mix(in srgb,var(--accent) 8%,var(--surface3));color:var(--text)}
.cm-pill-op-hint{font-size:9px;opacity:0.5;margin-left:1px;font-family:inherit}
.cm-pill--num{
  background:color-mix(in srgb,var(--amber) 12%,transparent);
  color:var(--amber);
  border:1px solid color-mix(in srgb,var(--amber) 28%,transparent);
  cursor:pointer;font-family:var(--font-mono);
  transition:background 0.1s;
}
.cm-pill--num:hover{background:color-mix(in srgb,var(--amber) 20%,transparent)}
.cm-pill--num-edit{cursor:default;padding:2px 6px}
.cm-pill--paren{
  background:var(--surface3);color:var(--text3);
  border:1px solid var(--border2);font-family:var(--font-mono);font-size:13px;
}
.cm-pill-x{
  background:none;border:none;color:currentColor;opacity:0.45;
  cursor:pointer;font-size:11px;padding:0;line-height:1;margin-left:1px;
  transition:opacity 0.1s;
}
.cm-pill-x:hover{opacity:1}
.cm-num-inline{
  width:56px;background:transparent;border:none;outline:none;
  font-family:var(--font-mono);font-size:11px;color:var(--amber);
}

/* Add-token section */
.cm-metric-search-wrap{
  position:relative;margin-bottom:4px;
}
.cm-metric-search-icon{
  position:absolute;left:9px;top:50%;transform:translateY(-50%);
  color:var(--text3);pointer-events:none;
}
.cm-metric-search{
  width:100%;padding:6px 8px 6px 28px;box-sizing:border-box;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;font-size:11px;color:var(--text);
  outline:none;transition:border-color 0.15s;
}
.cm-metric-search:focus{border-color:var(--accent)}
.cm-metric-search::placeholder{color:var(--text3)}
.cm-metric-list{
  max-height:120px;overflow-y:auto;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;margin-bottom:6px;
  scrollbar-width:none;
}
.cm-metric-list:hover{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.cm-metric-list-item{
  display:block;width:100%;text-align:left;
  padding:5px 10px;font-size:11px;color:var(--text2);
  background:none;border:none;cursor:pointer;
  transition:background 0.08s,color 0.08s;
  border-radius:0;
}
.cm-metric-list-item:first-child{border-radius:8px 8px 0 0}
.cm-metric-list-item:last-child{border-radius:0 0 8px 8px}
.cm-metric-list-item:only-child{border-radius:8px}
.cm-metric-list-item:hover{background:var(--accent-bg);color:var(--accent2)}
.cm-metric-list-empty{font-size:11px;color:var(--text3);padding:8px 10px;font-style:italic}
.cm-add-ops{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.cm-add-chip{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:5px;font-size:11px;
  border:1px solid var(--border2);background:var(--surface2);
  color:var(--text2);cursor:pointer;
  transition:background 0.1s,border-color 0.1s,color 0.1s;
}
.cm-add-chip:hover{background:var(--surface3);color:var(--text)}
.cm-add-chip--op{font-family:var(--font-mono);font-size:14px;padding:2px 8px;font-weight:600}
.cm-add-chip--paren{font-family:var(--font-mono);font-size:13px;padding:2px 7px;color:var(--text3)}
.cm-add-chip--num{gap:5px}
.cm-add-sep{width:1px;height:18px;background:var(--border);margin:0 2px;flex-shrink:0}
.cm-num-add-wrap{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--surface2);border:1px solid var(--accent);
  border-radius:6px;padding:2px 4px 2px 8px;
}
.cm-num-add-input{
  width:72px;background:transparent;border:none;outline:none;
  font-size:11px;color:var(--text);font-family:var(--font-mono);
}
.cm-num-add-confirm{
  padding:2px 8px;font-size:11px;
  background:var(--accent-bg);color:var(--accent2);
  border:none;border-radius:4px;cursor:pointer;
  transition:background 0.1s;
}
.cm-num-add-confirm:hover{background:color-mix(in srgb,var(--accent) 18%,transparent)}

/* Format segmented control */
.cm-format-seg{
  display:flex;background:var(--surface2);
  border:1px solid var(--border2);border-radius:8px;
  padding:2px;width:fit-content;
}
.cm-format-btn{
  padding:4px 11px;border-radius:6px;font-size:11px;
  color:var(--text2);background:none;border:none;cursor:pointer;
  transition:background 0.1s,color 0.1s;white-space:nowrap;
}
.cm-format-btn:hover{color:var(--text)}
.cm-format-btn--active{
  background:var(--surface);color:var(--text);
  box-shadow:0 1px 3px rgba(0,0,0,0.1);
}

/* Preview bar */
.cm-preview{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;background:var(--surface2);
  border:1px solid var(--border);border-radius:8px;
}
.cm-preview-label{
  font-size:9.5px;color:var(--text3);text-transform:uppercase;
  letter-spacing:0.07em;font-weight:600;white-space:nowrap;
}
.cm-preview-val{font-size:14px;font-weight:600;color:var(--text);font-family:var(--font-mono)}
.cm-preview-null{color:var(--text3);font-size:12px}
.cm-preview-from{font-size:10px;color:var(--text3);margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}

/* Actions row */
.cm-editor-actions{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:2px}
.cm-actions-spacer{flex:1}
.cm-delete-btn{color:var(--red) !important}
.cm-clear-btn{
  font-size:10px;color:var(--text3);background:none;border:none;cursor:pointer;padding:0;
  transition:color 0.1s;
}
.cm-clear-btn:hover{color:var(--red)}

/* ── CSV BULK EDIT ── */
.csv-preview-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:12px}
.csv-preview-table th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:0.06em;color:var(--text3);padding:4px 8px;border-bottom:1px solid var(--border)}
.csv-preview-table td{padding:7px 8px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle}
.csv-change{color:var(--accent2);font-weight:500}
.csv-unchanged{color:var(--text3);font-style:italic}
.csv-error-box{background:var(--red-bg);border:1px solid rgba(248,113,113,0.3);border-radius:8px;padding:10px 12px;margin-bottom:12px;font-size:11px;color:var(--red);line-height:1.7}
.csv-preview-scroll{max-height:320px;overflow-y:auto}
.csv-goal-select{background:var(--bg2);border:1px solid var(--border);border-radius:4px;color:var(--accent2);font-size:11px;padding:2px 6px;cursor:pointer;font-family:inherit;font-weight:500;max-width:180px}
.csv-goal-select:focus{outline:1px solid var(--accent);border-color:var(--accent)}
.csv-invalid-note{font-size:10px;color:var(--text3);font-style:italic}

/* ── DEMO BANNER ── */
#demo-banner,#demo-banner-perf,.demo-banner{display:none;align-items:center;gap:10px;margin:0 0 14px;padding:10px 14px;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:8px;font-size:12px;color:var(--text2)}
#demo-banner.visible,#demo-banner-perf.visible,.demo-banner.visible{display:flex}
#demo-banner strong,#demo-banner-perf strong,.demo-banner strong{color:var(--text);font-weight:600}

/* ── COLUMN RESIZE HANDLES ── */
.cam-resize-handle{
  position:absolute;right:-4px;top:0;bottom:0;
  width:8px;cursor:col-resize;z-index:2;
  user-select:none;-webkit-user-select:none;
}
.cam-resize-handle::after{
  content:'';position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:2px;height:20px;border-radius:1px;
  background:transparent;
  transition:background 0.12s;
  pointer-events:none;
}
.cam-resize-handle:hover::after,
.cam-resize-handle.dragging::after{
  background:var(--accent-border);
}
