/* ══════════════════════════════════════════════════════════
   DRILL-DOWN PANEL SYSTEM (DEPTH_UPDATE_SPEC Phase 1)
   Slide-over panels that open on entity click — tracks, albums,
   playlists, curators, artists, cities. Max stack depth: 3.
   ══════════════════════════════════════════════════════════ */
.drill-panel-backdrop{position:fixed;inset:0;background:rgba(30,28,24,0.35);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity var(--duration-base) var(--ease);z-index:9000}
.drill-panel-backdrop.active{opacity:1;pointer-events:auto}
.drill-panel{position:fixed;top:0;right:0;height:100dvh;width:min(480px,85vw);background:var(--surface);border-left:1px solid var(--divider);box-shadow:-12px 0 48px rgba(45,42,38,0.12),-4px 0 16px rgba(45,42,38,0.06);transform:translateX(100%);transition:transform var(--duration-slow) var(--ease), 0.9, 0.3, 1), opacity var(--duration-base) var(--ease), filter var(--duration-base) var(--ease);z-index:9001;display:flex;flex-direction:column;opacity:0}
.drill-panel.active{transform:translateX(0);opacity:1}
/* Stacked panels — when a new panel opens, underlying panels shift left and dim */
.drill-panel.stacked-1{transform:translateX(-20px);opacity:var(--opacity-muted);filter:brightness(0.85)}
.drill-panel.stacked-2{transform:translateX(-40px);opacity:var(--opacity-disabled);filter:brightness(0.7)}
.drill-panel-header{padding:var(--space-5) var(--space-6) var(--space-4);border-bottom:1px solid var(--divider);flex-shrink:0;background:var(--surface)}
.drill-panel-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.drill-panel-entity-type{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-faint)}
.drill-panel-nav{display:flex;gap:var(--space-1)}
.drill-panel-nav button{background:none;border:none;width:28px;height:28px;border-radius:var(--radius);cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease);font-size:var(--text-md);line-height:1}
.drill-panel-nav button:hover{background:var(--surface-offset);color:var(--text)}
.drill-panel-nav button svg{width:16px;height:16px}
.drill-panel-title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:700;color:var(--text);line-height:1.25;letter-spacing:-0.2px;margin:0 0 4px}
.drill-panel-subtitle{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-muted);line-height:1.4}
.drill-panel-subtitle span{font-family:var(--font-mono)}
.drill-panel-body{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6) var(--space-8);-webkit-overflow-scrolling:touch}
.drill-panel-section{margin-bottom:20px}
.drill-panel-section:last-child{margin-bottom:0}
.drill-panel-section-title{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-faint);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.drill-panel-section-title-count{font-family:var(--font-mono);color:var(--text-muted);font-weight:600;letter-spacing:0}
.drill-panel-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2) var(--space-4);margin-bottom:6px}
.drill-panel-stat{display:flex;flex-direction:column;gap:var(--space-1)}
.drill-panel-stat-label{font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:0.6px;font-weight:600}
.drill-panel-stat-value{font-family:var(--font-mono);font-size:var(--text-base);color:var(--text);font-weight:600}
.drill-panel-pills{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:4px}
.drill-panel-pill{font-family:var(--font-body);font-size:var(--text-xs);padding:var(--space-1) var(--space-3);border-radius:var(--radius);background:var(--surface-offset);color:var(--text-muted);font-weight:500}
.drill-panel-pill.mood{background:var(--indigo-soft);color:var(--indigo)}
.drill-panel-list{display:flex;flex-direction:column}
.drill-panel-list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-bottom:1px solid var(--divider);cursor:pointer;transition:background var(--duration-fast) var(--ease);border-radius:var(--radius);margin:0 -10px}
.drill-panel-list-item:last-of-type{border-bottom:none}
.drill-panel-list-item:hover{background:var(--surface-offset)}
.drill-panel-list-item.non-interactive{cursor:default}
.drill-panel-list-item.non-interactive:hover{background:transparent}
.drill-panel-list-rank{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;color:var(--text-faint);width:22px;text-align:right;flex-shrink:0}
.drill-panel-list-main{flex:1;min-width:0}
.drill-panel-list-name{font-family:var(--font-body);font-size:var(--text-base);font-weight:600;color:var(--text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.drill-panel-list-sub{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);line-height:1.4;margin-top:2px;display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}
.drill-panel-list-sub span.num{font-family:var(--font-mono);color:var(--text-muted)}
.drill-panel-list-side{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);font-weight:600;flex-shrink:0;text-align:right}
.drill-panel-editorial-badge{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--indigo);color:white;letter-spacing:0.4px;text-transform:uppercase}
.drill-panel-expand-btn{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;letter-spacing:0.5px;color:var(--indigo);background:none;border:none;padding:var(--space-3) 0 var(--space-1);cursor:pointer;text-align:left;text-transform:uppercase;margin-top:4px}
.drill-panel-expand-btn:hover{text-decoration:underline}
.drill-panel-empty{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-faint);text-align:center;padding:var(--space-6) var(--space-2);font-style:italic}
.drill-panel-chart{position:relative;height:140px;margin-top:4px}
.drill-track-range-pills{display:flex;gap:3px;flex-shrink:0}
.drill-panel-loading{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-faint);letter-spacing:0.3px;padding:var(--space-3) 0}
.drill-panel-skeleton{background:linear-gradient(90deg,var(--surface-offset) 0%,var(--divider) 50%,var(--surface-offset) 100%);background-size:200% 100%;animation:drillShimmer 1.4s infinite;height:12px;border-radius:var(--radius-sm);margin-bottom:8px}
.drill-panel-skeleton.lg{height:18px;width:60%}
.drill-panel-skeleton.sm{height:10px;width:40%}
@keyframes drillShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.drill-panel-error{font-family:var(--font-body);font-size:var(--text-base);color:var(--coral);padding:var(--space-3) 0}
/* Track name click affordance in existing sections */
.cm-track-name.drillable,.cm-tt-track-name.drillable{cursor:pointer;transition:color var(--duration-fast) var(--ease)}
.cm-track-name.drillable:hover,.cm-tt-track-name.drillable:hover{color:var(--indigo)}
@media(max-width:640px){
  .drill-panel{width:100vw;border-left:none}
  .drill-panel.stacked-1{transform:translateX(-10px)}
  .drill-panel.stacked-2{transform:translateX(-20px)}
  .drill-panel-stats-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════════
   PHASE 4: Overview enrichment sections
   ══════════════════════════════════════════════════════════ */
/* Rank + Trend — compact inline card, one line */
.cm-rank-trend{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-4) var(--space-5);background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);margin-bottom:14px;box-shadow:var(--shadow-sm)}
.cm-rank-trend-main{display:flex;align-items:baseline;gap:var(--space-4);flex-shrink:0}
.cm-rank-trend-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-faint)}
.cm-rank-trend-value{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;color:var(--text);line-height:1}
.cm-rank-trend-change{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:var(--space-1)}
.cm-rank-trend-change.up{background:var(--emerald-soft);color:var(--emerald)}
.cm-rank-trend-change.down{background:var(--coral-soft);color:var(--coral)}
.cm-rank-trend-change.flat{background:var(--surface-offset);color:var(--text-muted)}
.cm-rank-trend-chart{flex:1;height:42px;min-width:100px;position:relative}
@media(max-width:640px){.cm-rank-trend{flex-wrap:wrap}.cm-rank-trend-chart{width:100%;flex-basis:100%}}

/* Platform URLs — horizontal pill row */
.cm-platform-urls{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:18px}
.cm-platform-url-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);text-decoration:none;transition:all var(--duration-fast) var(--ease);font-weight:500}
.cm-platform-url-pill:hover{background:var(--indigo-soft);border-color:var(--indigo);color:var(--indigo)}
.cm-platform-url-pill svg{width:12px;height:12px;opacity:var(--opacity-muted)}

/* Top Tracks by Platform — table-style rows */
.cm-top-tracks-platform-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius);margin:0 -6px;cursor:pointer;transition:background var(--duration-fast) var(--ease)}
.cm-top-tracks-platform-row:hover{background:var(--surface-offset)}
.cm-top-tracks-platform-row .rank{font-family:var(--font-mono);font-size:var(--text-base);font-weight:700;color:var(--text-faint);width:24px;text-align:right;flex-shrink:0}
.cm-top-tracks-platform-row .info{flex:1;min-width:0}
.cm-top-tracks-platform-row .name{font-family:var(--font-body);font-size:var(--text-base);font-weight:600;color:var(--text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-top-tracks-platform-row .meta{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);line-height:1.4;margin-top:2px}
.cm-top-tracks-platform-row .side{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--text-muted);flex-shrink:0;text-align:right}
.cm-top-tracks-platform-empty{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-faint);text-align:center;padding:var(--space-6) 0;font-style:italic}
.cm-top-tracks-platform-locked{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-muted);text-align:center;padding:var(--space-6) 0}

/* Artist Chart Appearances — compact table */
.cm-artist-charts-list{display:flex;flex-direction:column}
.cm-artist-chart-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base)}
.cm-artist-chart-row:last-child{border-bottom:none}
.cm-artist-chart-row .chart-name{flex:1;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-artist-chart-row .chart-pos{font-family:var(--font-mono);font-weight:700;color:var(--text);min-width:36px;text-align:right}
.cm-artist-chart-row .chart-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);min-width:72px;text-align:right}
.cm-artist-chart-row .chart-trend{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;min-width:20px;text-align:center}
.cm-artist-chart-row .chart-trend.up{color:var(--emerald)}
.cm-artist-chart-row .chart-trend.down{color:var(--coral)}
.cm-artist-chart-row .chart-trend.flat{color:var(--text-faint)}

/* ══════════════════════════════════════════════════════════
   PHASE 5: Playlists + Radio & Sync sub-tabs
   ══════════════════════════════════════════════════════════ */
/* Playlist Placements — richer than the Overview summary */
.cm-placement-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius);margin:0 -6px;cursor:pointer;transition:background var(--duration-fast) var(--ease);border-bottom:1px solid var(--divider)}
.cm-placement-row:last-child{border-bottom:none}
.cm-placement-row:hover{background:var(--surface-offset)}
.cm-placement-row .pl-name{flex:1;font-family:var(--font-body);font-size:var(--text-base);font-weight:600;color:var(--text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.cm-placement-row .pl-meta{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);line-height:1.4;margin-top:2px;display:flex;gap:var(--space-2);flex-wrap:wrap}
.cm-placement-row .pl-meta .num{font-family:var(--font-mono)}
.cm-placement-row .pl-main{flex:1;min-width:0}
.cm-placement-row .pl-followers{font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;color:var(--text-muted);flex-shrink:0;text-align:right}
.cm-placement-row .pl-editorial{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--indigo);color:white;letter-spacing:0.4px;text-transform:uppercase}
.cm-placement-empty{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-faint);text-align:center;padding:var(--space-6) 0;font-style:italic}
.cm-placement-locked{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-muted);text-align:center;padding:var(--space-6) 0}

/* Playlist Journey — timeline */
.cm-journey-list{display:flex;flex-direction:column;gap:0}
.cm-journey-item{display:flex;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--divider);align-items:flex-start}
.cm-journey-item:last-child{border-bottom:none}
.cm-journey-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);width:78px;flex-shrink:0;padding-top:var(--space-1)}
.cm-journey-body{flex:1;min-width:0}
.cm-journey-action{font-family:var(--font-body);font-size:var(--text-base);color:var(--text);line-height:1.4}
.cm-journey-action strong{font-weight:600}
.cm-journey-action.added{color:var(--text)}
.cm-journey-action.removed{color:var(--text-muted)}
.cm-journey-dot{width:8px;height:8px;border-radius:var(--radius-full);margin-top:6px;flex-shrink:0}
.cm-journey-dot.added{background:var(--emerald)}
.cm-journey-dot.removed{background:var(--coral)}
.cm-journey-dot.active{background:var(--indigo)}

/* Pitch Targets — grouped by curator */
.cm-pitch-curator{border:1px solid var(--divider);border-radius:var(--radius-sm);padding:var(--space-4) var(--space-4);margin-bottom:12px;background:var(--surface)}
.cm-pitch-curator-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:var(--space-3);border-bottom:1px solid var(--divider)}
.cm-pitch-curator-name{font-family:var(--font-body);font-size:var(--text-md);font-weight:700;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:var(--space-2)}
.cm-pitch-curator-name:hover{color:var(--indigo)}
.cm-pitch-curator-overlap{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;color:var(--text-muted);padding:var(--space-1) var(--space-2);background:var(--indigo-soft);border-radius:var(--radius-sm);color:var(--indigo)}
.cm-pitch-target-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--divider);cursor:pointer;transition:background var(--duration-fast) var(--ease)}
.cm-pitch-target-row:last-child{border-bottom:none}
.cm-pitch-target-row:hover{background:var(--surface-offset)}
.cm-pitch-target-name{flex:1;font-family:var(--font-body);font-size:var(--text-base);font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-pitch-target-followers{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);font-weight:600;flex-shrink:0}

/* Radio Airplay */
.cm-radio-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
@media(max-width:640px){.cm-radio-summary{grid-template-columns:1fr}}
.cm-radio-summary-stat{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);background:var(--surface-offset);border-radius:var(--radius-sm)}
.cm-radio-summary-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:var(--text-faint)}
.cm-radio-summary-value{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--text);line-height:1.1}
.cm-radio-markets-title,.cm-radio-recent-title{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px}
.cm-radio-market-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base)}
.cm-radio-market-row:last-child{border-bottom:none}
.cm-radio-market-row .market-name{flex:1;color:var(--text);font-weight:500}
.cm-radio-market-row .market-stations{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);min-width:70px;text-align:right}
.cm-radio-market-row .market-spins{font-family:var(--font-mono);font-weight:600;color:var(--text);min-width:60px;text-align:right}
.cm-radio-recent-row{display:flex;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-sm);align-items:flex-start}
.cm-radio-recent-row:last-child{border-bottom:none}
.cm-radio-recent-row .station-name{flex:1;color:var(--text);font-weight:600}
.cm-radio-recent-row .track-name{color:var(--text-muted);font-style:italic}
.cm-radio-recent-row .spin-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);min-width:72px;text-align:right;flex-shrink:0}

/* Sync Placements */
.cm-sync-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base)}
.cm-sync-row:last-child{border-bottom:none}
.cm-sync-row .sync-show{flex:1;font-weight:600;color:var(--text)}
.cm-sync-row .sync-episode{color:var(--text-muted);font-size:var(--text-sm);margin-top:2px}
.cm-sync-row .sync-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);min-width:72px;text-align:right}

/* YouTube Market Coverage */
.cm-yt-market-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base)}
.cm-yt-market-row:last-child{border-bottom:none}
.cm-yt-market-row .yt-flag{flex-shrink:0;font-size:var(--text-lg)}
.cm-yt-market-row .yt-country{flex:1;color:var(--text);font-weight:500}
.cm-yt-market-row .yt-views{font-family:var(--font-mono);font-weight:600;color:var(--text);min-width:80px;text-align:right}
.cm-yt-market-row .yt-pct{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);min-width:48px;text-align:right}

/* ══════════════════════════════════════════════════════════
   PHASE 6: Stats & Trends sub-tab
   ══════════════════════════════════════════════════════════ */
/* Time range selector — sticky at top of sub-tab */
.cm-stats-range-bar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);margin-bottom:18px;box-shadow:var(--shadow-sm)}
.cm-stats-range-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-faint)}
.cm-stats-range-buttons{display:flex;gap:var(--space-1);border:1px solid var(--divider);background:var(--surface-offset);border-radius:var(--radius-sm);padding:var(--space-1)}
.cm-stats-range-btn{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:all var(--duration-fast) var(--ease)}
.cm-stats-range-btn:hover{color:var(--text)}
.cm-stats-range-btn.active{background:var(--indigo);color:white}

/* Per-platform charts grid */
.cm-stats-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-bottom:24px}
@media(max-width:900px){.cm-stats-charts-grid{grid-template-columns:1fr}}
.cm-stats-chart-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm)}
.cm-stats-chart-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);margin-bottom:12px}
.cm-stats-chart-title{font-family:var(--font-body);font-size:var(--text-sm);font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:var(--text-faint)}
.cm-stats-chart-value-row{display:flex;align-items:baseline;gap:var(--space-3);margin-bottom:12px}
.cm-stats-chart-value{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;color:var(--text);line-height:1}
.cm-stats-chart-change{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}
.cm-stats-chart-change.up{background:var(--emerald-soft);color:var(--emerald)}
.cm-stats-chart-change.down{background:var(--coral-soft);color:var(--coral)}
.cm-stats-chart-change.flat{background:var(--surface-offset);color:var(--text-muted)}
.cm-stats-chart-canvas-wrap{position:relative;height:150px}

/* Cross-platform comparison chart */
.cm-stats-compare-chart-wrap{position:relative;height:280px}

/* Metric Movers table */
.cm-stats-movers-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
@media(max-width:640px){.cm-stats-movers-grid{grid-template-columns:1fr;gap:var(--space-5)}}
.cm-stats-movers-title{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;margin-bottom:10px}
.cm-stats-movers-title.up{color:var(--emerald)}
.cm-stats-movers-title.down{color:var(--coral)}
.cm-stats-movers-list{display:flex;flex-direction:column}
.cm-stats-mover-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--divider)}
.cm-stats-mover-row:last-child{border-bottom:none}
.cm-stats-mover-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}
.cm-stats-mover-name{flex:1;font-family:var(--font-body);font-size:var(--text-base);color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-stats-mover-abs{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);min-width:72px;text-align:right}
.cm-stats-mover-pct{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);min-width:54px;text-align:right}
.cm-stats-mover-pct.up{background:var(--emerald-soft);color:var(--emerald)}
.cm-stats-mover-pct.down{background:var(--coral-soft);color:var(--coral)}

/* ══════════════════════════════════════════════════════════
   PHASE 7: Audience sub-tab
   ══════════════════════════════════════════════════════════ */
/* Geo row styles (also used by the Pass 3 Overview audience grid —
   classes were referenced but never defined until now). */
.cm-audience-geo-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:5px;font-family:var(--font-body);font-size:var(--text-sm)}
.cm-audience-geo-flag{font-size:var(--text-md);flex-shrink:0}
.cm-audience-geo-name{color:var(--text);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-audience-geo-bar{flex:1;height:6px;background:var(--surface-offset);border-radius:var(--radius-sm);overflow:hidden;min-width:40px}
.cm-audience-geo-bar-fill{height:100%;background:var(--indigo);border-radius:var(--radius-sm);transition:width var(--duration-slow) var(--ease)}
.cm-audience-geo-pct{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);min-width:42px;text-align:right;flex-shrink:0}

/* Audience Summary header — combined across platforms */
.cm-aud-summary{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);padding:var(--space-5) var(--space-6);margin-bottom:20px;box-shadow:var(--shadow-sm)}
.cm-aud-summary-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-faint);margin-bottom:6px}
.cm-aud-summary-value{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;color:var(--text);line-height:1;margin-bottom:12px}
.cm-aud-summary-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.cm-aud-summary-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:var(--surface-offset);font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);font-weight:500}
.cm-aud-summary-pill .pill-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}
.cm-aud-summary-pill .pill-num{font-family:var(--font-mono);color:var(--text);font-weight:700}

/* Cross-Platform Geographic Compare */
.cm-aud-cross-table{border:1px solid var(--divider);border-radius:var(--radius-sm);overflow:hidden;overflow-x:auto}
.cm-aud-cross-header{display:grid;padding:var(--space-3) var(--space-3);background:var(--surface-offset);font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:var(--text-faint)}
.cm-aud-cross-row{display:grid;padding:var(--space-3) var(--space-3);border-top:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-sm);align-items:center}
.cm-aud-cross-row .country-name{color:var(--text);font-weight:500;display:flex;align-items:center;gap:var(--space-2)}
.cm-aud-cross-row .country-flag{font-size:var(--text-md)}
.cm-aud-cross-row .pct{font-family:var(--font-mono);font-weight:600;color:var(--text);text-align:right}
.cm-aud-cross-row .pct.dim{color:var(--text-faint)}

/* Enhanced Top Listener Cities */
.cm-aud-cities-controls{display:flex;align-items:center;gap:var(--space-3);margin-bottom:14px}
.cm-aud-cities-sort-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-faint)}
.cm-aud-cities-sort-buttons{display:flex;gap:var(--space-1);border:1px solid var(--divider);background:var(--surface-offset);border-radius:var(--radius-sm);padding:var(--space-1)}
.cm-aud-cities-sort-btn{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:all var(--duration-fast) var(--ease)}
.cm-aud-cities-sort-btn:hover{color:var(--text)}
.cm-aud-cities-sort-btn.active{background:var(--indigo);color:white}
.cm-aud-cities-list{display:flex;flex-direction:column}
.cm-aud-city-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius);margin:0 -6px;cursor:pointer;transition:background var(--duration-fast) var(--ease);border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base)}
.cm-aud-city-row:last-child{border-bottom:none}
.cm-aud-city-row:hover{background:var(--surface-offset)}
.cm-aud-city-row .city-rank{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;color:var(--text-faint);width:22px;text-align:right;flex-shrink:0}
.cm-aud-city-row .city-flag{font-size:var(--text-md);flex-shrink:0}
.cm-aud-city-row .city-name{flex:1;color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-aud-city-row .city-listeners{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--text);min-width:68px;text-align:right}
.cm-aud-city-row .city-affinity{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);min-width:50px;text-align:right}
@media(max-width:640px){
  .cm-aud-cities-controls{flex-direction:column;align-items:flex-start;gap:var(--space-2)}
  .cm-aud-city-row{gap:var(--space-2);padding:var(--space-3) var(--space-1)}
  .cm-aud-city-row .city-listeners{min-width:54px}
  .cm-aud-city-row .city-affinity{min-width:38px}
  .cm-aud-summary-value{font-size:var(--text-xl)}
  .cm-aud-cross-header,.cm-aud-cross-row{font-size:var(--text-xs);padding:var(--space-2) var(--space-2)}
}

/* ══════════════════════════════════════════════════════════
   PHASE 8: Tracks sub-tab
   ══════════════════════════════════════════════════════════ */
/* Filter bar */
.cm-tracks-filter-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--space-4);padding:var(--space-4) var(--space-4);background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);margin-bottom:14px;box-shadow:var(--shadow-sm)}
.cm-tracks-filter-group{display:flex;flex-direction:column;gap:var(--space-2)}
.cm-tracks-filter-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint)}
.cm-tracks-filter-pills{display:flex;gap:var(--space-1);border:1px solid var(--divider);background:var(--surface-offset);border-radius:var(--radius-sm);padding:var(--space-1)}
.cm-tracks-filter-pill{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:all var(--duration-fast) var(--ease)}
.cm-tracks-filter-pill:hover{color:var(--text)}
.cm-tracks-filter-pill.active{background:var(--indigo);color:white}
.cm-tracks-filter-search{font-family:var(--font-body);font-size:var(--text-base);padding:var(--space-2) var(--space-3);border:1px solid var(--divider);border-radius:var(--radius-sm);background:var(--surface-offset);color:var(--text);min-width:160px;width:100%}
.cm-tracks-filter-search:focus{outline:none;border-color:var(--indigo);background:var(--surface)}

/* Comparison bar */
.cm-tracks-compare-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--indigo-soft);border:1px solid var(--indigo);border-radius:var(--radius-sm);margin-bottom:14px}
.cm-tracks-compare-bar-label{font-family:var(--font-body);font-size:var(--text-base);color:var(--indigo);font-weight:600;flex:1}
.cm-tracks-compare-bar-label span{font-family:var(--font-mono);font-weight:700}
.cm-tracks-compare-btn{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-4);background:var(--indigo);color:white;border:none;border-radius:var(--radius);cursor:pointer;transition:opacity var(--duration-fast) var(--ease)}
.cm-tracks-compare-btn:hover{opacity:var(--opacity-hover)}
.cm-tracks-compare-btn.secondary{background:none;color:var(--text-muted);border:1px solid var(--divider)}
.cm-tracks-compare-btn.secondary:hover{background:var(--surface-offset);color:var(--text)}

/* Comparison card */
.cm-tracks-compare-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);padding:var(--space-5) var(--space-5);margin-bottom:18px;box-shadow:var(--shadow-sm)}
.cm-tracks-compare-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cm-tracks-compare-card-title{font-family:var(--font-body);font-size:var(--text-base);font-weight:700;color:var(--text)}
.cm-tracks-compare-close{background:none;border:none;font-size:var(--text-lg);color:var(--text-muted);cursor:pointer;padding:0 var(--space-1);line-height:1}
.cm-tracks-compare-close:hover{color:var(--text)}
.cm-tracks-compare-chart-wrap{position:relative;height:280px;margin-bottom:14px}
.cm-tracks-compare-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}
.cm-tracks-compare-summary-card{background:var(--surface-offset);border-radius:var(--radius);padding:var(--space-3) var(--space-3)}
.cm-tracks-compare-summary-name{font-family:var(--font-body);font-size:var(--text-base);font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;display:flex;align-items:center;gap:var(--space-2)}
.cm-tracks-compare-summary-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}
.cm-tracks-compare-summary-stat{font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-muted);display:flex;justify-content:space-between;padding:var(--space-1) 0}
.cm-tracks-compare-summary-stat span:last-child{font-family:var(--font-mono);color:var(--text);font-weight:600}

/* Sortable table */
.cm-tracks-table{width:100%;border-collapse:collapse;font-family:var(--font-body);font-size:var(--text-base)}
.cm-tracks-table thead th{font-size:var(--text-xs);font-weight:700;letter-spacing:0.9px;text-transform:uppercase;color:var(--text-faint);text-align:left;padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--divider);cursor:pointer;user-select:none;white-space:nowrap;transition:color var(--duration-fast) var(--ease)}
.cm-tracks-table thead th:hover{color:var(--text)}
.cm-tracks-table thead th.sorted{color:var(--indigo)}
.cm-tracks-table thead th .sort-indicator{font-family:var(--font-mono);margin-left:4px;font-size:var(--text-xs)}
.cm-tracks-table thead th.numeric,.cm-tracks-table tbody td.numeric{text-align:right;font-family:var(--font-mono)}
.cm-tracks-table thead th.checkbox-col,.cm-tracks-table tbody td.checkbox-col{width:32px;text-align:center;cursor:default}
.cm-tracks-table tbody td{padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--divider);color:var(--text)}
.cm-tracks-table tbody tr:hover{background:var(--surface-offset)}
.cm-tracks-table tbody tr.checked{background:var(--indigo-soft)}
.cm-tracks-table .track-name-cell{font-weight:600;color:var(--text);cursor:pointer;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-tracks-table .track-name-cell:hover{color:var(--indigo)}
.cm-tracks-table .track-release-date{font-family:var(--font-mono);color:var(--text-muted);font-size:var(--text-sm)}
.cm-tracks-table .track-album{color:var(--text-muted);font-size:var(--text-sm);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-tracks-table input[type="checkbox"]{cursor:pointer;accent-color:var(--indigo)}

.cm-tracks-count{font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:0.6px;font-weight:600;margin-bottom:8px;padding-bottom:var(--space-1)}
@media(max-width:900px){
  .cm-tracks-filter-bar{flex-direction:column;align-items:stretch}
  .cm-tracks-filter-group{width:100%}
  .cm-tracks-table thead th,.cm-tracks-table tbody td{padding:var(--space-2) var(--space-1);font-size:var(--text-sm)}
  .cm-tracks-table .track-name-cell{max-width:120px}
  .cm-tracks-table .track-album{max-width:80px}
}

/* ══════════════════════════════════════════════════════════
   PHASE 9: Events sub-tab — Compact Split Layout
   ══════════════════════════════════════════════════════════ */
/* Split grid: events 65% | sidebar 35% */
.cm-ev-split{display:grid;grid-template-columns:1fr 360px;gap:var(--space-5);align-items:start}
@media(max-width:900px){.cm-ev-split{grid-template-columns:1fr;gap:var(--space-3)}}
.cm-ev-split-main{min-width:0}
.cm-ev-split-side{min-width:0;position:sticky;top:0}

/* Event list — compact rows */
.cm-ev-list{display:flex;flex-direction:column}
.cm-ev-row{display:flex;align-items:flex-start;gap:14px;padding:10px 0;border-bottom:1px solid var(--divider)}
.cm-ev-row:last-child{border-bottom:none}
.cm-ev-row.affinity{background:var(--indigo-soft);border-radius:var(--radius);padding:10px 12px;margin:0 -6px;border-bottom:none}
.cm-ev-row.affinity + .cm-ev-row{border-top:1px solid var(--divider)}

/* Date block — compact */
.cm-ev-date-block{width:48px;text-align:center;flex-shrink:0}
.cm-ev-date-day{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--indigo);line-height:1}
.cm-ev-date-month{font-family:var(--font-mono);font-size:10px;color:var(--text-faint);letter-spacing:0.5px;text-transform:uppercase;margin-top:2px}
.cm-ev-date-year{font-family:var(--font-mono);font-size:10px;color:var(--text-faint)}

/* Event body */
.cm-ev-body-main{flex:1;min-width:0}
.cm-ev-name{font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--text);line-height:1.3}
.cm-ev-venue-line{font-family:var(--font-body);font-size:12px;color:var(--text-muted);margin-top:3px;line-height:1.4}
.cm-ev-meta-row{display:flex;align-items:center;gap:8px;margin-top:5px;flex-wrap:wrap}
.cm-ev-flag{font-size:14px}
.cm-ev-type{font-family:var(--font-body);font-size:10px;font-weight:600;padding:2px 7px;border-radius:var(--radius-sm);background:var(--surface-offset);color:var(--text-muted);text-transform:uppercase;letter-spacing:0.3px}
.cm-ev-affinity-badge{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-sm);background:var(--indigo);color:white;letter-spacing:0.3px}

/* Action links — inline pills, bold, visible */
.cm-ev-link-pill{display:inline-flex;align-items:center;font-family:var(--font-body);font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--radius-sm);text-decoration:none;letter-spacing:0.2px;transition:all var(--duration-fast) var(--ease);line-height:1.4}
.cm-ev-link-pill.sk{background:rgba(241,80,37,0.1);color:#f15025;border:1px solid rgba(241,80,37,0.2)}
.cm-ev-link-pill.sk:hover{background:rgba(241,80,37,0.2);border-color:rgba(241,80,37,0.4)}
.cm-ev-link-pill.venue{background:var(--surface-offset);color:var(--text-muted);border:1px solid var(--divider)}
.cm-ev-link-pill.venue:hover{background:var(--indigo-soft);color:var(--indigo);border-color:var(--indigo)}
.cm-ev-link-pill.tickets{background:var(--indigo);color:white;border:1px solid var(--indigo)}
.cm-ev-link-pill.tickets:hover{opacity:0.85}

/* Venues — compact list (replaces table for sidebar) */
.cm-ev-venues-compact{display:flex;flex-direction:column}
.cm-ev-venue-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:13px}
.cm-ev-venue-row:last-child{border-bottom:none}
.cm-ev-venue-row:hover{background:var(--surface-offset);margin:0 -8px;padding:8px 8px;border-radius:var(--radius)}
.cm-ev-venue-row .v-name{flex:1;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.cm-ev-venue-row .v-city{color:var(--text-muted);font-size:12px;flex-shrink:0}
.cm-ev-venue-row .v-count{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-faint);flex-shrink:0;min-width:18px;text-align:right}
.cm-ev-venue-row .v-link{font-size:11px;color:var(--indigo);text-decoration:none;font-weight:600;flex-shrink:0;opacity:0;transition:opacity var(--duration-fast) var(--ease)}
.cm-ev-venue-row:hover .v-link{opacity:1}

/* Tour Market Analysis */
.cm-ev-tour-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
@media(max-width:640px){.cm-ev-tour-grid{grid-template-columns:1fr;gap:var(--space-5)}}
.cm-ev-tour-title{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1.1px;text-transform:uppercase;margin-bottom:4px}
.cm-ev-tour-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base);cursor:pointer;transition:background var(--duration-fast) var(--ease)}
.cm-ev-tour-row:last-child{border-bottom:none}
.cm-ev-tour-row:hover{background:var(--surface-offset)}
.cm-ev-tour-row .flag{font-size:var(--text-md);flex-shrink:0}
.cm-ev-tour-row .city-name{flex:1;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-ev-tour-row .listeners{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--text-muted);min-width:64px;text-align:right}
.cm-ev-tour-row .affinity{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);min-width:40px;text-align:right}

/* Festivals */
.cm-ev-festivals-list{display:flex;flex-direction:column}
.cm-ev-festival-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--divider);font-family:var(--font-body);font-size:var(--text-base)}
.cm-ev-festival-row:last-child{border-bottom:none}
.cm-ev-festival-row .festival-name{flex:1;font-weight:600;color:var(--text)}
.cm-ev-festival-row .festival-loc{color:var(--text-muted);font-size:var(--text-sm)}
.cm-ev-festival-row .festival-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);min-width:80px;text-align:right}
.cm-ev-festival-row .festival-billing{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--indigo-soft);color:var(--indigo)}
@media(max-width:640px){
  .cm-ev-row{gap:6px;padding:5px 0}
  .cm-ev-date-block{width:32px}
  .cm-ev-date-day{font-size:14px}
  .cm-ev-festival-row{flex-wrap:wrap;gap:var(--space-2) var(--space-3);padding:var(--space-3) 0}
  .cm-ev-festival-row .festival-date{min-width:auto}
}

/* Co-Performers — sidebar-friendly single column */
.cm-ev-co-performers-grid{display:flex;flex-direction:column;gap:0}
.cm-ev-co-performer-card{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--divider);transition:background var(--duration-fast) var(--ease)}
.cm-ev-co-performer-card:last-child{border-bottom:none}
.cm-ev-co-performer-card:hover{background:var(--surface-offset);margin:0 -8px;padding:9px 8px;border-radius:var(--radius)}
.cm-ev-co-performer-name{font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.cm-ev-co-performer-name a:hover{color:var(--indigo) !important}
.cm-ev-co-performer-count{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);font-weight:600;flex-shrink:0;white-space:nowrap}

/* Venue count badge */
.cm-ev-count{font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:0.6px;font-weight:600;margin-bottom:6px}


/* ══════════════════════════════════════════════════════════
   PHASE 10: Brand Directory + Briefing signal cards
   ══════════════════════════════════════════════════════════ */
/* Brand filter bar */
.cm-brand-filter-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--surface-offset);border-radius:var(--radius-sm);margin-bottom:14px}
.cm-brand-filter-group{display:flex;flex-direction:column;gap:var(--space-2)}
.cm-brand-filter-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint)}
.cm-brand-filter-pills{display:flex;flex-wrap:wrap;gap:var(--space-1)}
.cm-brand-filter-pill{font-family:var(--font-body);font-size:var(--text-xs);font-weight:600;padding:var(--space-2) var(--space-3);background:var(--surface);border:1px solid var(--divider);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease)}
.cm-brand-filter-pill:hover{color:var(--text);border-color:rgba(45,106,79,0.3)}
.cm-brand-filter-pill.active{background:var(--indigo);color:white;border-color:var(--indigo)}
.cm-brand-search{font-family:var(--font-body);font-size:var(--text-base);padding:var(--space-2) var(--space-3);border:1px solid var(--divider);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);min-width:160px;width:100%}
.cm-brand-search:focus{outline:none;border-color:var(--indigo)}

/* Brand cards grid */
.cm-brand-directory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-3)}
.cm-brand-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);transition:box-shadow var(--duration-base) var(--ease), border-color var(--duration-base) var(--ease);display:flex;flex-direction:column;gap:var(--space-2)}
.cm-brand-card:hover{box-shadow:var(--shadow-sm);border-color:rgba(45,106,79,0.3)}
.cm-brand-card-name{font-family:var(--font-body);font-size:var(--text-base);font-weight:700;color:var(--text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-brand-card-category{font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;font-weight:600}
.cm-brand-card-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:4px;padding-top:var(--space-2);border-top:1px solid var(--divider)}
.cm-brand-card-affinity{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--indigo);padding:var(--space-1) var(--space-2);background:var(--indigo-soft);border-radius:var(--radius-sm)}
.cm-brand-card-link{font-family:var(--font-body);font-size:var(--text-xs);font-weight:600;color:var(--indigo);text-decoration:none}
.cm-brand-card-link:hover{text-decoration:underline}
@media(max-width:640px){
  .cm-brand-filter-bar{flex-direction:column;align-items:stretch;gap:var(--space-3)}
  .cm-brand-filter-group{width:100%}
  .cm-brand-directory-grid{grid-template-columns:1fr}
}

/* Briefing signal cards — Phase 10 additions reuse the .signal-card styles
   but with CM-specific accent colors */
.signal-card.cm-chart-activity{--signal-accent:var(--indigo)}
.signal-card.cm-new-playlist{--signal-accent:var(--emerald)}
.signal-card.cm-rank-up{--signal-accent:var(--emerald)}
.signal-card.cm-rank-down{--signal-accent:var(--coral)}
.signal-card .cm-signal-emoji{font-size:var(--text-lg);line-height:1;margin-right:6px;vertical-align:middle}

