/* ============================================================================
   League Tables Dashboard — V2 Stylesheet
   Depends on: app-shell.css (base variables, .btn, .v2-card, typography)
   ============================================================================ */

/* -- Local tokens (extend shell palette) ----------------------------------- */
:root {
  --lt-border: var(--border, #1e2433);
  --lt-muted: var(--muted, #ADADAD);
  --lt-bg: var(--bg, #0b0e13);
  --lt-card: var(--bg-elev, #111520);
  --lt-accent: var(--accent, #0964A0);
  --lt-positive: var(--success, #1fa971);
  --lt-negative: var(--danger, #e05b5b);
  --lt-warn: var(--warning, #e2b534);
  --lt-text: var(--text, #e6e9f0);
  --lt-text-strong: var(--text-strong, #E8F2F9);
  --lt-radius: 6px;
}

/* -- Page container — mirrors .mm-page from Market Movers ----------------- */
.lt-page {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  color: var(--lt-text);
  font-size: 13px;
}

/* -- Universe Bar ---------------------------------------------------------- */
.lt-universe-bar {
  flex-shrink: 0;
  border-bottom: 1px solid var(--lt-border);
}
.lt-universe-bar:empty {
  display: none;
}

/* -- Header ---------------------------------------------------------------- */
.lt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  border-bottom: 1px solid var(--lt-border);
  flex-shrink: 0;
  gap: 12px;
}
.lt-header__left h1 {
  font-size: 16px;
  font-weight: 700;
  margin: 0;
  color: var(--lt-text-strong);
}
.lt-header__breadcrumb {
  font-size: 11px;
  color: var(--lt-muted);
  margin-top: 1px;
}
.lt-header__search {
  position: relative;
  width: 260px;
  flex-shrink: 0;
}
.lt-header__search input {
  width: 100%;
  /* box-sizing: without this, the 30px/10px horizontal padding + 1px borders
     push the rendered input ~42px past its 260px wrapper, so the search
     overflows the header on the right edge. */
  box-sizing: border-box;
  padding: 6px 10px 6px 30px;
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  background: var(--lt-card);
  color: var(--lt-text);
  font-size: 12px;
  outline: none;
  transition: border-color .15s;
}
.lt-header__search input:focus {
  border-color: var(--lt-accent);
}
.lt-header__search i {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  color: var(--lt-muted);
  pointer-events: none;
}

/* -- Controls -------------------------------------------------------------- */
.lt-controls {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--lt-border);
  flex-shrink: 0;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.lt-controls__share {
  margin-left: auto;
  display: flex;
  align-items: center;
}
.lt-control-group {
  display: flex;
  align-items: center;
  gap: 4px;
}
.lt-control-group label {
  font-size: 11px;
  color: var(--lt-muted);
  margin-right: 4px;
  white-space: nowrap;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Button-group toggles */
.lt-btn-group {
  display: inline-flex;
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  overflow: hidden;
}
.lt-btn-group .lt-btn {
  border: none;
  border-right: 1px solid var(--lt-border);
  border-radius: 0;
}
.lt-btn-group .lt-btn:last-child { border-right: none; }

.lt-btn {
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  background: var(--lt-card);
  color: var(--lt-muted);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.lt-btn:hover {
  color: var(--lt-text);
  background: color-mix(in srgb, var(--lt-accent) 15%, var(--lt-card));
}
.lt-btn.active {
  background: var(--lt-accent);
  color: #fff;
  border-color: var(--lt-accent);
}

/* Select dropdown */
.lt-select {
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 600;
  background: var(--lt-card);
  color: var(--lt-text);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  cursor: pointer;
  outline: none;
}
.lt-select:focus { border-color: var(--lt-accent); }

/* Pill toggles */
.lt-pills {
  display: inline-flex;
  gap: 4px;
}
.lt-pill {
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 999px;
  background: var(--lt-card);
  color: var(--lt-muted);
  border: 1px solid var(--lt-border);
  cursor: pointer;
  transition: all .15s;
}
.lt-pill:hover { color: var(--lt-text); }
.lt-pill.active {
  background: color-mix(in srgb, var(--lt-accent) 20%, var(--lt-card));
  color: var(--lt-text-strong);
  border-color: var(--lt-accent);
}

/* -- KPI Row --------------------------------------------------------------- */
.lt-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 10px 16px;
  flex-shrink: 0;
}
.lt-kpi {
  background: var(--lt-card);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.lt-kpi__label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--lt-muted);
}
.lt-kpi__value {
  font-size: 22px;
  font-weight: 700;
  color: var(--lt-text-strong);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}

/* -- Charts Row ------------------------------------------------------------ */
.lt-charts {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  gap: 10px;
  padding: 0 16px 10px;
  height: 250px;
  min-height: 250px;
  max-height: 250px;
  flex-shrink: 0;
  flex-shrink: 0;
}
.lt-chart-card {
  background: var(--lt-card);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.lt-chart-card__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--lt-muted);
  padding: 8px 12px 0;
  flex-shrink: 0;
}
.lt-chart-card__body {
  flex: 1;
  min-height: 0;
}

/* Recent entrants list inside chart card */
.lt-recent-entrants {
  flex: 1;
  overflow-y: auto;
  font-size: 12px;
}
.lt-recent-entrants table {
  width: 100%;
  border-collapse: collapse;
}
.lt-recent-entrants thead {
  position: sticky;
  top: 0;
  z-index: 1;
}
.lt-recent-entrants th {
  background: var(--lt-card);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--lt-muted);
  padding: 6px 10px;
  text-align: left;
  border-bottom: 1px solid var(--lt-border);
}
.lt-recent-entrants td {
  padding: 5px 10px;
  border-bottom: 1px solid var(--lt-border);
  color: var(--lt-text);
  font-variant-numeric: tabular-nums;
}

/* -- Grid section ---------------------------------------------------------- */
.lt-grid-section {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  padding: 0 16px 10px;
}
.lt-grid-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
  flex-shrink: 0;
}
.lt-grid-toolbar__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--lt-muted);
}
.lt-grid-container {
  height: 600px;
  border-radius: var(--lt-radius);
  overflow: hidden;
}

/* AG Grid overrides (balham) */
.lt-grid-container .ag-theme-balham {
  --ag-background-color: var(--lt-card);
  --ag-header-background-color: color-mix(in srgb, var(--lt-card) 90%, #000);
  --ag-odd-row-background-color: var(--lt-bg);
  --ag-row-hover-color: color-mix(in srgb, var(--lt-accent) 8%, var(--lt-card));
  --ag-selected-row-background-color: color-mix(in srgb, var(--lt-accent) 15%, var(--lt-card));
  --ag-border-color: var(--lt-border);
  --ag-header-foreground-color: var(--lt-muted);
  --ag-foreground-color: var(--lt-text);
  --ag-font-size: 12px;
  --ag-row-height: 36px;
  --ag-header-height: 34px;
  --ag-cell-horizontal-padding: 8px;
  width: 100%;
  height: 100%;
}
.lt-grid-container .ag-header-cell-label {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: .04em;
}
.lt-grid-container .ag-row { cursor: pointer; }

/* Cell renderers */
.lt-name-cell { line-height: 1.25; }
.lt-name-cell__name {
  font-weight: 600;
  color: var(--lt-text-strong);
  font-size: 12px;
}
.lt-name-cell__issuer {
  font-size: 10px;
  color: var(--lt-muted);
}
/* Sponsor badge — shield icon + pill label */
.lt-sponsor-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px 2px 5px;
  border-radius: 999px;
  background: color-mix(in srgb, #e2a634 14%, transparent);
  border: 1px solid color-mix(in srgb, #e2a634 30%, transparent);
  font-size: 10px;
  font-weight: 700;
  color: #e2a634;
  letter-spacing: .02em;
  text-transform: uppercase;
  line-height: 1;
  white-space: nowrap;
}
.lt-sponsor-badge__icon {
  width: 14px;
  height: 14px;
  fill: #e2a634;
  flex-shrink: 0;
}

/* Act/Pas split — labels flanking a gradient bar */
.lt-split {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  padding-right: 4px;
}
.lt-split__label {
  font-size: 10px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  min-width: 26px;
  text-align: center;
  flex-shrink: 0;
}
.lt-split__label--active {
  color: var(--lt-warn);
}
.lt-split__label--passive {
  color: var(--lt-positive);
}
.lt-split__bar {
  flex: 1;
  display: flex;
  height: 8px;
  border-radius: 4px;
  overflow: hidden;
  background: var(--lt-border);
}
.lt-split__seg {
  height: 100%;
  transition: width .3s;
}
.lt-split__seg--active {
  background: linear-gradient(90deg, #d4942a, #e2b534);
  border-radius: 4px 0 0 4px;
}
.lt-split__seg--passive {
  background: linear-gradient(90deg, #1a8a5c, #1fa971);
  border-radius: 0 4px 4px 0;
}

.lt-split--ac {
  padding: 0 8px;
  height: 100%;
  display: flex;
  align-items: center;
}

/* Asset class bar segments */
.lt-split__seg--equity {
  background: #3b82f6;
}
.lt-split__seg--fixed {
  background: #10b981;
}
.lt-split__seg--other {
  background: #94a3b8;
}
.lt-split__label--equity { color: #3b82f6; }
.lt-split__label--other  { color: #94a3b8; }

/* Legend above grid */
.lt-grid-legend {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  color: var(--lt-muted);
}
.lt-grid-legend__item {
  display: flex;
  align-items: center;
  gap: 4px;
}
.lt-grid-legend__sep {
  width: 1px;
  height: 12px;
  background: var(--lt-border);
  margin: 0 2px;
}
.lt-swatch {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
}
.lt-swatch--equity  { background: #3b82f6; }
.lt-swatch--fixed   { background: #10b981; }
.lt-swatch--other   { background: #94a3b8; }
.lt-swatch--active  { background: linear-gradient(90deg, #d4942a, #e2b534); }
.lt-swatch--passive { background: linear-gradient(90deg, #1a8a5c, #1fa971); }

.lt-badge-new {
  display: inline-block;
  padding: 1px 6px;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  background: color-mix(in srgb, var(--lt-accent) 20%, transparent);
  color: var(--lt-accent);
}

/* -- Profile Drawer -------------------------------------------------------- */
.lt-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 900;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.lt-drawer-backdrop.open {
  opacity: 1;
  pointer-events: auto;
}
.lt-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(420px, 90vw);
  background: var(--lt-card);
  border-left: 1px solid var(--lt-border);
  z-index: 901;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .25s cubic-bezier(.4, 0, .2, 1);
  overflow: hidden;
}
.lt-drawer.open { transform: translateX(0); }

.lt-drawer__header {
  padding: 16px;
  border-bottom: 1px solid var(--lt-border);
  flex-shrink: 0;
}
.lt-drawer__header-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 8px;
}
.lt-drawer__badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.lt-drawer__badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  background: color-mix(in srgb, var(--lt-accent) 15%, transparent);
  color: var(--lt-accent);
  text-transform: uppercase;
  letter-spacing: .03em;
}
.lt-drawer__badge--sponsor {
  background: color-mix(in srgb, var(--lt-positive) 15%, transparent);
  color: var(--lt-positive);
}
.lt-drawer__close {
  background: none;
  border: none;
  color: var(--lt-muted);
  font-size: 16px;
  cursor: pointer;
  padding: 4px;
  line-height: 1;
}
.lt-drawer__close:hover { color: var(--lt-text); }
.lt-drawer__name {
  font-size: 18px;
  font-weight: 700;
  color: var(--lt-text-strong);
  margin: 0;
}
.lt-drawer__issuer {
  font-size: 12px;
  color: var(--lt-muted);
  margin-top: 2px;
}

.lt-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
}
.lt-drawer__section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--lt-muted);
  margin: 16px 0 8px;
}
.lt-drawer__section-title:first-child { margin-top: 0; }

.lt-drawer__kpis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.lt-drawer__kpi {
  background: var(--lt-bg);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius);
  padding: 8px 10px;
}
.lt-drawer__kpi-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--lt-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.lt-drawer__kpi-value {
  font-size: 16px;
  font-weight: 700;
  color: var(--lt-text-strong);
  font-variant-numeric: tabular-nums;
}

.lt-drawer__chart {
  height: 120px;
  margin-top: 8px;
}

.lt-drawer__footer {
  padding: 12px 16px;
  border-top: 1px solid var(--lt-border);
  flex-shrink: 0;
}
.lt-drawer__footer .btn {
  width: 100%;
  justify-content: center;
}

/* Utility: positive/negative coloring */
.lt-positive { color: var(--lt-positive); }
.lt-negative { color: var(--lt-negative); }

/* Loading states */
.lt-loading-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--lt-muted);
  font-size: 13px;
  min-height: 120px;
}
.lt-loading-placeholder .lt-spinner {
  width: 22px;
  height: 22px;
  border: 3px solid var(--lt-border);
  border-top-color: var(--lt-accent);
  border-radius: 50%;
  animation: lt-spin .8s linear infinite;
}
@keyframes lt-spin { to { transform: rotate(360deg); } }

.lt-empty-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  color: var(--lt-muted);
  font-size: 12px;
  min-height: 120px;
  padding: 16px;
  text-align: center;
}
.lt-empty-placeholder i {
  font-size: 22px;
  opacity: 0.5;
}

.lt-kpis.is-loading .lt-kpi__value,
.lt-chart-card__body.is-loading,
.lt-grid-container.is-loading {
  opacity: .35;
  pointer-events: none;
  transition: opacity .2s;
}
