/* ─────────────────────────────────────────────────────────────────────────
   Estilos de la página /performance.html
   - Bloque trend chart compuesto (revenue + occ + adr + revpar)
   - Bloques top/bottom unidades en grid de 2 columnas
   ─────────────────────────────────────────────────────────────────────── */

/* ── Trend chart ─────────────────────────────────────────────────────────── */

.block-trend {
  margin-bottom: 40px;
}

.trend-card {
  padding: var(--sp-5);
}

.trend-chart {
  width: 100%;
  height: 360px;
  min-height: 260px;
}

@media (max-width: 720px) {
  .trend-chart { height: 300px; }
}

@media (max-width: 480px) {
  .trend-chart { height: 240px; }
  .trend-card { padding: var(--sp-3); }
}

/* Tabla compacta debajo del chart con todos los KPIs por mes */
.trend-table {
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border-subtle);
  font-variant-numeric: tabular-nums;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.trend-table-row {
  display: grid;
  /* Métrica + N columnas (los meses). max 12 → grid auto */
  grid-template-columns: 130px repeat(auto-fit, minmax(60px, 1fr));
  gap: var(--sp-2);
  align-items: center;
  padding: var(--sp-2) var(--sp-1);
  font-size: 13px;
  color: var(--text-primary);
  border-bottom: 1px solid rgba(201, 162, 107, 0.04);
}

.trend-table-row:last-child { border-bottom: none; }

.trend-table-row--head {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
  border-bottom: 1px solid var(--border-subtle);
}

.trend-table-row .numeric,
.trend-month {
  text-align: right;
}

.trend-metric {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-weight: 600;
  color: var(--ivory);
}

.trend-table-row--head .trend-metric { color: var(--text-faint); font-weight: 600; }

.trend-swatch {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  flex-shrink: 0;
}

.trend-swatch--ghost {
  background: transparent;
}

@media (max-width: 600px) {
  .trend-table-row {
    grid-template-columns: 90px repeat(auto-fit, minmax(50px, 1fr));
    font-size: 11px;
    gap: 4px;
  }
  .trend-metric { font-size: 11px; gap: 4px; }
}

/* ── Top/Bottom unidades · grid 2 columnas ──────────────────────────────── */

.block-units {
  margin-bottom: 40px;
}

.units-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

@media (max-width: 960px) {
  .units-grid { grid-template-columns: 1fr; gap: 16px; }
}

.units-card {
  padding: 0;            /* el header tiene su propio padding y la tabla también */
  overflow: hidden;
}

.units-card-header {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
}

.units-card-header--top {
  background: linear-gradient(90deg,
    rgba(80, 200, 120, 0.08) 0%,
    rgba(80, 200, 120, 0.0) 100%);
  border-left: 3px solid #50C878;   /* verde · top performers */
}

.units-card-header--bottom {
  background: linear-gradient(90deg,
    rgba(255, 56, 92, 0.08) 0%,
    rgba(255, 56, 92, 0.0) 100%);
  border-left: 3px solid #FF385C;   /* coral · bottom (oportunidad) */
}

.units-card-title {
  font-size: var(--type-caption);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gold-bright);
}

.units-card-sub {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

/* Tabla de unidades ─────────────────────────────────────────────────────── */

.units-table {
  display: flex;
  flex-direction: column;
  font-variant-numeric: tabular-nums;
}

.units-table-head,
.units-table-row {
  display: grid;
  grid-template-columns: 1fr 0.7fr 1fr 1.2fr;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-3) var(--sp-5);
}

.units-table-head {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
  border-bottom: 1px solid var(--border-subtle);
}

.units-table-head span:not(:first-child),
.units-table-row .units-num {
  text-align: right;
}

.units-table-row {
  font-size: 14px;
  color: var(--text-primary);
  border-bottom: 1px solid rgba(201, 162, 107, 0.04);
  transition: background var(--dur-quick) var(--ease-out);
}

.units-table-row:last-child {
  border-bottom: none;
}

.units-table-row:hover {
  background: rgba(201, 162, 107, 0.04);
}

.units-name {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}

.units-name-number {
  font-weight: 700;
  color: var(--ivory);
  font-size: 15px;
}

.units-revenue {
  font-weight: 600;
  color: var(--ivory);
}

.units-empty {
  padding: var(--sp-5);
  text-align: center;
  color: var(--text-faint);
  font-style: italic;
}

/* Mobile: tabla más compacta */
@media (max-width: 600px) {
  .units-table-head,
  .units-table-row {
    grid-template-columns: 1fr 0.6fr 1fr 1.2fr;
    padding: var(--sp-2) var(--sp-3);
    gap: var(--sp-2);
    font-size: 12px;
  }
  .units-name-number { font-size: 13px; }
  .units-card-header { padding: var(--sp-3) var(--sp-3); }
}
