/* ── PORTFOLIOS: portfolio cards, inner tabs, breakdown, insights, optimise modal ── */

/* ── GRID COLUMN TOKENS ──────────────────────────────────────────────────────
   Change a token here and every grid that uses it updates automatically.
   S1 name:      chev | name           — user-resizable via drag on first header divider
   S2 attributes: div | group | platforms — expands with 1fr
   S3 budget:    div | budget | pacing  — expands with 1fr
   S4 metrics:   div | rev | cost | roas — expands with 1fr
   S5 actions:   div | actions          — fixed
   Each section separated by a visible divider track.
   Grids have a min-width floor; .portfolio-table-wrap scrolls when viewport < floor.
*/
:root {
  --pcol-name:      220px; /* JS sets this on drag; persists for session, resets on browser refresh */
  --pcol-div:       16px;
  --pcol-status:    minmax(72px,1fr);
  --pcol-group:     minmax(64px,1fr);
  --pcol-platforms: minmax(48px,1fr);
  --pcol-budget:    minmax(115px,1fr);
  --pcol-pacing:    minmax(155px,1fr);
  --pcol-metric:    minmax(88px,1fr);
  --pcol-actions:  170px;
}
:root {
  --pgrid:
    20px var(--pcol-name)
    var(--pcol-div) var(--pcol-status) var(--pcol-group) var(--pcol-platforms)
    var(--pcol-div) var(--pcol-budget) var(--pcol-pacing)
    var(--pcol-div) var(--pcol-metric) var(--pcol-metric) var(--pcol-metric)
    var(--pcol-div) var(--pcol-actions);
  --pgrid-select:
    50px var(--pcol-name)
    var(--pcol-div) var(--pcol-status) var(--pcol-group) var(--pcol-platforms)
    var(--pcol-div) var(--pcol-budget) var(--pcol-pacing)
    var(--pcol-div) var(--pcol-metric) var(--pcol-metric) var(--pcol-metric)
    var(--pcol-div) var(--pcol-actions);
}

/* ── NAME COLUMN RESIZE HANDLE — styles defined after .pcard-vdivider below ── */

/* Three-zone scroll layout — window scrolls, Zone 2 sticks under fixed header */
#panel-portfolios{ padding-bottom:100vh }
.portfolios-sticky{
  position:sticky;top:56px;z-index:10;
  background:var(--bg);
  /* Extend background into main's padding so card shadows don't bleed through */
  margin-left:-32px;margin-right:-32px;
  padding-left:32px;padding-right:32px;
  padding-top:12px;
  transition:border-color 0.15s;
  border-bottom:1px solid transparent;
}
.portfolios-sticky.is-stuck{
  border-bottom-color:var(--border);
}
#portfolios-sticky-sentinel{ height:1px;pointer-events:none }
.portfolios-cards{ padding-top:8px;overflow-anchor:none }

/* ── SECTION HEADER TOOLBAR ── */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-header-left{display:flex;align-items:center;gap:10px}
.section-header-right{display:flex;align-items:center;gap:6px}
.section-title{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-0.02em;color:var(--text)}
/* More dropdown */
.more-dropdown{position:relative}
.more-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;box-shadow:var(--shadow-lg);
  padding:4px;min-width:160px;z-index:100;display:none;
}
.more-menu.open{display:block}
.more-menu-item{
  display:flex;width:100%;align-items:center;gap:8px;
  padding:8px 12px;border-radius:7px;
  font-family:var(--font-ui);font-size:12px;font-weight:500;
  background:none;border:none;cursor:pointer;
  color:var(--text2);transition:background 0.12s,color 0.12s;text-align:left;
}
.more-menu-item:hover{background:var(--surface2);color:var(--text)}
.more-menu-item.btn-optimise{background:var(--accent-grad);color:white;box-shadow:0 1px 4px var(--accent-glow)}
.more-menu-item.btn-optimise:hover{background:var(--accent-grad);color:white;box-shadow:0 4px 18px var(--accent-glow)}

/* ── TABLE WRAPPER ── */
.portfolios-grid{display:flex;flex-direction:column}
.portfolio-table-wrap{overflow-x:auto}
/* Clip the sticky header — no scrollbar of its own, JS syncs scrollLeft from card area */
.portfolio-header-scroll{overflow:hidden}

/* ── SHARED COLUMN HEADER ── */
.portfolio-table-header{
  display:grid;
  grid-template-columns:var(--pgrid);
  align-items:center;padding:0 16px;height:36px;
  background:transparent;
  min-width:1060px;
  transition:grid-template-columns 0.22s cubic-bezier(0.22,1,0.36,1);
}
.portfolio-th{
  font-size:10px;font-weight:600;letter-spacing:0.07em;
  text-transform:uppercase;color:var(--text3);
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
}
.portfolio-th-r{text-align:right}
.portfolio-th-c{text-align:center}
.pth-portfolio-wrap{display:flex;align-items:center;width:100%;overflow:hidden}
.pth-sortable{cursor:pointer;user-select:none;transition:color 0.12s}
.pth-sortable:hover{color:var(--text2)}
.pth-active{color:var(--text2)}
.pth-icon{margin-left:4px;font-size:11px;opacity:0.4}
.pth-active .pth-icon{color:var(--accent2);opacity:1}

/* ── TOTALS ROW ── */
/* ── TOTALS CARD — same shape as portfolio card but inert, lives in sticky zone ── */
.pcard-totals{ margin-bottom:0;position:relative;overflow:hidden }
.portfolio-card.pcard-totals{ border-bottom:none }
.pcard-totals::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 60%,#818cf8));
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
}
.pcard-totals:hover{ box-shadow:var(--shadow); border-color:var(--border) }
.pcard-totals:hover .portfolio-card-header{ background:transparent }
.pcard-totals .portfolio-card-header{ cursor:default }
.pcard-totals:hover .portfolio-name{ color:var(--text3) }
.pcard-totals:hover .portfolio-campaign-count{ color:var(--text2) }
.pcard-totals:hover .portfolio-card-header .pcard-vdivider{ background:var(--border) }
.pcard-totals:hover .portfolio-card-header .pcell{ color:inherit }
.pcard-totals .portfolio-name{ font-size:11px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--text3) }
.pcard-totals .pcell{ font-weight:600 }

/* ── PORTFOLIO CARD (floating panel) ── */
.portfolio-card{
  background:var(--surface);
  border:2px solid var(--border2);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  margin-bottom:8px;
  overflow:hidden;
  position:relative;
  min-width:1060px;
  opacity:0;
  animation:card-in 0.45s cubic-bezier(0.22,1,0.36,1) forwards;
  transition:box-shadow 0.2s,border-color 0.2s;
}
/* animation-delay is now set inline by renderPortfolioCard(p, idx) in portfolios.js */
.portfolio-card:hover{
  box-shadow:var(--shadow-lg);
  border-color:var(--border2);
}
.portfolio-card:hover .portfolio-card-header{background:rgba(0,0,0,0.01)}
.dark .portfolio-card:hover .portfolio-card-header{background:rgba(255,255,255,0.015)}
.portfolio-card:hover .portfolio-name{color:var(--accent2)}
.portfolio-card:hover .portfolio-campaign-count{color:var(--accent2)}

/* ── CARD HEADER ROW ── */
.portfolio-card-header{
  display:grid;
  grid-template-columns:var(--pgrid);
  align-items:center;padding:0 16px;height:52px;
  position:relative;cursor:pointer;
  min-width:1060px;
  transition:background 0.15s, grid-template-columns 0.22s cubic-bezier(0.22,1,0.36,1);user-select:none;
}
.portfolio-card.expanded .portfolio-card-header{
  border-bottom:1px solid var(--border);
  cursor:default;
}


/* Chevron + checkbox cell */
.pcard-col-chev{
  display:flex;align-items:center;justify-content:flex-start;padding-left:2px;
}
/* Checkbox: zero-width + invisible by default — animatable unlike display:none */
.pcard-col-chev .pcard-checkbox-wrap{
  display:flex;align-items:center;position:static;flex-shrink:0;
  width:0;overflow:hidden;opacity:0;pointer-events:none;
  transition:width 0.22s cubic-bezier(0.22,1,0.36,1), opacity 0.18s ease;
}
/* Input sizing always present so it's correct during the expand transition */
.pcard-col-chev .pcard-checkbox-wrap input{
  cursor:pointer;accent-color:var(--accent);width:13px;height:13px;flex-shrink:0;margin:0;
}
/* Expanded cards never show checkbox */
.portfolio-card.expanded .pcard-checkbox-wrap{ display:none !important }

/* ── SELECT MODE ── */
/* Widen first column to fit checkbox + chevron side by side */
.select-mode .portfolio-card-header,
.select-mode .portfolio-table-header{
  grid-template-columns:var(--pgrid-select);
}
/* Checkbox slides in; column expansion pushes chevron right */
.select-mode .pcard-col-chev{
  justify-content:flex-start;gap:5px;padding-left:4px;
}
.select-mode .pcard-col-chev .pcard-checkbox-wrap{
  width:18px;opacity:1;pointer-events:auto;
}
/* Hovering a card row in select mode hints it's clickable */
.select-mode .portfolio-card:not(.expanded) .portfolio-card-header:hover{
  background:var(--surface-hover);
}
/* Header checkbox cell — mirrors .pcard-col-chev structure */
.pth-chev-cell{display:flex;align-items:center;justify-content:flex-start;padding-left:2px}
.pth-checkbox-wrap{
  display:flex;align-items:center;flex-shrink:0;
  width:0;overflow:hidden;opacity:0;pointer-events:none;
  transition:width 0.22s cubic-bezier(0.22,1,0.36,1), opacity 0.18s ease;
}
.select-mode .pth-chev-cell{justify-content:flex-start;gap:5px;padding-left:4px}
.select-mode .pth-checkbox-wrap{width:18px;opacity:1;pointer-events:auto}
/* ── TOOLBAR ANIMATION WRAPPER ── */
/* Provides a shared stacking context so both bars occupy the same space */
#toolbar-wrap{
  position:relative;
  display:flex;
  align-items:center;
}

/* Default toolbar fades out when selection bar opens */
#toolbar-default{
  transition:opacity 0.18s ease, visibility 0s linear 0s;
  pointer-events:auto;
  white-space:nowrap;
}
#toolbar-default.tb-hidden{
  opacity:0;
  pointer-events:none;
  user-select:none;
  visibility:hidden;
  transition:opacity 0.18s ease, visibility 0s linear 0.18s;
}

/* Selection bar — always in DOM, clip-path hides/reveals it */
.toolbar-selection{
  position:absolute;
  left:0;top:50%;
  transform:translateY(-50%);
  display:flex;align-items:center;gap:8px;
  background:var(--accent-bg);border:1px solid var(--accent-border);
  padding:5px 12px;border-radius:8px;
  white-space:nowrap;
  pointer-events:none;
  will-change:clip-path;
  /* Fully hidden by default — JS seeds the 84px start state on enter */
  clip-path:inset(-1px 100% -1px -1px round 8px);
  transition:clip-path 0.25s cubic-bezier(0.22,1,0.36,1);
}
.toolbar-selection.tb-visible{
  clip-path:inset(-1px -1px -1px -1px round 8px);
  pointer-events:auto;
}
.toolbar-sel-count{font-size:12px;font-weight:500;color:var(--accent2);white-space:nowrap}
.toolbar-sel-divider{width:1px;height:14px;background:var(--accent-border);flex-shrink:0}
/* Select button active state */
.select-mode-active{
  background:var(--accent-bg) !important;
  border:1px solid var(--accent-border) !important;
  color:var(--accent2) !important;
}

/* ── STALE SETTINGS INDICATOR ── */
.stale-indicator{
  font-size:14px;
  color:var(--amber);
  flex-shrink:0;
  cursor:default;
  line-height:1;
}
.btn-execute.stale-blocked{
  opacity:0.35;
  cursor:not-allowed;
  pointer-events:none;
}

/* Vertical divider between card header sections */
.pcard-vdivider{width:2px;height:24px;background:var(--border);justify-self:center;align-self:center;transition:background 0.2s}
/* Card dividers pick up theme colour on row hover; table header dividers stay static */
.portfolio-card:hover .portfolio-card-header .pcard-vdivider{background:var(--accent-border)}

/* NAME COLUMN RESIZE HANDLE — two-class selector beats .pcard-vdivider specificity */
/* Full 16px track is the click target; visual line via ::after pseudo-element */
.pcard-vdivider.pcard-vdivider-resize{
  width:100%;height:100%;
  justify-self:stretch;align-self:stretch;
  background:transparent;
  cursor:col-resize;
  position:relative;
  transition:none;
}
.pcard-vdivider.pcard-vdivider-resize::after{
  content:'';position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:2px;height:24px;
  background:var(--border);
  transition:background 0.12s;
  pointer-events:none;
}
.pcard-vdivider.pcard-vdivider-resize:hover::after,
.pcard-vdivider.pcard-vdivider-resize.dragging::after{
  background:var(--accent-border);
}

/* Generic right-aligned grid cell */
.pcard-col-r{display:flex;align-items:center;justify-content:flex-end}
/* Generic centered grid cell (metric columns) */
.pcard-col-c{display:flex;align-items:center;justify-content:center}
/* Pacing column cell — badge stacked above delta %, both centred */
.pcard-col-pace{flex-direction:column;gap:1px}
.pcard-pace-delta{font-size:10px;font-weight:600;font-variant-numeric:tabular-nums}

/* Cell value classes — match mockup's 13px light style */
.pcell{font-size:13px;color:var(--text2);transition:color 0.15s}
.pcell-green{font-size:13px;color:var(--green);font-weight:500}
.pcell-accent{font-size:13px;color:var(--accent2);font-weight:500}
/* Metric values turn accent on card hover (dash values retain text3 via inline style) */
.portfolio-card:hover .portfolio-card-header .pcell{color:var(--accent2)}

/* Portfolio group pill — sits in its own grid column (--pcol-group) */
.pcard-group-pill{
  display:inline-block;font-size:10px;font-weight:500;letter-spacing:0.04em;
  padding:2px 8px;border-radius:99px;
  background:var(--surface2);border:1px solid var(--border);color:var(--text3);
  max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  transition:background 0.15s,border-color 0.15s,color 0.15s;
}
.portfolio-card:hover .pcard-group-pill{
  background:var(--accent-border);border-color:var(--accent-border);color:var(--accent2);
}
/* Grid cell — centres its pill content */
.pcard-col-group{display:flex;align-items:center;justify-content:center}

/* Platform logos — sits in its own grid column (--pcol-platforms) */
.pcard-platforms{
  display:flex;align-items:center;justify-content:center;gap:4px;
  opacity:0.75;transition:opacity 0.15s;
}
.portfolio-card:hover .pcard-platforms{opacity:1}

/* IS Lost colour classes */
.islost-low{color:var(--text2);font-size:13px}
.islost-mid{color:var(--amber);font-size:13px}
.islost-hi{color:var(--red);font-size:13px}

/* Left side of collapsed header */
.pcard-left{display:flex;align-items:center;gap:16px;flex:1;min-width:0}
.pcard-chevron{
  color:var(--text3);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  width:12px;height:12px;
  transition:transform 0.22s cubic-bezier(0.22,1,0.36,1), color 0.15s;
}
.portfolio-card.expanded .pcard-chevron{transform:rotate(90deg);color:var(--accent)}
.portfolio-card:hover .pcard-chevron{color:var(--accent)}
.portfolio-card.expanded .pcard-checkbox-wrap{display:none}
/* name-wrap fills the 1fr grid cell — no sub-column management needed */
.portfolio-name-wrap{min-width:0;overflow:hidden}
.portfolio-name-inner{flex:1;min-width:0}
.portfolio-name{
  font-size:14px;font-weight:500;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:color 0.15s;
}
.portfolio-name-input{
  font-size:14px;color:var(--text);border:none;
  background:transparent;outline:none;width:100%;
  border-bottom:1.5px solid var(--accent);padding-bottom:2px;
}
.portfolio-campaign-count{font-size:11px;color:var(--text3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color 0.15s}
/* Right side of collapsed header — key stats always visible */
.pcard-summary{
  display:grid;
  grid-template-columns:100px 90px 70px 110px auto;
  align-items:center;
  gap:0;
  flex-shrink:0;
}
.pcard-stat{text-align:right;padding:0 16px}
.pcard-stat-label{font-size:9px;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3)}
.pcard-stat-value{font-family:'Bricolage Grotesque',sans-serif;font-size:14px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
.pcard-stat-value.green{color:var(--green)}
.pcard-budget-edit{display:flex;align-items:center;gap:1px}
.pcard-budget-prefix{font-size:13px;color:var(--text2);transition:color 0.15s}
.pcard-budget-input{
  width:50px;background:transparent;border:none;border-bottom:1px solid transparent;
  font-size:13px;color:var(--text2);text-align:left;
  padding:0 2px;outline:none;font-variant-numeric:tabular-nums;
  transition:color 0.15s,border-color 0.15s;font-family:inherit;
}
.portfolio-card:hover .pcard-budget-prefix{color:var(--accent2)}
.portfolio-card:hover .pcard-budget-input:not(:focus){color:var(--accent2)}
.pcard-budget-input:focus{border-bottom-color:var(--accent2);}
.pcard-budget-input:hover{border-bottom-color:var(--border);}
.pcard-budget-input::-webkit-inner-spin-button,.pcard-budget-input::-webkit-outer-spin-button{-webkit-appearance:none;}
.pcard-budget-input{-moz-appearance:textfield;}
.pcard-goal-pill{
  font-size:10px;color:var(--accent2);
  background:var(--accent-bg);border:1px solid var(--accent-border);
  padding:3px 8px;border-radius:10px;white-space:nowrap;
}
/* Actions cell */
.portfolio-actions{display:flex;align-items:center;justify-content:space-between;width:100%;flex-shrink:0}
.portfolio-actions .pa-left{display:flex;align-items:center;gap:6px}
.portfolio-actions .pa-right{display:flex;align-items:center;gap:5px}
.btn-execute.exec-idle{opacity:0.25;cursor:not-allowed;pointer-events:none}
/* ── DUPLICATE POPOVER ── */
.dup-popover{
  position:fixed;z-index:600;
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:14px 16px;
  box-shadow:0 8px 28px rgba(0,0,0,0.18);
  display:flex;flex-direction:column;gap:10px;
  min-width:190px;
}
.dup-popover-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em}
.dup-stepper{display:flex;align-items:stretch;gap:0;border:1px solid var(--border);border-radius:7px;overflow:hidden;height:32px}
.dup-step-btn{
  background:var(--surface2);border:none;color:var(--text2);
  font-size:16px;line-height:1;padding:0 12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.12s,color 0.12s;
}
.dup-step-btn:hover{background:var(--accent-bg);color:var(--accent2)}
.dup-step-btn:disabled{opacity:0.3;cursor:not-allowed}
#dup-count-display{
  flex:1;text-align:center;font-size:14px;font-weight:600;
  color:var(--text);background:var(--surface);
  border-left:1px solid var(--border);border-right:1px solid var(--border);
  font-variant-numeric:tabular-nums;
  display:flex;align-items:center;justify-content:center;
}
.dup-confirm-btn{font-size:11px;padding:6px 12px;width:100%}
/* ── CARD BODY SPRING ANIMATION ── */
/* springAnimate() in state.js drives the height directly */
.pcard-body-wrap{overflow:hidden;height:0}
.pcard-body-clip{}

/* Expanded body */
.portfolio-card-body{
  padding:16px 24px 18px;
  border-top:1px solid var(--border);
}

/* Stats row */
.portfolio-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border-radius:10px;overflow:hidden;margin-bottom:14px;
}
.pstat{background:var(--surface2);padding:12px 14px}
.pstat-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px}
.pstat-value{font-family:'Bricolage Grotesque',sans-serif;font-size:17px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
.pstat-value.green{color:var(--green)}

/* Fields */
.portfolio-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.field-readonly{cursor:default;color:var(--text2);user-select:none}
.field-group label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-bottom:5px}
.field-input{
  width:100%;padding:8px 10px;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;font-family:'DM Mono',monospace;font-size:12px;
  color:var(--text);outline:none;transition:border-color 0.15s,background 0.15s;
}
.field-input:focus{border-color:var(--accent);background:var(--surface3)}
.field-prefix-wrap{display:flex;align-items:center;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;overflow:hidden;transition:border-color 0.15s,background 0.15s}
.field-prefix-wrap:focus-within{border-color:var(--accent);background:var(--surface3)}
.field-prefix{padding:8px 6px 8px 10px;font-size:12px;color:var(--text3)}
.field-prefix-wrap input{flex:1;padding:8px 10px 8px 2px;background:transparent;border:none;font-family:'DM Mono',monospace;font-size:12px;color:var(--text);outline:none}

/* Campaign list in portfolio */
.portfolio-campaigns{border-top:1px solid var(--border);padding-top:12px;margin-top:2px}
.portfolio-campaigns-label{
  font-size:10px;text-transform:uppercase;letter-spacing:0.07em;
  color:var(--text3);margin-bottom:8px;display:flex;align-items:center;gap:6px;
}
.campaigns-label-hint{font-size:9px;color:var(--text3);text-transform:none;letter-spacing:0;opacity:0.7;font-style:italic}
.portfolio-campaign-item{
  display:grid;grid-template-columns:1fr auto auto auto auto auto;
  align-items:center;gap:8px;
  padding:8px 10px;background:var(--surface2);
  border-radius:8px;margin-bottom:4px;
  transition:background 0.12s,transform 0.15s;
  border:1px solid transparent;
}
.portfolio-campaign-item:hover{background:var(--surface3);border-color:var(--border2)}
.portfolio-campaign-item.removing{animation:itemRemove 0.25s ease forwards}
@keyframes itemRemove{to{opacity:0;transform:translateX(8px);height:0;padding:0;margin:0}}
.pcitem-name{font-size:11px;color:var(--text2);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.roas-badge{
  font-size:10px;color:var(--green);
  background:var(--green-bg);border:1px solid rgba(52,211,153,0.2);
  padding:2px 7px;border-radius:4px;white-space:nowrap;font-weight:600;
}
.alloc-badge{
  font-size:10px;color:var(--accent2);
  background:var(--accent-bg);border:1px solid var(--accent-border);
  padding:2px 7px;border-radius:4px;white-space:nowrap;font-weight:600;min-width:60px;text-align:center;
  transition:all 0.3s cubic-bezier(0.22,1,0.36,1);
}
.alloc-badge.stale{color:var(--text3);background:var(--surface3);border-color:var(--border2)}
.alloc-badge.empty{color:var(--text3);background:transparent;border-color:transparent}
.remove-btn{
  background:none;border:none;color:var(--text3);
  cursor:pointer;font-size:16px;line-height:1;padding:2px 4px;
  border-radius:4px;transition:all 0.12s;
}
.remove-btn:hover{color:var(--red);background:var(--red-bg)}
.empty-campaigns{
  text-align:center;padding:14px;
  color:var(--text3);font-size:11px;font-style:italic;
  border:1px dashed var(--border2);border-radius:8px;
}

/* ── CAMPAIGN GRID TABLE (inner Campaigns tab) ── */
.pcam-grid{margin-top:0}
/* Campaigns tab grid: 9 cols — Campaign|Type|Status|Daily Budget|Daily%|Spend|ROAS|IS Lost|× */
.pcam-grid.pcam-grid-cam .pcam-row{
  grid-template-columns:minmax(120px,1fr) 72px 76px 84px 58px 72px 56px 110px 26px;
}
.pcam-row{
  display:grid;
  grid-template-columns:minmax(120px,1fr) 72px 76px 72px 72px 56px 110px 26px;
  padding:8px 0;font-size:12px;color:var(--text3);
  border-bottom:1px solid var(--border);align-items:center;gap:0 6px;
}
.pcam-row:last-child{border-bottom:none}
.pcam-row.pcam-header{
  font-size:10px;text-transform:uppercase;letter-spacing:0.05em;color:var(--text3);
  padding:4px 0 8px;position:sticky;top:0;background:var(--surface);z-index:1;
}
.pcam-name{color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcam-r{text-align:right}
.pcam-per-day{font-size:10px;color:var(--text3);margin-left:1px}
/* Daily % colour classes */
.pcam-daily-pct{font-family:var(--font-mono);font-size:11px;font-weight:600}
.pct-good{color:var(--green)}
.pct-warn{color:var(--amber)}
.pct-bad{color:var(--red)}
.pct-none{color:var(--text3)}
/* IS Lost inline bar cell — right-justified so bar sits near the value */
.pcam-is{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.pcam-is .is-bar-wrap{flex:none;width:48px}
.pcam-is .is-val{font-family:var(--font-mono);font-size:11px;color:var(--text2);width:28px;text-align:right;flex-shrink:0}
.pcam-remove{
  background:none;border:none;color:var(--text3);cursor:pointer;
  font-size:14px;line-height:1;padding:2px 4px;border-radius:4px;
  transition:all 0.12s;opacity:0;
}
.pcam-row:hover .pcam-remove{opacity:1}
.pcam-remove:hover{color:var(--red);background:var(--red-bg)}

/* ── CAMPAIGNS TAB WRAPPER ── */
.pcam-tab-wrap{display:flex;flex-direction:column;gap:0}
.pcam-tab-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.pcam-tab-label{
  font-size:10px;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);
  display:flex;align-items:center;gap:6px;
}
.pcam-tab-count{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--surface2);border:1px solid var(--border);
  color:var(--text3);font-size:10px;font-weight:500;
  padding:1px 6px;border-radius:99px;letter-spacing:0;
}
.pcam-add-btn{
  font-size:11px;padding:5px 12px;
  background:var(--accent-bg);border:1px solid var(--accent-border);
  color:var(--accent2);border-radius:8px;cursor:pointer;
  transition:background 0.15s,color 0.15s,border-color 0.15s;
  font-family:inherit;font-weight:500;
}
.pcam-add-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
/* Scrollable table wrapper — max ~10 rows, sticky header */
.pcam-tab-scroll{
  max-height:368px;overflow-y:auto;overflow-x:hidden;
  border:1px solid var(--border);border-radius:10px;
  padding:0 12px;
}
.pcam-tab-scroll .pcam-row.pcam-header{
  background:var(--surface);
}

/* ── PORTFOLIO INNER TABS ── */
.pcard-tabs{
  display:flex;gap:0;border-bottom:1px solid var(--border);
  margin:-16px -20px 16px;padding:0 20px;
  position:relative;
}
.pcard-tab{
  padding:10px 16px;font-size:11px;font-weight:500;
  color:var(--text3);cursor:pointer;
  transition:color 0.15s;letter-spacing:0.05em;text-transform:uppercase;
  user-select:none;
}
.pcard-tab:hover{color:var(--text2)}
.pcard-tab.active{color:var(--accent2)}
.pcard-tab-indicator{
  position:absolute;bottom:0;height:2px;
  background:var(--accent);border-radius:2px 2px 0 0;
  transition:left 0.22s cubic-bezier(0.4,0,0.2,1),width 0.22s cubic-bezier(0.4,0,0.2,1);
  pointer-events:none;
}
.pcard-tab-panel{transition:opacity 0.1s ease}
.pcard-tab-panel.tab-fade{opacity:0}

/* ── CAMPAIGN BREAKDOWN TAB ── */
.breakdown-panel{display:flex;flex-direction:column;gap:0}
.breakdown-sort-row{
  display:flex;align-items:center;gap:6px;
  margin-bottom:14px;flex-wrap:wrap;
}
.breakdown-sort-label{font-size:10px;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-right:2px}
.breakdown-sort-pill{
  padding:4px 10px;border-radius:12px;font-size:10px;font-weight:500;
  cursor:pointer;border:1px solid var(--border2);
  background:var(--surface2);color:var(--text3);
  transition:all 0.12s;user-select:none;
}
.breakdown-sort-pill.active{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent2)}
.breakdown-legend{
  display:flex;gap:16px;margin-bottom:14px;flex-wrap:wrap;
}
.breakdown-legend-item{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text3)}
.breakdown-legend-swatch{width:14px;height:4px;border-radius:2px}
.breakdown-rows{display:flex;flex-direction:column;gap:8px}
.breakdown-row{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:9px;padding:10px 12px;
  transition:border-color 0.12s;
}
.breakdown-row:hover{border-color:var(--border2)}
.breakdown-row-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;gap:8px;
}
.breakdown-cam-name{
  font-size:11.5px;font-weight:500;color:var(--text);
  flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.breakdown-badges{display:flex;gap:5px;flex-shrink:0;align-items:center}
.breakdown-roas{
  font-size:10px;font-weight:600;
  padding:2px 7px;border-radius:4px;white-space:nowrap;
}
.breakdown-roas.good{background:var(--green-bg);color:var(--green)}
.breakdown-roas.mid{background:var(--amber-bg);color:var(--amber)}
.breakdown-roas.low{background:var(--red-bg);color:var(--red)}
.breakdown-pct{font-size:10px;color:var(--text3);white-space:nowrap}
.breakdown-bars{display:flex;flex-direction:column;gap:4px}
.breakdown-bar-row{display:flex;align-items:center;gap:8px}
.breakdown-bar-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em;width:48px;flex-shrink:0;text-align:right}
.breakdown-bar-track{flex:1;height:5px;background:var(--surface3);border-radius:3px;overflow:hidden;position:relative}
.breakdown-bar-fill{height:100%;border-radius:3px;transition:width 0.7s cubic-bezier(0.22,1,0.36,1);width:0}
.breakdown-bar-val{font-size:10px;color:var(--text2);width:52px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}
/* IS Lost mini-bar (Section 11.3) */
.is-bar-wrap{flex:1;display:flex;align-items:center}
.is-bar{flex:1;height:3px;background:var(--surface3);border-radius:20px;overflow:hidden}
.is-fill{height:100%;border-radius:20px;background:var(--accent);transition:width 0.8s cubic-bezier(0.22,1,0.36,1);width:0%}
.is-val{font-family:var(--font-mono);font-size:11px;color:var(--text2);width:52px;text-align:right;flex-shrink:0}
.breakdown-totals{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border-radius:9px;overflow:hidden;margin-bottom:14px;
}
.breakdown-total-cell{background:var(--surface2);padding:9px 12px}
.breakdown-total-label{font-size:9px;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-bottom:3px}
.breakdown-total-value{font-family:'Bricolage Grotesque',sans-serif;font-size:15px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
.breakdown-total-value.green{color:var(--green)}
.breakdown-paused-note{font-size:10px;color:var(--text3);font-style:italic;margin-top:8px;padding:0 2px}

/* ── INSIGHTS PANEL ── */
.insights-panel{display:flex;flex-direction:column;gap:14px}
.insight-section{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:10px;overflow:hidden;
}
.insight-section-header{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-bottom:1px solid var(--border);
}
.insight-section-icon{font-size:14px}
.insight-section-title{font-size:11px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:0.06em;flex:1}
.insight-section-value{font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}
.insight-section-value.positive{color:var(--green)}
.insight-section-value.warning{color:var(--amber)}
.insight-section-value.negative{color:var(--red)}
.insight-bullets{padding:10px 14px;display:flex;flex-direction:column;gap:6px}
.insight-bullet{
  display:flex;align-items:flex-start;gap:8px;
  font-size:11.5px;color:var(--text2);line-height:1.5;
}
.insight-bullet-dot{
  width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:5px;
}
.insight-bullet-dot.green{background:var(--green)}
.insight-bullet-dot.amber{background:var(--amber)}
.insight-bullet-dot.red{background:var(--red)}
.insight-bullet-dot.blue{background:var(--blue)}
.insight-bullet strong{color:var(--text)}

/* Health bar */
.health-bar-wrap{padding:10px 14px 14px}
.health-bar-track{
  display:flex;height:8px;border-radius:4px;overflow:hidden;gap:2px;margin-bottom:10px;
}
.health-seg{height:100%;border-radius:2px;transition:width 0.6s cubic-bezier(0.22,1,0.36,1)}
.health-legend{display:flex;gap:14px;flex-wrap:wrap}
.health-legend-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text3)}
.health-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.health-campaign-list{padding:0 14px 12px;display:flex;flex-direction:column;gap:4px}
.health-cam-row{
  display:flex;align-items:center;gap:8px;
  padding:6px 8px;border-radius:6px;background:var(--surface3);
}
.health-cam-name{flex:1;font-size:11px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.health-cam-status{
  font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;
  padding:2px 7px;border-radius:4px;white-space:nowrap;
}
.status-constrained{background:rgba(var(--amber-ch),0.15);color:var(--amber)}
.status-healthy{background:rgba(var(--green-ch),0.12);color:var(--green)}
.status-underperforming{background:rgba(var(--red-ch),0.12);color:var(--red)}
.status-paused{background:var(--surface2);color:var(--text3)}
.health-cam-metric{font-size:10px;color:var(--text3);white-space:nowrap}

/* Utilisation bar */
.utilisation-wrap{padding:10px 14px 14px}
.util-bar-track{height:8px;background:var(--surface3);border-radius:4px;overflow:hidden;margin-bottom:8px}
.util-bar-fill{height:100%;border-radius:4px;transition:width 0.6s cubic-bezier(0.22,1,0.36,1)}
.util-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text3);margin-bottom:10px}

/* Insights disclaimer */
.insights-disclaimer{
  font-size:10.5px;color:var(--text3);font-style:italic;
  padding:8px 4px;line-height:1.5;
}

/* ── AI INSIGHTS ── */
.ai-insights-status{
  display:flex;align-items:center;gap:8px;
  font-size:10px;text-transform:uppercase;letter-spacing:0.06em;
  color:var(--text3);font-weight:600;margin-bottom:12px;
}
.ai-insights-status-dot{
  width:6px;height:6px;border-radius:50%;flex-shrink:0;
}
.ai-insights-status-dot.ai{background:var(--accent)}
.ai-insights-status-dot.rule{background:var(--text3)}
.ai-insights-age{font-weight:400;opacity:0.7;margin-left:auto}
.ai-insights-refresh{
  font-size:12px;padding:2px 6px;margin-left:4px;
  color:var(--text3);cursor:pointer;border-radius:4px;
  background:none;border:none;
}
.ai-insights-refresh:hover{color:var(--accent);background:var(--surface3)}

.ai-insight-sections{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.ai-insight-card{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:10px;padding:12px 14px;
  border-left:3px solid var(--border2);
}
.ai-insight-card.urgent{border-left-color:var(--red)}
.ai-insight-card.important{border-left-color:var(--amber)}
.ai-insight-card.info{border-left-color:var(--accent)}

.ai-insight-card-header{
  display:flex;align-items:center;gap:8px;margin-bottom:6px;
}
.ai-insight-icon{font-size:13px}
.ai-insight-title{
  font-size:11px;font-weight:600;color:var(--text);
  text-transform:uppercase;letter-spacing:0.04em;flex:1;
}
.ai-insight-priority-badge{
  font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;
  padding:2px 6px;border-radius:3px;
}
.ai-insight-priority-badge.urgent{background:rgba(var(--red-ch),0.12);color:var(--red)}
.ai-insight-priority-badge.important{background:rgba(var(--amber-ch),0.12);color:var(--amber)}
.ai-insight-priority-badge.info{background:rgba(var(--accent-ch),0.08);color:var(--accent)}

.ai-insight-body{
  font-size:12px;line-height:1.65;color:var(--text2);
}
.ai-insight-body strong{color:var(--text);font-weight:600}

/* Loading skeleton */
.ai-insights-loading{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.ai-insight-skeleton{
  height:72px;border-radius:10px;
  background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);
  background-size:200% 100%;
  animation:ai-skeleton-shimmer 1.5s ease-in-out infinite;
}
.ai-insight-skeleton.short{height:56px;width:75%}
@keyframes ai-skeleton-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.ai-insights-loading-label{
  display:flex;align-items:center;gap:8px;
  font-size:11px;color:var(--text3);margin-top:4px;
}
.ai-insights-error{
  font-size:11px;color:var(--red);
  padding:8px 12px;background:rgba(var(--red-ch),0.06);
  border-radius:8px;border:1px solid rgba(var(--red-ch),0.15);
}
.ai-insights-no-key{
  font-size:11px;color:var(--text3);font-style:italic;
  padding:4px 0;
}

/* Divider between AI and rule sections */
.ai-insights-divider{
  display:flex;align-items:center;gap:10px;
  margin:16px 0 12px;
}
.ai-insights-divider::before,.ai-insights-divider::after{
  content:'';flex:1;height:1px;background:var(--border);
}
.ai-insights-divider span{
  font-size:9px;text-transform:uppercase;letter-spacing:0.08em;
  color:var(--text3);white-space:nowrap;
}

/* Modal insights link */
.opt-modal-insights-link{
  text-align:center;margin-top:12px;padding-top:12px;
  border-top:1px solid var(--border);
}
.opt-modal-insights-link a{
  font-size:11px;color:var(--accent);text-decoration:none;
  font-weight:500;
}
.opt-modal-insights-link a:hover{text-decoration:underline}

/* Optimise row */
.optimise-row{
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.opt-status{font-size:11px;color:var(--text3);font-style:italic}
.opt-status.applied{color:var(--green)}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;
  background:var(--overlay-bg);
  display:flex;align-items:center;justify-content:center;
  z-index:999;opacity:0;pointer-events:none;
  transition:opacity 0.22s;backdrop-filter:blur(6px);
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--radius-xl);padding:28px;
  width:460px;max-width:calc(100vw - 32px);
  box-shadow:var(--shadow-xl);
  transform:translateY(12px) scale(0.98);
  transition:transform 0.22s cubic-bezier(0.22,1,0.36,1);
}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal-title{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:600;color:var(--text);margin-bottom:6px}
.modal-sub{font-size:12px;color:var(--text3);margin-bottom:20px;line-height:1.6}
.modal-field{margin-bottom:14px}
.modal-field label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-bottom:6px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:22px}
.modal-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
/* Pacing strategy cards */
.pacing-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;position:relative}
.pacing-card{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:8px 8px 8px;border-radius:8px;cursor:pointer;user-select:none;
  border:1.5px solid var(--border);background:var(--surface2);
  transition:border-color 0.15s,background 0.15s;
  justify-content:flex-end;min-height:66px;
  position:relative;z-index:1;
}
.pacing-card:hover{border-color:var(--accent-border);background:var(--surface3)}
.pacing-card.selected{background:transparent;border-color:transparent}
.pacing-card.selected .pacing-card-label{color:var(--accent2)}
.pacing-card svg{color:var(--accent2)}
.pacing-card rect{transform-box:fill-box;transform-origin:bottom;transition:transform 0.45s cubic-bezier(0.34,1.4,0.64,1)}
.pacing-card-label{
  font-size:9px;text-transform:uppercase;letter-spacing:0.07em;
  font-weight:400;color:var(--text3);text-align:center;line-height:1.2;
  transition:color 0.15s;
}
/* Sliding selection indicator */
.pacing-selector{
  position:absolute;z-index:0;pointer-events:none;
  border:1.5px solid var(--accent);background:var(--accent-bg);
  border-radius:8px;
  transition:left 0.18s cubic-bezier(0.4,0,0.2,1),top 0.18s cubic-bezier(0.4,0,0.2,1),width 0.18s,height 0.18s;
}
.new-portfolio-campaigns-wrap{display:flex;align-items:center;gap:10px}
.new-portfolio-campaigns-btn{opacity:0.35;cursor:not-allowed;pointer-events:none;font-size:11px;padding:5px 12px;border:1px dashed var(--border)}
.new-portfolio-campaigns-hint{font-size:11px;color:var(--text3)}
.delete-confirm-field{margin-bottom:4px}
.delete-confirm-label{display:block;font-size:11px;color:var(--text3);margin-bottom:6px}
.delete-confirm-input{
  width:100%;box-sizing:border-box;
  background:var(--surface2);border:1px solid var(--border);border-radius:6px;
  color:var(--text);font-family:inherit;font-size:13px;
  padding:7px 10px;outline:none;
  transition:border-color 0.15s;
}
.delete-confirm-input:focus{border-color:var(--accent2);}
.delete-confirm-input::placeholder{color:var(--text3);opacity:0.5;}

/* Assign list */
.assign-list{max-height:260px;overflow-y:auto;border:1px solid var(--border2);border-radius:10px;margin-bottom:4px}
.assign-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.1s}
.assign-item:last-child{border-bottom:none}
.assign-item:hover{background:var(--surface2)}
.assign-item.selected{background:var(--accent-bg);border-left:2px solid var(--accent)}
.assign-item-name{flex:1;font-size:12px;color:var(--text)}
.assign-item-roas{font-size:11px;color:var(--green)}

/* ── OPTIMISATION MODAL ── */
.opt-modal{width:680px;max-width:calc(100vw - 24px);max-height:88vh;overflow-y:auto}
.opt-modal-header{
  display:flex;align-items:center;gap:14px;margin-bottom:22px;
  padding-bottom:18px;border-bottom:1px solid var(--border);
}
.opt-modal-icon{
  width:44px;height:44px;flex-shrink:0;
  background:var(--accent-grad);color:white;
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:20px;
}
.opt-modal-icon .sparkle-star{display:inline-block;animation:sparkle-pulse 2s ease-in-out infinite}
.opt-modal-title{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:700;color:var(--text)}
.opt-modal-subtitle{font-size:12px;color:var(--text3);margin-top:3px}

/* AI reasoning */
.ai-reasoning-box{
  background:linear-gradient(135deg,rgba(124,106,247,0.08),rgba(192,132,252,0.06));
  border:1px solid var(--accent-border);
  border-radius:12px;padding:16px 18px;margin-bottom:20px;
  position:relative;
}
.ai-reasoning-label{
  font-size:10px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--accent2);font-weight:600;margin-bottom:10px;
  display:flex;align-items:center;gap:6px;
}
.ai-reasoning-text{font-size:12.5px;line-height:1.8;color:var(--text2)}
.ai-reasoning-text p{margin-bottom:10px}
.ai-reasoning-text p:last-child{margin-bottom:0}
.ai-reasoning-text strong{color:var(--text);font-weight:600}

/* Allocation table */
.alloc-table{width:100%;border-collapse:collapse;margin-bottom:20px}
.alloc-table th{
  font-size:10px;text-transform:uppercase;letter-spacing:0.07em;
  color:var(--text3);padding:8px 10px;
  border-bottom:1px solid var(--border2);text-align:left;
}
.alloc-table th.r{text-align:right}
.alloc-table td{padding:10px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.alloc-table tr:last-child td{border-bottom:none}
.alloc-table tr:hover td{background:var(--surface2)}
.alloc-name{font-size:12px;font-weight:500;color:var(--text)}
.alloc-meta{font-size:10px;color:var(--text3);margin-top:2px}
.bar-wrap{display:flex;align-items:center;gap:8px}
.bar-bg{flex:1;height:5px;background:var(--surface3);border-radius:3px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:3px;transition:width 0.7s cubic-bezier(0.22,1,0.36,1);width:0}
.bar-pct{font-size:11px;color:var(--text3);width:32px;text-align:right;font-variant-numeric:tabular-nums}
.alloc-amount{font-size:13px;font-weight:600;color:var(--accent2);text-align:right;font-variant-numeric:tabular-nums}
.change-up{color:var(--green);font-size:11px}
.change-dn{color:var(--red);font-size:11px}
.change-eq{color:var(--text3);font-size:11px}
.paused-row td{opacity:0.45}
.paused-row:hover td{background:transparent}

/* Pacing panel */
.pacing-panel{
  background:var(--surface2);border:1px solid var(--border2);border-radius:10px;
  padding:14px 16px;margin-bottom:18px;
}
.pacing-panel-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pacing-panel-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3)}
.pace-badge{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;
  padding:2px 7px;border-radius:20px;
}
.pace-on{background:color-mix(in srgb,var(--green) 15%,transparent);color:var(--green)}
.pace-slightly-ahead{background:color-mix(in srgb,var(--amber) 15%,transparent);color:var(--amber)}
.pace-ahead{background:color-mix(in srgb,var(--red) 15%,transparent);color:var(--red)}
.pace-slightly-behind{background:color-mix(in srgb,var(--amber) 15%,transparent);color:var(--amber)}
.pace-behind{background:color-mix(in srgb,var(--red) 15%,transparent);color:var(--red)}
.pace-delta-pct{font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;text-align:right}
.pstatus-pill{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;padding:2px 7px;border-radius:20px}
.pstatus-active{background:color-mix(in srgb,var(--green) 15%,transparent);color:var(--green)}
.pstatus-inactive{background:color-mix(in srgb,var(--text3) 12%,transparent);color:var(--text3)}
.pstatus-new{
  background:color-mix(in srgb,var(--blue) 12%,transparent);color:var(--blue);
  position:relative;overflow:hidden;
}
.pstatus-new::after{
  content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.45),transparent);
  animation:pstatus-shine 3s ease-in-out infinite;
}
@keyframes pstatus-shine{0%,35%{left:-120%}55%,100%{left:160%}}
.pstatus-sparkle{
  display:inline-block;font-size:9px;margin-right:2px;
  animation:sparkle-pulse 2s ease-in-out infinite;
}
@keyframes sparkle-pulse{
  0%,100%{transform:scale(0.75) rotate(-10deg);opacity:0.6}
  50%{transform:scale(1.3) rotate(15deg);opacity:1}
}
.pace-pct-on{color:var(--green)}
.pace-pct-slightly-ahead,.pace-pct-slightly-behind{color:var(--amber)}
.pace-pct-ahead,.pace-pct-behind{color:var(--red)}
.pacing-bar-track{
  position:relative;height:6px;background:var(--surface3);border-radius:3px;overflow:visible;margin-bottom:10px;
}
.pacing-bar-fill{
  position:absolute;left:0;top:0;height:100%;border-radius:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  transition:width 0.5s ease;
}
.pacing-bar-marker{
  position:absolute;top:-4px;width:2px;height:14px;background:var(--text3);border-radius:1px;
  transform:translateX(-50%);
}
.pacing-stats{display:flex;gap:18px;flex-wrap:wrap}
.pacing-stat{display:flex;flex-direction:column;gap:2px}
.pacing-stat-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.05em}
.pacing-stat-value{font-size:13px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}

/* Pacing tab — SVG bar chart */
.pacing-tab-panel{padding:4px 0 8px}
.pacing-confidence-row{min-height:20px;display:flex;align-items:center;margin-bottom:6px}
.pacing-tab-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.pacing-tab-left{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}
.pacing-tab-stats{display:flex;gap:20px;flex-wrap:wrap;align-items:flex-start}
.pacing-stat-sep{width:2px;align-self:stretch;background:var(--border);margin:0 4px;flex-shrink:0}
.pacing-mode-select{
  font-size:11px;font-family:var(--font-ui);font-weight:500;
  padding:4px 24px 4px 10px;border-radius:8px;
  border:1px solid var(--border2);background:var(--surface2);
  color:var(--text2);cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 8px center;
  transition:border-color 0.15s,color 0.15s;
  align-self:center;
}
.pacing-mode-select:focus{outline:none;border-color:var(--accent)}
.pacing-mode-select:hover{border-color:var(--border);color:var(--text)}
.pacing-chart-month{font-size:11px;color:var(--text3);margin-bottom:4px;font-weight:500}
.pacing-chart-wrap{position:relative;margin-bottom:4px;margin-left:-20px;margin-right:-20px}
.pacing-bar{transition:filter 0.1s ease}
.pacing-tooltip{
  display:none;position:absolute;pointer-events:none;z-index:20;
  background:var(--surface);border:1px solid var(--border2);border-radius:8px;
  padding:8px 12px;box-shadow:0 4px 16px rgba(0,0,0,0.35);min-width:110px;
}
.pacing-tip-date{font-size:11px;font-weight:600;color:var(--text);margin-bottom:2px}
.pacing-tip-type{font-size:10px;color:var(--text3);margin-bottom:6px}
.pacing-tip-value{font-size:16px;font-weight:700;color:var(--accent2);font-variant-numeric:tabular-nums}
.pacing-tip-plan{font-size:10px;color:var(--text3);margin-top:5px;font-variant-numeric:tabular-nums}
.pacing-tip-delta{font-size:10px;font-weight:600;margin-top:3px;font-variant-numeric:tabular-nums}
.tip-delta-green{color:var(--green)}
.tip-delta-amber{color:var(--amber)}
.tip-delta-red{color:var(--red)}
.pacing-tab-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.pacing-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3)}
.pacing-legend-swatch{width:14px;height:9px;border-radius:2px;flex-shrink:0}
.pacing-legend-swatch.actual{background:var(--accent)}
.pacing-legend-swatch.projected{background:var(--accent);opacity:0.32}
.pacing-legend-swatch.plan{background:var(--text2);height:2px;border-radius:1px;opacity:0.75}
.pacing-model-confidence{font-size:10px;color:var(--text3);white-space:nowrap;align-self:center}

/* ── PACING MULTIPLIER EDITOR ── */
.pacing-editor{
  display:none;position:absolute;z-index:30;pointer-events:all;
  width:174px;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:10px;padding:12px 14px;
  box-shadow:0 6px 24px rgba(0,0,0,0.4);
}
.pacing-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.pacing-editor-date{font-size:12px;font-weight:600;color:var(--text)}
.pacing-editor-close{background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:0;line-height:1;transition:color 0.15s}
.pacing-editor-close:hover{color:var(--text)}
.pacing-editor-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:6px}
.pacing-editor-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.pacing-editor-input{
  width:58px;padding:5px 8px;border-radius:6px;
  border:1px solid var(--border2);background:var(--surface2);
  color:var(--text);font-size:13px;text-align:center;
  transition:border-color 0.15s;
}
.pacing-editor-input:focus{outline:none;border-color:var(--accent)}
.pacing-editor-eq{font-size:12px;color:var(--text2)}
.pacing-editor-preview{color:var(--text)}
.pacing-editor-actions{display:flex;gap:6px}
.pacing-editor-actions .btn-primary{flex:1;justify-content:center}
/* Pin dot on customised bars */
.pacing-pin{pointer-events:none}

/* Right-side column: pace badge + remove button */
.pacing-tab-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.pacing-remove-mults{
  font-size:10px;font-family:'DM Mono',monospace;letter-spacing:0.02em;
  padding:3px 9px;border-radius:6px;cursor:pointer;white-space:nowrap;
  background:transparent;border:1px solid var(--border2);color:var(--text3);
  transition:color 0.15s,border-color 0.15s,background 0.15s;
}
.pacing-remove-mults:hover{
  color:var(--red);border-color:color-mix(in srgb,var(--red) 35%,transparent);
  background:color-mix(in srgb,var(--red) 8%,transparent);
}

/* ── STAGED BADGE ──────────────────────────────────────────────────────────── */
.opt-staged-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:10px;font-weight:600;letter-spacing:0.04em;
  color:var(--accent2);
  background:color-mix(in srgb,var(--accent2) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--accent2) 30%,transparent);
  border-radius:4px;padding:2px 7px;white-space:nowrap;
}
.opt-status.staged{ color:var(--accent2); }
.opt-status.applied{ color:var(--green); }

/* ── EXECUTE BUTTON ────────────────────────────────────────────────────────── */
.btn-execute{
  background:color-mix(in srgb,var(--green) 14%,transparent);
  color:var(--green);
  border:1px solid color-mix(in srgb,var(--green) 35%,transparent);
  border-radius:6px;padding:6px 14px;font-size:12px;font-weight:500;
  cursor:pointer;transition:background 0.15s,border-color 0.15s;white-space:nowrap;
}
.btn-execute:hover{
  background:color-mix(in srgb,var(--green) 22%,transparent);
  border-color:color-mix(in srgb,var(--green) 50%,transparent);
}
.btn-execute:disabled{ opacity:0.5;cursor:not-allowed; }

/* ── BULK DRAWER ───────────────────────────────────────────────────────────── */
.bulk-drawer{
  position:fixed;bottom:0;left:6%;right:6%;
  background:var(--surface);
  border-top:1px solid var(--border);
  box-shadow:0 -6px 32px rgba(0,0,0,0.22);
  z-index:200;
  border-radius:12px 12px 0 0;
  transform:translateY(100%);
  transition:transform 0.3s cubic-bezier(0.4,0,0.2,1),
             max-height 0.35s cubic-bezier(0.4,0,0.2,1),
             left 0.35s cubic-bezier(0.4,0,0.2,1),
             right 0.35s cubic-bezier(0.4,0,0.2,1);
  max-height:68vh;
  display:flex;flex-direction:column;
}
.bulk-drawer.open{ transform:translateY(0); }
.bulk-drawer-handle{
  width:40px;height:4px;border-radius:2px;
  background:var(--border2);margin:10px auto 0;flex-shrink:0;
}
.bulk-drawer-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 20px 10px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.bulk-drawer-title{ font-size:14px;font-weight:600;color:var(--text); }
.bulk-drawer-sub{ font-size:11px;color:var(--text3);margin-top:2px; }
.bulk-drawer-header-actions{ display:flex;gap:8px;align-items:center; }
.bulk-drawer-body{ overflow-y:auto;flex:1; }

/* Bulk summary bar */
.bulk-summary-bar{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding:10px 20px;font-size:12px;color:var(--text2);
  background:var(--surface2);border-bottom:1px solid var(--border);
}
.bulk-summary-sep{ color:var(--text3);opacity:.5; }

/* Bulk drawer portfolio rows */
.bulk-row{ border-bottom:1px solid var(--border); }
.bulk-row:last-child{ border-bottom:none; }
.bulk-row.skipped{ opacity:0.38;pointer-events:none; }
.bulk-row-header{
  display:flex;align-items:center;gap:10px;
  padding:10px 20px;cursor:pointer;user-select:none;
  transition:background 0.12s;
}
.bulk-row-header:hover{ background:var(--surface2); }
.bulk-row-chevron{
  font-size:9px;color:var(--text3);flex-shrink:0;
  transition:transform 0.15s;
}
.bulk-row.expanded .bulk-row-chevron{ transform:rotate(90deg); }
.bulk-row-name{
  font-size:13px;font-weight:600;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  min-width:0;flex-shrink:1;
}
.bulk-row-budget{
  font-size:11px;white-space:nowrap;flex-shrink:0;
  font-family:var(--font-mono);
}
.bulk-row-counts{
  display:flex;gap:8px;font-size:11px;white-space:nowrap;flex-shrink:0;
}
.bulk-row-actions{ display:flex;gap:6px;align-items:center;flex-shrink:0;margin-left:auto; }
.bulk-row-body{
  padding:0 20px 14px;
  border-top:1px solid var(--border2);
}

/* Bulk campaign table */
.bulk-cam-table{
  width:100%;border-collapse:collapse;font-size:12px;margin-top:4px;
  table-layout:fixed;
}
.bulk-cam-table colgroup .col-campaign{ width:auto; }
.bulk-cam-table colgroup .col-current{ width:90px; }
.bulk-cam-table colgroup .col-new{ width:90px; }
.bulk-cam-table colgroup .col-change{ width:100px; }
.bulk-cam-table colgroup .col-target{ width:130px; }
.bulk-cam-table th{
  color:var(--text3);font-weight:500;font-size:10px;
  text-transform:uppercase;letter-spacing:0.05em;
  padding:6px 8px;text-align:left;
  border-bottom:1px solid var(--border2);
  position:sticky;top:0;background:var(--surface);z-index:1;
}
.bulk-cam-table td{ padding:6px 8px;border-bottom:1px solid var(--border2); }
.bulk-cam-table tr:last-child td{ border-bottom:none; }
.bulk-cam-table .bulk-cam-current,
.bulk-cam-table .bulk-cam-new,
.bulk-cam-table .bulk-cam-change,
.bulk-cam-table .bulk-cam-target{ text-align:right; }
.bulk-cam-table th:not(:first-child){ text-align:right; }
.bulk-cam-name{ color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.bulk-cam-current,.bulk-cam-new{ font-family:var(--font-mono);font-size:11px; }
.bulk-cam-target{ font-size:11px; }
.bulk-cam-scroll{ max-height:280px;overflow-y:auto; }
.bulk-cam-table .paused-row{ opacity:.45; }

/* ── BULK THEATRE (concurrent pipeline animation) ────────────────────────── */
.bulk-drawer.theatre{
  max-height:90vh;
  left:6%;right:6%;
}
.bulk-drawer.theatre .bulk-drawer-header-actions{ display:none; }

/* Grid layout — shared by header + rows */
.bt-grid{
  display:grid;
  grid-template-columns:200px 1fr 110px;
  align-items:center;
  padding:0 24px;
}

/* Header row with node labels */
.bt-header{
  border-bottom:1px solid var(--border2);
  padding-top:8px;padding-bottom:8px;
  font-size:9px;font-weight:600;text-transform:uppercase;
  letter-spacing:.07em;color:var(--text3);
}
.bt-header-name{ padding-left:4px; }
.bt-header-pipeline{
  display:grid;grid-template-columns:repeat(6,1fr);
  text-align:center;
}
.bt-header-pipeline span{
  font-size:8px;font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;color:var(--text3);
}

/* Portfolio row */
.bt-row{
  border-bottom:1px solid var(--border2);
  padding-top:14px;padding-bottom:14px;
  opacity:0;transform:translateY(4px);
  animation:bt-row-in .3s ease forwards;
}
@keyframes bt-row-in{to{opacity:1;transform:translateY(0)}}

.bt-row-name{
  font-size:13px;font-weight:600;color:var(--text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  padding-left:4px;
}
/* Pipeline strip — single bar with nodes */
.bt-pipeline{
  position:relative;
  height:28px;
}
.bt-track{
  position:absolute;top:50%;
  left:calc(100%/12);right:calc(100%/12);
  height:2px;background:var(--surface3);border-radius:2px;
  transform:translateY(-50%);
}
.bt-fill{
  position:absolute;top:50%;left:0;
  height:3px;background:var(--accent-grad);border-radius:2px;
  transform:translateY(-50%);
  width:0;transition:width 480ms cubic-bezier(.22,1,.36,1);
}
.bt-nodes{
  display:grid;grid-template-columns:repeat(6,1fr);
  justify-items:center;align-items:center;
  position:relative;z-index:1;height:100%;
}
.bt-node{
  width:28px;height:28px;border-radius:50%;
  background:var(--surface3);border:1.5px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:var(--text3);
  transition:all .3s cubic-bezier(.22,1,.36,1);
  flex-shrink:0;
}
.bt-node.active{
  background:var(--accent-bg);border-color:var(--accent);color:var(--accent);
  box-shadow:0 0 0 5px var(--accent-bg);
  animation:bt-ring 1.8s ease-in-out infinite;
}
.bt-node.done{
  background:var(--accent);border-color:var(--accent);color:white;
}
@keyframes bt-ring{
  0%,100%{box-shadow:0 0 0 5px var(--accent-bg)}
  50%{box-shadow:0 0 0 8px var(--accent-bg)}
}

/* Row status */
.bt-row-status{
  font-size:11px;font-weight:500;color:var(--text3);
  text-align:right;white-space:nowrap;
  padding-right:4px;
}
.bt-row.complete .bt-row-status{ color:var(--green); }

/* Overflow indicator */
.bt-overflow{
  text-align:center;padding:12px 24px;
  font-size:12px;color:var(--text3);
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.bt-overflow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);
  animation:bt-dot-pulse 1.4s ease-in-out infinite;
}
@keyframes bt-dot-pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.35;transform:scale(.7)}
}

/* Footer with Review Changes button */
.bt-footer{
  padding:14px 24px;
  display:flex;align-items:center;justify-content:flex-end;
  border-top:1px solid var(--border2);
}
.bt-review{
  background:var(--accent-grad);color:white;
  border:none;border-radius:8px;padding:8px 20px;
  font-family:var(--font-ui);font-size:13px;font-weight:600;
  cursor:pointer;
  opacity:0;transform:translateY(6px);
  transition:opacity .3s,transform .3s;
}
.bt-review.visible{
  opacity:1;transform:translateY(0);
}
.bt-review:hover{ filter:brightness(1.1); }

/* ═══════════════════════════════════════════════════════════════════════════════
   CAMPAIGN PICKER MODAL
   ═══════════════════════════════════════════════════════════════════════════════ */

.cam-picker-overlay{
  position:fixed;inset:0;z-index:900;
  background:rgba(0,0,0,0.55);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity 0.18s;
}
.cam-picker-modal{
  background:var(--surface);border:1px solid var(--border);
  border-radius:16px;box-shadow:0 24px 64px rgba(0,0,0,0.35);
  width:85vw;max-width:1100px;height:80vh;
  display:flex;flex-direction:column;overflow:hidden;
  opacity:0;transform:scale(0.97) translateY(12px);
  transition:opacity 0.18s,transform 0.22s cubic-bezier(0.22,1,0.36,1);
}
/* Header */
.cam-picker-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px 14px;border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.cam-picker-title{
  font-size:15px;font-weight:600;color:var(--text);
  font-family:'Bricolage Grotesque',sans-serif;
}
.cam-picker-title-port{color:var(--text2);font-weight:500}
.cam-picker-close{
  background:none;border:none;color:var(--text3);cursor:pointer;
  font-size:16px;line-height:1;padding:6px 8px;border-radius:6px;
  transition:color 0.12s,background 0.12s;
}
.cam-picker-close:hover{color:var(--text);background:var(--surface2)}
/* Filter bar */
.cam-picker-filters{
  padding:12px 24px;border-bottom:1px solid var(--border);
  flex-shrink:0;display:flex;flex-direction:column;gap:8px;
}
.cam-picker-search-row{ display:flex; }
.cam-picker-search{
  width:100%;padding:8px 12px;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;font-size:13px;color:var(--text);
  outline:none;font-family:inherit;
  transition:border-color 0.15s,background 0.15s;
}
.cam-picker-search:focus{border-color:var(--accent);background:var(--surface3)}
.cam-picker-chip-row{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
}
.cfl-group{display:flex;align-items:center;gap:4px}
.cfl-group-right{margin-left:auto}
.cfl-label{
  font-size:10px;text-transform:uppercase;letter-spacing:0.06em;
  color:var(--text3);margin-right:2px;white-space:nowrap;
}
.cfl-chip{
  padding:4px 10px;border-radius:99px;font-size:11px;font-weight:500;
  background:var(--surface2);border:1px solid var(--border2);
  color:var(--text2);cursor:pointer;font-family:inherit;
  transition:background 0.12s,color 0.12s,border-color 0.12s;
}
.cfl-chip:hover{background:var(--surface3);color:var(--text)}
.cfl-chip.active{
  background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent2);
}
/* Body — swappable between step 1 (filters+table) and step 2 (review) */
.cam-picker-body{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}
/* Table area */
.cam-picker-table-wrap{flex:1;overflow-y:auto;overflow-x:auto}
.cam-picker-grid{min-width:740px}
/* Picker row: ☐ | Campaign | Type | Status | Platform | Daily Budget | ROAS | Current Portfolio */
.cam-picker-row{
  display:grid;
  grid-template-columns:32px minmax(150px,1fr) 76px 80px 40px 90px 60px minmax(120px,180px);
  padding:10px 24px;font-size:12px;color:var(--text2);
  border-bottom:1px solid var(--border);align-items:center;gap:0 8px;
  cursor:pointer;transition:background 0.1s;
}
.cam-picker-row:last-child{border-bottom:none}
.cam-picker-row:hover{background:var(--surface2)}
.cam-picker-row.cam-picker-header{
  font-size:10px;text-transform:uppercase;letter-spacing:0.05em;color:var(--text3);
  padding:8px 24px 8px;cursor:default;
  position:sticky;top:0;background:var(--surface);z-index:1;border-bottom:2px solid var(--border);
}
.cam-picker-row.cam-picker-header:hover{background:var(--surface)}
/* In-portfolio row */
.cam-picker-row.cpr-inport{background:color-mix(in srgb,var(--accent) 5%,var(--surface))}
.cam-picker-row.cpr-inport:hover{background:color-mix(in srgb,var(--accent) 10%,var(--surface))}
/* Marked for removal */
.cam-picker-row.cpr-marked-rem{opacity:0.55;text-decoration:line-through}
/* Marked for add */
.cam-picker-row.cpr-marked-add{background:color-mix(in srgb,var(--green) 6%,var(--surface))}
.cpr-cb-wrap{display:flex;align-items:center;justify-content:center}
.cam-picker-cb{cursor:pointer;accent-color:var(--accent);width:14px;height:14px}
.cpr-name{color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cpr{text-align:right}
.cpr-accent{color:var(--accent2)}
.cpr-plat{display:flex;align-items:center;justify-content:center;opacity:0.75}
/* Portfolio badges in picker */
.cpr-badge{
  display:inline-block;font-size:10px;font-weight:500;
  padding:2px 8px;border-radius:99px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.cpr-badge-inport{
  background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent2);
}
.cpr-badge-other{
  background:var(--surface2);border:1px solid var(--border);color:var(--text3);
}
/* Remove / Undo button in Current Portfolio cell */
.cpr-port-cell{display:flex;align-items:center;gap:6px;min-width:0}
.cpr-remove-btn{
  flex-shrink:0;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;
  font-family:inherit;cursor:pointer;transition:background 0.12s,color 0.12s,border-color 0.12s;
  background:transparent;border:1px solid var(--border2);color:var(--text3);
}
.cpr-remove-btn:hover{
  background:color-mix(in srgb,var(--red,#ef4444) 12%,transparent);
  border-color:color-mix(in srgb,var(--red,#ef4444) 40%,transparent);
  color:var(--red,#ef4444);
}
.cpr-remove-btn.cpr-remove-undoing{
  background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent2);
}
.cpr-remove-btn.cpr-remove-undoing:hover{
  background:color-mix(in srgb,var(--accent) 18%,var(--surface));
}
.cam-picker-empty{
  padding:40px 24px;text-align:center;color:var(--text3);
  font-size:13px;font-style:italic;
}
/* Footer */
.cam-picker-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;border-top:1px solid var(--border);
  flex-shrink:0;background:var(--surface2);gap:16px;
}
.cam-picker-footer-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.cam-picker-footer-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.cam-picker-count-lbl{font-size:12px;color:var(--text2);font-weight:500}
.cam-picker-warn{
  font-size:11px;color:var(--amber);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ── Step 2: Review page ── */
.cp-review-wrap{
  flex:1;overflow-y:auto;padding:20px 24px;
  display:flex;flex-direction:column;gap:12px;
}
.cp-review-section{
  border-radius:8px;border:1px solid var(--border);overflow:hidden;flex-shrink:0;
}
.cp-review-remove-sec{border-left:3px solid color-mix(in srgb,var(--red,#ef4444) 70%,transparent)}
.cp-review-move-sec  {border-left:3px solid var(--amber)}
.cp-review-add-sec   {border-left:3px solid var(--green)}
.cp-review-section-hd{
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;font-size:12px;font-weight:600;color:var(--text);
  background:var(--surface2);border-bottom:1px solid var(--border);
  cursor:pointer;user-select:none;
}
.cp-review-section-hd:hover{background:var(--surface3)}
.cp-rsec-chevron{
  margin-left:auto;flex-shrink:0;
  font-size:15px;color:var(--text3);
  display:inline-block;
  transform:rotate(90deg); /* default: open/pointing down */
  transition:transform 0.18s ease;
}
.cp-review-section-body{overflow:hidden}
.cp-review-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
}
.cp-dot-remove{background:color-mix(in srgb,var(--red,#ef4444) 80%,transparent)}
.cp-dot-move  {background:var(--amber)}
.cp-dot-add   {background:var(--green)}
.cp-review-count{
  margin-left:auto;font-size:11px;font-weight:500;color:var(--text3);
}
/* Review table rows */
.cp-review-table{width:100%;font-size:12px}
.cp-review-thead .cp-review-row{
  font-size:10px;text-transform:uppercase;letter-spacing:0.05em;
  color:var(--text3);border-bottom:1px solid var(--border);
  background:var(--surface2);cursor:default;
}
.cp-review-thead .cp-review-row:hover{background:var(--surface2)}
.cp-review-row{
  display:grid;
  grid-template-columns:minmax(120px,1fr) 72px 80px 180px 46px;
  padding:9px 16px;gap:0 8px;align-items:center;
  border-bottom:1px solid var(--border);color:var(--text2);
  transition:background 0.08s;
}
.cp-review-row:last-child{border-bottom:none}
.cp-review-row:hover{background:var(--surface2)}
.cp-review-name{
  color:var(--text);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
/* Action badge pills */
.cp-action{
  display:inline-block;
  padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.cp-action-remove{
  background:color-mix(in srgb,var(--red,#ef4444) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--red,#ef4444) 30%,transparent);
  color:var(--red,#ef4444);
}
.cp-action-move{
  background:color-mix(in srgb,var(--amber) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--amber) 30%,transparent);
  color:var(--amber);
}
.cp-action-add{
  background:color-mix(in srgb,var(--green) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--green) 30%,transparent);
  color:var(--green);
}
/* Step 2 footer summary */
.cp-review-summary{
  font-size:12px;font-weight:500;color:var(--text2);
}
/* Per-row Undo button on review page */
.cp-review-undo-btn{
  font-size:11px;font-weight:500;font-family:inherit;
  padding:2px 8px;border-radius:99px;cursor:pointer;
  background:transparent;border:1px solid var(--border2);color:var(--text3);
  transition:background 0.1s,color 0.1s,border-color 0.1s;white-space:nowrap;
}
.cp-review-undo-btn:hover{
  background:var(--surface3);border-color:var(--border);color:var(--text);
}

/* Campaign name tooltip (fixed-position, JS-driven) */
.cam-name-tooltip{
  position:fixed;z-index:9999;pointer-events:none;
  background:var(--surface3);border:1px solid var(--border);
  color:var(--text);font-size:11px;font-weight:400;font-family:inherit;
  padding:5px 9px;border-radius:6px;
  white-space:normal;word-break:break-word;
  box-shadow:0 4px 16px rgba(0,0,0,0.35);
  animation:tip-in 0.1s ease;
}
@keyframes tip-in{from{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}

/* ── Optimisation Tab — Knob Panel ──────────────────────────────────────── */
.opt-tab-wrap{padding:4px 0 8px}

/* Top bar: presets + reserve fund pill */
.opt-top-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 0 10px;gap:16px;flex-wrap:wrap;
}
.opt-presets{display:flex;gap:6px;flex-wrap:wrap}
.opt-preset-pill{
  padding:5px 14px;border-radius:20px;
  font-size:11px;font-weight:500;
  background:var(--surface2);border:1px solid var(--border);
  color:var(--text2);cursor:pointer;
  transition:background 0.12s,border-color 0.12s,color 0.12s;
}
.opt-preset-pill:hover{background:var(--surface3);color:var(--text)}
.opt-preset-pill.active{
  background:var(--accent-bg);border-color:var(--accent-border);
  color:var(--accent2);font-weight:600;
}
.opt-preset-pill.custom{border-style:dashed}
.opt-reserve-pill{
  padding:5px 14px;border-radius:20px;
  font-size:11px;font-weight:500;
  background:var(--surface2);border:1px solid var(--border);
  color:var(--text2);cursor:pointer;
  transition:background 0.12s,border-color 0.12s,color 0.12s;
}
.opt-reserve-pill:hover{background:var(--surface3);color:var(--text)}
.opt-reserve-pill.active{
  background:var(--accent-bg);border-color:var(--accent-border);
  color:var(--accent2);font-weight:600;
}
.opt-reserve-pill svg{vertical-align:-2px;margin-right:4px}

/* Strategy row */
.opt-strategy-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:12px;
}
.opt-strategy-row .field-group{display:flex;align-items:center;gap:8px}
.opt-strategy-row .field-group label{
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text3);white-space:nowrap;
}
.opt-strategy-row .field-input{width:180px;padding:5px 8px;font-size:12px}
.opt-reset-link{
  font-size:11px;color:var(--text3);cursor:pointer;
  text-decoration:none;
}
.opt-reset-link:hover{color:var(--accent2);text-decoration:underline}

/* Goal select (custom appearance) */
.goal-select{
  font-family:var(--font-ui);font-size:12px;
  background:var(--surface2);border:1px solid var(--border);color:var(--text);
  padding:5px 28px 5px 10px;border-radius:8px;cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' stroke='%237d8fbb' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 8px center;
}

/* Quad outer container */
.quad-wrap{
  background:var(--surface);border:1px solid var(--border);
  border-radius:16px;
}

/* 2×2 grid */
.quad-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px}
.quad-grid.hidden{display:none}

/* Individual panel */
.quad-panel{
  background:var(--panel-bg);border:1px solid var(--panel-border);
  border-radius:12px;padding:16px;
  box-shadow:var(--panel-inset);
}
.quad-panel-title{
  font-family:var(--font-display);
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--accent2);margin-bottom:16px;
}

/* Knob grid (default 3-col) */
.quad-knob-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px 8px;justify-items:center;
}
.quad-knob-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.quad-knob-grid.cols-5{grid-template-columns:repeat(5,1fr)}

/* Knob component */
.knob-wrap{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  user-select:none;-webkit-user-select:none;
}
.knob-label{
  font-size:9px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text3);text-align:center;
  line-height:1.2;max-width:76px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
}
.knob-value{
  font-family:'DM Mono',monospace;font-size:11px;color:var(--text);
  text-align:center;min-width:36px;
}
.knob-outer{position:relative;cursor:grab}
.knob-outer:active{cursor:grabbing}
.knob-svg{display:block}

/* SVG knob styling */
.knob-track-bg{fill:none;stroke:var(--surface3)}
.knob-track-fill{fill:none;stroke:var(--accent);filter:drop-shadow(0 0 3px var(--accent-glow));transition:stroke-dashoffset 0.1s ease-out}
.knob-pointer{stroke:var(--text);stroke-width:2;stroke-linecap:round}
.knob-ticks{opacity:0.2}
.knob-outer:hover .knob-track-fill{filter:drop-shadow(0 0 6px var(--accent-glow))}

/* Knob tooltip */
.knob-wrap[data-tip]{position:relative}
.knob-wrap[data-tip]::after{
  content:attr(data-tip);
  position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);
  background:var(--surface2);color:var(--text);border:1px solid var(--border);
  font-size:11px;line-height:1.35;padding:6px 10px;border-radius:6px;
  white-space:pre-line;width:max-content;max-width:200px;text-align:center;
  pointer-events:none;opacity:0;transition:opacity 0.15s ease;z-index:20;
  box-shadow:0 2px 8px rgba(0,0,0,0.25);
}
.knob-wrap[data-tip]:hover::after{opacity:1}

/* Personalised preset pill */
.opt-preset-pill.personalised{border-style:dashed}
.opt-preset-pill.personalised.active{
  background:var(--accent-bg);border-color:var(--accent-border);
  border-style:solid;color:var(--accent2);
}

/* Personalised confidence line */
.pers-confidence{font-size:11px;color:var(--text3);font-family:var(--font-mono);padding:0 8px;align-self:center}

/* Target inputs row below Limits knobs */
.quad-targets-row{
  display:flex;align-items:center;gap:12px;margin-top:14px;
  padding-top:12px;border-top:1px solid var(--panel-border);flex-wrap:wrap;
}
.opt-target-row{display:flex;align-items:center;gap:6px}
.opt-target-label{
  font-size:9px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text3);width:40px;flex-shrink:0;
}
.opt-target-input{
  width:50px;padding:4px 6px;font-size:11px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:6px;color:var(--text);text-align:center;
  font-family:'DM Mono',monospace;transition:border-color 0.15s;
}
.opt-target-input:focus{border-color:var(--accent);outline:none}
.opt-target-input::placeholder{color:var(--text3);opacity:0.5}
.opt-target-sep{color:var(--text3);font-size:12px}
.opt-target-suffix{font-size:10px;color:var(--text3)}

/* Reserve profile pills (in reserve panel) */
.reserve-pills{display:flex;gap:4px;justify-content:center;margin-top:10px}
.reserve-pill{
  font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;
  padding:3px 10px;border-radius:12px;
  background:var(--surface2);border:1px solid var(--border);color:var(--text3);
  cursor:pointer;transition:all 0.15s;
}
.reserve-pill:hover{background:var(--surface3);color:var(--text)}
.reserve-pill.active{
  background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent2);
}

/* ── Reserve Fund view ── */
.reserve-view{padding:12px;display:none}
.reserve-view.visible{display:block}
.reserve-chart-container{
  background:var(--panel-bg);border:1px solid var(--panel-border);
  border-radius:12px;padding:16px 20px;
  box-shadow:var(--panel-inset);
}
.reserve-chart-title{
  font-family:var(--font-display);font-size:13px;font-weight:600;margin-bottom:2px;
}
.reserve-chart-subtitle{font-size:11px;color:var(--text2);margin-bottom:12px}
.reserve-svg-wrap{width:100%;position:relative}
.reserve-svg-wrap svg{display:block;width:100%;height:auto}
.reserve-axis-labels{
  display:flex;justify-content:space-between;
  font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);
  margin-top:6px;padding:0 2px;
}
.reserve-bottom-row{display:flex;gap:12px;margin-top:14px;align-items:stretch}
.reserve-stats-strip{display:flex;gap:8px;flex-wrap:wrap;flex:1;align-content:flex-start}
.reserve-stat-chip{
  background:var(--panel-bg);border:1px solid var(--panel-border);
  border-radius:8px;padding:8px 12px;
  box-shadow:var(--panel-inset);
  display:flex;align-items:baseline;gap:6px;
  flex:1 1 auto;min-width:0;
}
.reserve-stat-label{
  font-size:9px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.06em;color:var(--text3);white-space:nowrap;
}
.reserve-stat-value{
  font-family:'DM Mono',monospace;font-size:13px;font-weight:500;
  color:var(--text);white-space:nowrap;
}
.reserve-stat-value.accent{color:var(--accent2)}
.reserve-profiles-strip{display:flex;gap:6px;flex-shrink:0}
.reserve-profile-card{
  background:var(--panel-bg);border:1px solid var(--panel-border);
  border-radius:8px;padding:8px 12px;
  box-shadow:var(--panel-inset);cursor:pointer;
  transition:all 0.15s;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  min-width:80px;
}
.reserve-profile-card:hover{border-color:var(--border2)}
.reserve-profile-card.active{border-color:var(--accent-border);background:var(--accent-bg)}
.reserve-profile-name{font-family:var(--font-display);font-size:10px;font-weight:600}
.reserve-profile-card.active .reserve-profile-name{color:var(--accent2)}
.reserve-profile-svg svg{display:block}
.opt-reserve-empty{font-size:11px;color:var(--text3);padding:8px 0}

/* ── ENGINE THEATRE (optimise animation) ───────────────────────────────── */
.et-wrap{padding:0 4px}
.et-accent{position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-grad);transition:height 0.3s}
.et-accent.processing{background:linear-gradient(90deg,var(--accent),#0d9488,#14b8a6,var(--accent));background-size:200% 100%;animation:et-shimmer 1.8s linear infinite}
.et-accent.complete{background:linear-gradient(135deg,#059669,#34d399,#059669);height:3px;animation:et-flash .6s ease}
@keyframes et-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes et-flash{0%{height:2px}50%{height:4px}100%{height:3px}}

.et-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.et-title{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-0.03em}
.et-subtitle{font-size:12px;color:var(--text3);margin-top:2px}
.et-pill{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:11px;font-weight:500;color:var(--text3);transition:all .3s}
.et-pill.active{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent2)}
.et-pill.done{background:var(--green-bg);border-color:rgba(5,150,105,0.24);color:var(--green)}
.et-pill-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.et-pill-dot.pulse{animation:et-dot-pulse 1.4s ease-in-out infinite}
@keyframes et-dot-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}

.et-progress{height:3px;background:var(--surface3);border-radius:20px;overflow:hidden;margin-bottom:12px}
.et-progress-fill{height:100%;background:var(--accent-grad);border-radius:20px;width:0%;transition:width .6s cubic-bezier(.22,1,.36,1)}

.et-pipeline{display:flex;align-items:center;margin-bottom:12px;gap:0;overflow:hidden}
.et-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative;opacity:.35;transition:opacity .3s}
.et-step.active,.et-step.done{opacity:1}
.et-step:not(:first-child)::before{content:'';position:absolute;top:11px;right:calc(50% + 12px);left:-50%;height:1px;background:var(--border2);transition:background .4s}
.et-step.done::before{background:var(--accent)}
.et-node{width:22px;height:22px;border-radius:50%;background:var(--surface3);border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--text3);transition:all .3s cubic-bezier(.22,1,.36,1);flex-shrink:0}
.et-step.active .et-node{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-bg);animation:et-ring 1.8s ease-in-out infinite}
.et-step.done .et-node{background:var(--accent);border-color:var(--accent);color:white}
@keyframes et-ring{0%,100%{box-shadow:0 0 0 4px var(--accent-bg)}50%{box-shadow:0 0 0 7px var(--accent-bg)}}
.et-step-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);white-space:nowrap}
.et-step.active .et-step-label,.et-step.done .et-step-label{color:var(--text2)}

.et-terminal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;height:148px;overflow-y:auto;overflow-x:hidden;position:relative;font-family:var(--font-mono);font-size:11.5px;scroll-behavior:smooth;margin-bottom:10px}
.et-terminal::-webkit-scrollbar{width:4px}
.et-terminal::-webkit-scrollbar-track{background:transparent}
.et-terminal::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.et-log{display:flex;gap:8px;align-items:flex-start;margin-bottom:5px;opacity:0;transform:translateY(4px);animation:et-log-in .25s cubic-bezier(.22,1,.36,1) forwards}
@keyframes et-log-in{to{opacity:1;transform:translateY(0)}}
.et-log-ts{color:var(--text3);flex-shrink:0;font-size:10.5px;margin-top:1px}
.et-log-tag{padding:1px 0;border-radius:3px;font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;flex-shrink:0;width:34px;text-align:center}
.et-tag-info{background:var(--blue-bg);color:var(--blue)}
.et-tag-ok{background:var(--green-bg);color:var(--green)}
.et-tag-warn{background:var(--amber-bg);color:var(--amber)}
.et-tag-sys{background:var(--surface3);color:var(--text3)}
.et-log-msg{color:var(--text2);line-height:1.4}
.et-log-val{color:var(--text);font-weight:500}

.et-handshake{opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s cubic-bezier(.22,1,.36,1)}
.et-handshake.visible{opacity:1;transform:translateY(0)}
.et-hs-card{background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:14px 16px}
.et-hs-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text3);margin-bottom:12px}
.et-hs-nodes{display:flex;align-items:center;gap:0}
.et-hs-node{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;width:90px}
.et-hs-icon{width:44px;height:44px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);position:relative;overflow:visible;transition:border-color .3s,box-shadow .3s,background .3s}
.et-hs-icon svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.et-hs-icon.active{border-color:var(--accent-border);box-shadow:var(--shadow),0 0 0 3px var(--accent-bg)}
.et-hs-icon.thinking{border-color:var(--amber)!important;box-shadow:var(--shadow),0 0 0 3px rgba(217,119,6,.15),0 0 16px rgba(217,119,6,.2)!important;animation:et-think .7s ease-in-out infinite alternate!important}
@keyframes et-think{from{box-shadow:var(--shadow),0 0 0 3px rgba(217,119,6,.12),0 0 12px rgba(217,119,6,.15)}to{box-shadow:var(--shadow),0 0 0 5px rgba(217,119,6,.22),0 0 22px rgba(217,119,6,.28)}}
.et-hs-icon.accepted{border-color:var(--green)!important;background:rgba(5,150,105,.06)!important;box-shadow:var(--shadow),0 0 0 3px rgba(5,150,105,.14),0 0 20px rgba(5,150,105,.22)!important;animation:et-accept-glow .6s ease forwards!important}
@keyframes et-accept-glow{0%{box-shadow:var(--shadow),0 0 0 0 rgba(5,150,105,.3)}40%{box-shadow:var(--shadow),0 0 0 8px rgba(5,150,105,.15),0 0 24px rgba(5,150,105,.2)}100%{box-shadow:var(--shadow),0 0 0 3px rgba(5,150,105,.14),0 0 20px rgba(5,150,105,.22)}}
.et-hs-icon.vetoed{border-color:var(--red)!important;box-shadow:var(--shadow),0 0 0 3px var(--red-bg),0 0 16px rgba(220,38,38,.15)!important;animation:et-shake .5s ease!important}
@keyframes et-shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-3px)}40%{transform:translateX(3px)}60%{transform:translateX(-2px)}80%{transform:translateX(1px)}}
.et-accept-ring{position:absolute;inset:0;border-radius:var(--radius);pointer-events:none;opacity:0}
.et-hs-icon.accepted .et-accept-ring{opacity:1;animation:et-accept-flash .5s ease forwards}
@keyframes et-accept-flash{0%{opacity:0;box-shadow:inset 0 0 0 2px rgba(5,150,105,.4)}50%{opacity:1;box-shadow:inset 0 0 0 2px rgba(5,150,105,.2)}100%{opacity:0}}
.et-hs-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text3)}
.et-hs-sub{font-size:10px;font-family:var(--font-mono);color:var(--text3);transition:color .3s}
.et-channel{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:0 8px;position:relative;gap:5px}
.et-ch-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);text-align:center;min-height:12px;transition:color .3s}
.et-ch-label.sending{color:var(--accent2)}.et-ch-label.thinking{color:var(--amber)}.et-ch-label.granted{color:var(--green)}.et-ch-label.vetoed{color:var(--red)}.et-ch-label.idle{color:var(--text3)}
.et-ch-track{height:2px;background:var(--border);border-radius:20px;position:relative;overflow:visible}
.et-pkt{position:absolute;top:-4px;width:9px;height:9px;border-radius:50%;opacity:0;pointer-events:none}
.et-pkt.bid{background:var(--accent);box-shadow:0 0 10px var(--accent-glow),0 0 20px var(--accent-bg)}
.et-pkt.grant{background:#059669;box-shadow:0 0 10px rgba(5,150,105,.6),0 0 22px rgba(5,150,105,.25)}
.et-trail{position:absolute;top:-1px;height:4px;border-radius:20px;opacity:0;pointer-events:none}
.et-trail.bid{background:linear-gradient(to right,transparent,var(--accent-border))}
.et-trail.grant{background:linear-gradient(to left,transparent,rgba(5,150,105,.35))}

.et-reserve-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:10px}
.et-reserve-row+.et-reserve-row{margin-top:6px}
.et-reserve-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);flex-shrink:0;width:70px}
.et-reserve-bar{flex:1;height:6px;background:var(--surface3);border-radius:20px;overflow:hidden}
.et-reserve-fill{height:100%;border-radius:20px;background:var(--accent-grad);width:0%;transition:width .8s cubic-bezier(.22,1,.36,1)}
.et-reserve-fill.depleting{background:linear-gradient(90deg,var(--amber),#f59e0b)}
.et-reserve-fill.deployed{background:linear-gradient(90deg,#059669,#34d399)}
.et-reserve-val{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text);flex-shrink:0;min-width:42px;text-align:right}

.et-roster{display:flex;flex-direction:column;gap:3px;margin-top:10px;min-height:90px}
.et-bid-row{display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:6px;font-size:11px;opacity:0;transform:translateY(4px);animation:et-log-in .25s ease forwards}
.et-bid-row.approved{background:var(--green-bg)}.et-bid-row.vetoed{background:var(--red-bg)}.et-bid-row.summary{background:var(--surface3)}
.et-bid-status{font-weight:700;flex-shrink:0;width:14px;text-align:center}
.et-bid-row.approved .et-bid-status{color:var(--green)}.et-bid-row.vetoed .et-bid-status{color:var(--red)}.et-bid-row.summary .et-bid-status{color:var(--text3)}
.et-bid-name{flex:1;font-weight:500;color:var(--text)}
.et-bid-signal{font-family:var(--font-mono);font-size:10px;color:var(--text3);flex-shrink:0}
.et-bid-amt{font-family:var(--font-mono);font-size:11px;font-weight:500;min-width:70px;text-align:right}
.et-bid-row.approved .et-bid-amt{color:var(--green)}.et-bid-row.vetoed .et-bid-amt{color:var(--red)}.et-bid-row.summary .et-bid-amt{color:var(--text3)}

.et-footer{position:relative;display:flex;align-items:center;justify-content:flex-end;margin-top:12px}
.et-skip{position:absolute;right:0;background:none;border:none;font-family:var(--font-ui);font-size:11px;color:var(--text3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s}
.et-skip:hover{color:var(--text);background:var(--surface3)}
.et-review{opacity:0;transform:translateY(6px)}
.et-review.visible{animation:et-review-in .4s cubic-bezier(.22,1,.36,1) .1s forwards}
@keyframes et-review-in{to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════════════════════════
   MAXIMISED PORTFOLIO MODE
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Maximise button in tab strip ── */
.pcard-maximise-btn{
  margin-left:auto;
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:7px;
  background:transparent;border:1px solid transparent;
  color:var(--text3);cursor:pointer;
  transition:color 0.15s,background 0.15s,border-color 0.15s;
  flex-shrink:0;padding:0;font-family:inherit;
}
.pcard-maximise-btn:hover{
  color:var(--text);background:var(--surface2);border-color:var(--border);
}
.pcard-maximise-btn.is-maximised{color:var(--accent2)}
.pcard-maximise-btn.is-maximised:hover{
  color:var(--accent);background:var(--accent-bg);border-color:var(--accent-border);
}

/* ── Body class: portfolio-maximised ── */
body.portfolio-maximised main{padding-top:56px}
body.portfolio-maximised .portfolios-above{display:none}
body.portfolio-maximised .portfolios-sticky{padding-top:0}
body.portfolio-maximised .portfolios-sticky .section-header{display:none}
body.portfolio-maximised #portfolio-action-bar{display:none}
body.portfolio-maximised .portfolio-card{display:none}
body.portfolio-maximised .portfolio-card.maximised{display:block}
body.portfolio-maximised .portfolio-card.maximised{
  min-width:0;box-shadow:none;
  margin:0;animation:none;opacity:1;
}
body.portfolio-maximised .portfolio-card.maximised .portfolio-card-header{
  min-width:0;cursor:default;
}
body.portfolio-maximised .portfolio-card.maximised .pcard-body-wrap{
  height:auto !important;overflow:visible;
}
body.portfolio-maximised .portfolio-card.maximised .portfolio-card-body{
  min-height:calc(100vh - 56px - 52px - 44px);
}
body.portfolio-maximised .portfolio-table-wrap{overflow-x:visible}
body.portfolio-maximised #panel-portfolios{padding-bottom:60px}
/* Hide totals row in maximised mode */
body.portfolio-maximised .pcard-totals{display:none !important}

/* ── Prev/Next navigation bar ── */
.maximised-nav{
  position:fixed;bottom:0;left:52px;right:0;
  height:44px;display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;background:var(--bg);
  border-top:1px solid var(--border);z-index:50;
  transition:left 0.45s cubic-bezier(0.34,1.18,0.64,1);
}
.maximised-nav-btn{
  display:flex;align-items:center;gap:8px;
  background:none;border:1px solid var(--border2);border-radius:8px;
  padding:6px 14px;cursor:pointer;
  color:var(--text2);font-size:12px;font-weight:500;
  font-family:var(--font-ui);
  transition:color 0.15s,border-color 0.15s,background 0.15s;
}
.maximised-nav-btn:hover:not(.disabled){
  color:var(--text);border-color:var(--accent-border);background:var(--surface2);
}
.maximised-nav-btn.disabled{opacity:0.3;pointer-events:none}
.maximised-nav-label{
  max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* ── Expand / shrink animation for entering / exiting maximised mode ── */
@keyframes pcard-maximise-in {
  from { transform:scale(0.92); opacity:0.7; }
  to   { transform:scale(1);    opacity:1;   }
}
@keyframes pcard-maximise-out {
  from { transform:scale(1);    opacity:1;   }
  to   { transform:scale(0.95); opacity:0.3; }
}
body.portfolio-maximised .portfolio-card.maximise-enter{
  animation:pcard-maximise-in 0.32s cubic-bezier(0.34,1.18,0.64,1) both;
}
.portfolio-card.maximise-exit{
  animation:pcard-maximise-out 0.18s ease-in both;
}
@keyframes pcard-maximise-return {
  from { transform:scale(1.04); opacity:0.6; }
  to   { transform:scale(1);    opacity:1;   }
}
.portfolio-card.maximise-return{
  animation:pcard-maximise-return 0.28s cubic-bezier(0.34,1.18,0.64,1) both;
}

/* ── Fade transition for navigating between maximised portfolios ── */
body.portfolio-maximised .portfolio-card.maximised .portfolio-card-header,
body.portfolio-maximised .portfolio-card.maximised .portfolio-card-body{
  transition:opacity 0.15s ease;
}
body.portfolio-maximised .portfolio-card.maximised .portfolio-card-header.maximised-fade,
body.portfolio-maximised .portfolio-card.maximised .portfolio-card-body.maximised-fade{
  opacity:0;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   PERFORMANCE TAB
   ═══════════════════════════════════════════════════════════════════════════════ */

.perf-tab-wrap{
  padding:20px 24px 24px;
}
.maximised .perf-tab-wrap{
  padding:20px 8px 24px;
}

/* ── KPI row ── */
.perf-kpi-row{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  margin-bottom:20px;
}
.perf-kpi{
  background:var(--surface);
  padding:12px 14px;
  text-align:center;
}
.perf-kpi-label{
  font-size:11px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:0.5px;
  margin-bottom:4px;
}
.perf-kpi-value{
  font-family:'DM Mono',monospace;
  font-size:15px;
  color:var(--text);
  font-weight:500;
}
.perf-kpi-value.green{
  color:var(--green);
}
.perf-kpi-delta{
  font-size:10px;
  font-family:'DM Mono',monospace;
  margin-left:4px;
}
.perf-kpi-up{   color:var(--green); }
.perf-kpi-down{ color:var(--red);   }

/* ── Chart controls ── */
.perf-chart-controls{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:12px;
}
.perf-metric-select-wrap{
  display:flex;
  align-items:center;
  gap:6px;
}
.perf-metric-label{
  font-size:11px;
  font-family:'DM Mono',monospace;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.5px;
  padding:2px 6px;
  border-radius:4px;
}
.perf-m1-label{
  background:color-mix(in srgb, var(--accent) 15%, transparent);
  color:var(--accent);
}
.perf-m2-label{
  background:color-mix(in srgb, var(--green) 15%, transparent);
  color:var(--green);
}
.perf-metric-select{
  font-size:12px;
  font-family:'DM Mono',monospace;
  padding:4px 8px;
  border:1px solid var(--border);
  border-radius:6px;
  background:var(--surface);
  color:var(--text);
  cursor:pointer;
  outline:none;
}
.perf-metric-select:focus{
  border-color:var(--accent);
}

/* ── Chart wrapper ── */
.perf-chart-wrap{
  position:relative;
  margin-bottom:20px;
}
.perf-chart-wrap canvas{
  display:block;
  width:100%;
  height:240px;
}
.perf-crosshair-svg{
  position:absolute;
  top:0; left:0;
  width:100%; height:100%;
  pointer-events:none;
  overflow:visible;
}
.perf-tooltip{
  display:none;
  position:absolute;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:8px;
  padding:8px 12px;
  pointer-events:none;
  min-width:140px;
  z-index:20;
  box-shadow:0 4px 12px rgba(0,0,0,0.3);
}
.perf-tt-date{
  font-size:11px;
  color:var(--text3);
  margin-bottom:4px;
  font-family:'DM Mono',monospace;
}
.perf-tt-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:12px;
  line-height:1.6;
}
.perf-tt-label{
  color:var(--text3);
}
.perf-tt-val{
  font-family:'DM Mono',monospace;
  color:var(--text);
  font-weight:500;
}
.perf-legend{
  margin-bottom:8px;
  font-size:12px;
  color:var(--text2);
}
.legend-item{
  display:flex;
  align-items:center;
  gap:6px;
}
.legend-swatch-solid{
  width:16px; height:3px;
  border-radius:2px;
}
.legend-swatch-dash{
  width:16px; height:0;
  border-top:2px dashed currentColor;
}

/* ── Below-chart grid ── */
.perf-below-chart{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.perf-section-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.5px;
  color:var(--text3);
  margin-bottom:10px;
  font-weight:600;
}

/* ── DOW heatmap ── */
.perf-dow-grid{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:4px;
}
.perf-dow-cell{
  text-align:center;
  padding:8px 4px;
  border-radius:6px;
  border:1px solid var(--border);
}
.perf-dow-label{
  font-size:10px;
  color:var(--text3);
  margin-bottom:2px;
}
.perf-dow-value{
  font-size:12px;
  font-family:'DM Mono',monospace;
  font-weight:500;
}
.perf-dow-hot{
  background:color-mix(in srgb, oklch(0.75 0.18 var(--green-ch)) 20%, var(--surface));
  border-color:color-mix(in srgb, oklch(0.75 0.18 var(--green-ch)) 40%, var(--border));
}
.perf-dow-hot .perf-dow-value{ color:var(--green); }
.perf-dow-warm{
  background:color-mix(in srgb, oklch(0.75 0.18 var(--green-ch)) 10%, var(--surface));
  border-color:color-mix(in srgb, oklch(0.75 0.18 var(--green-ch)) 20%, var(--border));
}
.perf-dow-warm .perf-dow-value{ color:var(--green); }
.perf-dow-neutral{
  background:var(--surface);
}
.perf-dow-neutral .perf-dow-value{ color:var(--text2); }
.perf-dow-cool{
  background:color-mix(in srgb, oklch(0.7 0.18 var(--amber-ch)) 10%, var(--surface));
  border-color:color-mix(in srgb, oklch(0.7 0.18 var(--amber-ch)) 20%, var(--border));
}
.perf-dow-cool .perf-dow-value{ color:oklch(0.8 0.14 var(--amber-ch)); }
.perf-dow-cold{
  background:color-mix(in srgb, oklch(0.7 0.18 var(--red-ch)) 10%, var(--surface));
  border-color:color-mix(in srgb, oklch(0.7 0.18 var(--red-ch)) 20%, var(--border));
}
.perf-dow-cold .perf-dow-value{ color:var(--red); }

/* ── Campaign contribution ── */
.perf-contrib-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:4px 12px;
  align-items:center;
  margin-bottom:6px;
}
.perf-contrib-name{
  font-size:12px;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
}
.perf-contrib-val{
  font-size:12px;
  font-family:'DM Mono',monospace;
  color:var(--text2);
  text-align:right;
  white-space:nowrap;
}
.perf-contrib-pct{
  color:var(--text3);
  font-size:10px;
}
.perf-contrib-bar-wrap{
  grid-column:1 / -1;
  height:4px;
  background:var(--border);
  border-radius:2px;
  overflow:hidden;
}
.perf-contrib-bar{
  height:100%;
  background:var(--accent);
  border-radius:2px;
  transition:width 0.5s cubic-bezier(0.22,1,0.36,1);
}
.perf-contrib-more{
  font-size:11px;
  color:var(--text3);
  margin-top:4px;
}

/* ── BUDGET CONFIRMATION POPOVER ─────────────────────────────────────────── */
.budget-confirm{
  position:fixed;z-index:100;
  width:240px;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:10px;padding:12px 14px;
  box-shadow:0 6px 24px rgba(0,0,0,0.4);
}
.budget-confirm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.budget-confirm-title{font-size:12px;font-weight:600;color:var(--text)}
.budget-confirm-close{background:none;border:none;cursor:pointer;color:var(--text3);font-size:16px;padding:0;line-height:1;transition:color 0.15s}
.budget-confirm-close:hover{color:var(--text)}
.budget-confirm-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.budget-confirm-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.budget-confirm-label{font-size:10px;text-transform:uppercase;letter-spacing:0.05em;color:var(--text3);flex-shrink:0;width:50px}
.budget-confirm-values{font-size:12px;color:var(--text2);text-align:right;font-variant-numeric:tabular-nums}
.budget-confirm-values strong{color:var(--text)}
.bc-up{color:var(--green);font-size:11px;font-weight:600}
.bc-down{color:var(--red);font-size:11px;font-weight:600}
.budget-confirm .pace-badge{font-size:9px;padding:1px 5px}
.budget-confirm-actions{display:flex;gap:6px}
.budget-confirm-actions .btn{flex:1;justify-content:center;padding:6px 0;font-size:12px}
