/* ─────────────────────────────────────────────────────────────────
   Components — Singolare · OS
   Paleta y jerarquía Biwiser editorial.
   ───────────────────────────────────────────────────────────────── */

/* ─── Section header ─── */
.section {
  margin-bottom: var(--sp-9);
}

.section__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-5);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--color-ink);
}

.section__eyebrow {
  display: block;
  margin-bottom: var(--sp-3);
}

.section__title {
  font-family: var(--font-display);
  font-size: var(--fs-action);
  font-weight: var(--fw-regular);
  letter-spacing: -0.012em;
  color: var(--color-ink);
  line-height: 1.06;
}

.section__title em {
  font-style: italic;
  color: var(--color-copper);
  font-weight: var(--fw-regular);
}

.section__hint {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-subtitle);
  color: var(--color-graphite);
  flex-shrink: 0;
}

/* ─── Hero (intro de pestaña) — composición editorial — */
.hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-9);
  margin-bottom: var(--sp-9);
  padding-bottom: var(--sp-7);
  border-bottom: 1px solid var(--color-line);
  align-items: end;
}

.hero__copy {
  max-width: 36ch;
}

.hero__copy h1 {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  font-weight: var(--fw-regular);
  line-height: 1.04;
  letter-spacing: -0.018em;
  margin-bottom: var(--sp-5);
  color: var(--color-ink);
}

.hero__copy h1 em {
  font-style: italic;
  color: var(--color-copper);
}

.hero__lede {
  font-size: var(--fs-body-lg);
  color: var(--color-graphite);
  line-height: 1.5;
  font-weight: var(--fw-regular);
}

.hero__sidekpi {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  align-items: flex-start;
}

.hero__sidekpi-label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
}

.hero__sidekpi-value {
  font-family: var(--font-body);
  font-size: var(--fs-kpi-hero);
  font-weight: var(--fw-bold);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  color: var(--color-ink);
  letter-spacing: -0.04em;
  margin: 0;
}

.hero__sidekpi-foot {
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  max-width: 32ch;
  line-height: 1.45;
}

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; gap: var(--sp-6); }
}

/* ─── Lectura editorial (bloque IA) ─── */
.lectura {
  background: var(--color-bg-subtle);
  border-left: 3px solid var(--color-ink);
  padding: var(--sp-6) var(--sp-6) var(--sp-6) var(--sp-6);
  margin-bottom: var(--sp-9);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-5);
}

.lectura__seal {
  width: 36px;
  height: 36px;
  border: 1px solid var(--color-ink);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 14px;
  color: var(--color-ink);
  flex-shrink: 0;
}

.lectura__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--sp-3);
}

.lectura__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline);
  font-style: italic;
  font-weight: var(--fw-regular);
  color: var(--color-ink);
}

.lectura__tag {
  font-family: var(--font-body);
  font-size: var(--fs-metadata);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
}

.lectura__body p {
  font-size: var(--fs-body);
  color: var(--color-body);
  line-height: 1.6;
  margin-bottom: var(--sp-3);
}
.lectura__body p:last-child { margin-bottom: 0; }
.lectura__body strong {
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
}

/* ─── KPI strip ─── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-ink);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--sp-9);
}

.kpi-grid--3 { grid-template-columns: repeat(3, 1fr); }

.kpi {
  padding: var(--sp-5) var(--sp-5) var(--sp-5) 0;
  border-right: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.kpi:first-child { padding-left: 0; }
.kpi:last-child { border-right: 0; padding-right: 0; }
.kpi:not(:first-child) { padding-left: var(--sp-5); }

.kpi__label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
}

.kpi__value {
  font-family: var(--font-body);
  font-size: var(--fs-kpi-strip);
  font-weight: var(--fw-bold);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  color: var(--color-ink);
  margin-top: var(--sp-3);
}

.kpi__sub {
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  margin-top: var(--sp-2);
  line-height: 1.45;
}

@media (max-width: 900px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .kpi { border-bottom: 1px solid var(--color-line); }
  .kpi:nth-child(2) { border-right: 0; padding-right: 0; }
  .kpi:nth-child(3) { padding-left: 0; }
}

/* ─── Card ─── */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  padding: var(--sp-5);
  border-radius: 0;
}

.card__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline);
  font-style: italic;
  font-weight: var(--fw-regular);
  color: var(--color-ink);
  margin-bottom: var(--sp-2);
}

.card__sub {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  margin-bottom: var(--sp-4);
}

/* ─── Bar list (top X) ─── */
.bar-list {
  display: flex;
  flex-direction: column;
}

.bar-list__row {
  display: grid;
  grid-template-columns: minmax(140px, 1.4fr) minmax(80px, 2.5fr) auto;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--color-line);
}

.bar-list--compact .bar-list__row {
  grid-template-columns: minmax(150px, 1.6fr) minmax(60px, 1fr) auto;
}
.bar-list__row:last-child { border-bottom: 0; }

.bar-list__label {
  font-size: var(--fs-body);
  color: var(--color-ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: var(--fw-regular);
}

.bar-list__bar {
  position: relative;
  height: 6px;
  background: var(--color-bg-subtle);
  border-radius: 0;
  overflow: hidden;
}

.bar-list__bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--color-ink);
}

.bar-list__bar-fill--copper { background: var(--color-copper); }
.bar-list__bar-fill--amber { background: var(--color-amber); }
.bar-list__bar-fill--forest { background: var(--color-forest); }
.bar-list__bar-fill--singolare { background: var(--color-singolare); }

.bar-list__value {
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-body);
  color: var(--color-ink);
  text-align: right;
  font-weight: var(--fw-medium);
}

.bar-list__row .delta { margin-left: 8px; }

/* ─── Tabla densa ─── */
.tbl {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-body);
}

.tbl thead th {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--color-ink);
}

.tbl tbody td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--color-line);
  vertical-align: middle;
  color: var(--color-ink);
}

.tbl tbody tr:hover td {
  background: var(--color-bg-subtle);
}

.tbl td.num, .tbl th.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.tbl td.label-strong { font-weight: var(--fw-medium); color: var(--color-ink); }

/* ─── Plan vs Real Canal grid ─── */
.canal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
@media (max-width: 1100px) { .canal-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px)  { .canal-grid { grid-template-columns: 1fr; } }

.canal-card {
  border-top: 1px solid var(--color-ink);
  padding: var(--sp-4) 0 0;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.canal-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
}

.canal-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-regular);
  color: var(--color-ink);
}

.canal-card__share {
  font-family: var(--font-body);
  font-size: var(--fs-metadata);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-graphite);
}

.canal-card__numbers {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp-3);
  align-items: baseline;
}

.canal-card__numbers .label {
  font-family: var(--font-body);
  font-size: var(--fs-metadata);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-graphite);
  display: block;
  margin-bottom: 2px;
}

.canal-card__numbers .value {
  font-family: var(--font-body);
  font-size: 28px;
  font-weight: var(--fw-bold);
  font-variant-numeric: tabular-nums;
  color: var(--color-ink);
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.canal-card__numbers .value.delta--pos { color: var(--color-pos); }
.canal-card__numbers .value.delta--neg { color: var(--color-neg); }

.canal-card__chart-wrap { margin-top: var(--sp-2); }

.canal-card__foot {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}

/* ─── Canales · personalidad (mix bar apilada por canal) ─── */
.canal-rows { display: flex; flex-direction: column; gap: var(--sp-5); margin-bottom: var(--sp-5); }

.canal-row {
  display: flex; flex-direction: column; gap: var(--sp-2);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--color-line);
}
.canal-row:first-child { border-top: 1px solid var(--color-ink); padding-top: var(--sp-4); }

.canal-row__header {
  display: flex; justify-content: space-between; align-items: baseline; gap: var(--sp-3);
}
.canal-row__name {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-regular);
  color: var(--color-ink);
  margin-right: var(--sp-3);
}
.canal-row__amount {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
}

.tipo-tag { font-size: 9px; }
.tipo--ink       { border-color: var(--color-ink); color: var(--color-ink); }
.tipo--singolare { border-color: var(--color-singolare); color: var(--color-singolare); }
.tipo--copper    { border-color: var(--color-copper); color: var(--color-copper); }
.tipo--amber     { border-color: var(--color-amber); color: var(--color-amber); }
.tipo--graphite  { border-color: var(--color-graphite); color: var(--color-graphite); }

.mix-bar {
  display: flex;
  width: 100%;
  height: 32px;
  overflow: hidden;
  background: var(--color-bg-subtle);
}
.mix-bar__seg {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  transition: filter 120ms ease;
}
.mix-bar__seg:hover { filter: brightness(1.05); }

.mix-bar__seg--nuevas       { background: var(--color-singolare); color: white; }
.mix-bar__seg--continuidad  { background: var(--color-forest-text); color: white; }
.mix-bar__seg--anteriores   { background: var(--color-amber); color: white; }
.mix-bar__seg--marca        { background: var(--color-copper); color: white; }
.mix-bar__seg--unknown      { background: var(--color-tenue); color: var(--color-graphite); }

.mix-bar__seg-label {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}

.mix-legend {
  display: flex;
  gap: var(--sp-5);
  flex-wrap: wrap;
  margin-top: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--color-line);
}
.mix-legend__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}
.mix-legend__dot {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 2px;
  flex-shrink: 0;
}
.mix-legend__dot.mix-bar__dot--nuevas      { background: var(--color-singolare); }
.mix-legend__dot.mix-bar__dot--continuidad { background: var(--color-forest-text); }
.mix-legend__dot.mix-bar__dot--anteriores  { background: var(--color-amber); }
.mix-legend__dot.mix-bar__dot--marca       { background: var(--color-copper); }
.mix-legend__dot.mix-bar__dot--unknown     { background: var(--color-tenue); }

/* ─── Canales · eficiencia bar inline (en tabla) ─── */
.eff-bar {
  width: 100%;
  height: 6px;
  background: var(--color-bg-subtle);
  position: relative;
}
.eff-bar__fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--color-ink);
}

/* ─── Canales · plan vs real bars (centradas en 0) ─── */
.plan-stack { display: flex; flex-direction: column; gap: var(--sp-3); }

.plan-row {
  display: grid;
  grid-template-columns: minmax(140px, 1.1fr) 2.5fr minmax(70px, auto) minmax(180px, auto);
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--color-line);
}
.plan-row__label {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--color-ink);
  font-weight: var(--fw-regular);
}
.plan-bar {
  position: relative;
  height: 18px;
  background: var(--color-bg-subtle);
}
.plan-bar__axis {
  position: absolute;
  left: 50%; top: -2px; bottom: -2px;
  width: 1px;
  background: var(--color-ink);
}
.plan-bar__fill {
  position: absolute;
  top: 2px; bottom: 2px;
}
.plan-bar__fill--pos { background: var(--color-forest-text); }
.plan-bar__fill--neg { background: var(--color-terracotta-text); }

.plan-row__var {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.plan-row__amount {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
  text-align: right;
}

/* ─── SKU Explorer · controles ─── */
.sku-controls {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  padding: var(--sp-4) 0;
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.sku-controls__row {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--sp-4);
}
.sku-search {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  border: 1px solid var(--color-line-strong);
  background: var(--color-surface);
  color: var(--color-ink);
  border-radius: 0;
  outline: none;
  transition: border-color 120ms ease;
}
.sku-search:focus { border-color: var(--color-ink); }
.sku-search::placeholder { color: var(--color-muted-2); font-style: italic; }

.sku-select {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  border: 1px solid var(--color-line-strong);
  background: var(--color-surface);
  color: var(--color-ink);
  border-radius: 0;
  outline: none;
  cursor: pointer;
  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 fill='none' stroke='%231F2826' stroke-width='1.4' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
}

.sku-controls__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.sku-controls__group-label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
  margin-right: var(--sp-3);
}
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  border: 1px solid var(--color-line-strong);
  background: transparent;
  color: var(--color-graphite);
  cursor: pointer;
  border-radius: 999px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  transition: all 120ms ease;
}
.chip:hover { border-color: var(--color-ink); color: var(--color-ink); }
.chip--active {
  background: var(--color-ink);
  border-color: var(--color-ink);
  color: var(--color-bg);
}
.chip__count {
  font-size: 10px;
  font-variant-numeric: tabular-nums;
  opacity: 0.7;
}
.chip--active .chip__count { opacity: 0.95; }

/* ─── SKU Explorer · tabla ─── */
.sku-table-wrap {
  margin-top: var(--sp-2);
  width: 100%;
  overflow-x: auto;
}
.tbl-sku { font-size: 13px; }
.tbl-sku tbody td { padding: var(--sp-2) var(--sp-3); white-space: nowrap; }
.tbl-sku thead th { padding: var(--sp-3) var(--sp-3); white-space: nowrap; }
.sku-row { cursor: pointer; transition: background 80ms ease; }
.sku-row:hover td { background: var(--color-bg-subtle); }
.sku-row__desc {
  display: block;
  font-size: 11px;
  color: var(--color-graphite);
  font-weight: var(--fw-regular);
  margin-top: 1px;
}
.sku-table__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-4) 0;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}
.sku-load-more {
  padding: 8px 18px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  letter-spacing: 0.06em;
  background: transparent;
  border: 1px solid var(--color-ink);
  color: var(--color-ink);
  cursor: pointer;
  border-radius: 0;
  transition: all 120ms ease;
}
.sku-load-more:hover { background: var(--color-ink); color: var(--color-bg); }

/* Pills de status (decisión) */
.pill-status {
  min-width: 100px;
  font-weight: var(--fw-medium);
}
.pill-status--neg     { background: var(--color-neg-soft); color: var(--color-neg); border-color: transparent; }
.pill-status--warn    { background: var(--color-warn-soft); color: var(--color-warn); border-color: transparent; }
.pill-status--amber   { background: var(--color-warn-soft); color: var(--color-amber); border-color: transparent; }
.pill-status--pos     { background: var(--color-pos-soft); color: var(--color-pos); border-color: transparent; }
.pill-status--neutral { background: var(--color-bg-subtle); color: var(--color-graphite); border-color: var(--color-line); }
.pill-status--unknown { background: transparent; color: var(--color-muted-2); border-color: var(--color-line); }

/* Decision cards (sección 01 SKU) */
.decision-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
@media (max-width: 1100px) { .decision-grid { grid-template-columns: 1fr; } }

.decision-card {
  border-top: 3px solid var(--color-ink);
  padding: var(--sp-5) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.decision-card--neg  { border-top-color: var(--color-terracotta-text); }
.decision-card--warn { border-top-color: var(--color-amber); }
.decision-card--pos  { border-top-color: var(--color-forest-text); }

.decision-card__head { display: flex; align-items: baseline; gap: var(--sp-3); }
.decision-card__count {
  font-family: var(--font-body);
  font-size: 48px;
  font-weight: var(--fw-bold);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--color-ink);
}
.decision-card__label {
  font-family: var(--font-display);
  font-size: var(--fs-headline);
  font-style: italic;
  font-weight: var(--fw-regular);
  color: var(--color-ink);
}
.decision-card__desc {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  margin: 0;
}
.decision-card__list {
  list-style: none;
  padding: 0;
  margin: var(--sp-3) 0 0;
  display: flex;
  flex-direction: column;
}
.decision-card__item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  padding: 10px 0;
  border-bottom: 1px solid var(--color-line);
  cursor: pointer;
  transition: background 80ms ease;
}
.decision-card__item:hover {
  background: var(--color-bg-subtle);
  margin: 0 -8px;
  padding-left: 8px;
  padding-right: 8px;
}
.decision-card__item:last-child { border-bottom: 0; }

/* Empty state narrativo dentro de la decision card */
.decision-card__empty {
  margin: var(--sp-2) 0 0;
  padding: var(--sp-3) 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-meta);
  line-height: 1.45;
  color: var(--color-graphite);
  border-top: 1px dashed var(--color-line);
}
.decision-card__sku {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-body);
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
}
.decision-card__sub {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
  text-align: right;
}

/* ─── Drawer (ficha SKU lateral) ─── */
.drawer-backdrop {
  position: fixed; inset: 0;
  background: rgba(31, 40, 38, 0.32);
  z-index: 998;
  animation: fadeIn 200ms ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(560px, 92vw);
  background: var(--color-bg);
  border-left: 1px solid var(--color-line-strong);
  box-shadow: -8px 0 40px rgba(31, 40, 38, 0.08);
  z-index: 999;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 240ms cubic-bezier(0.2, 0.8, 0.2, 1);
  padding: var(--sp-6) var(--sp-6) var(--sp-7);
}
.drawer.drawer--open { transform: translateX(0); }

.drawer__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--color-ink);
}
.drawer__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
  margin-bottom: var(--sp-1);
}
.drawer__title {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-regular);
  color: var(--color-ink);
  letter-spacing: -0.01em;
  margin-bottom: var(--sp-1);
  line-height: 1.05;
}
.drawer__desc {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-body-lg);
  color: var(--color-graphite);
  margin: 0;
}
.drawer__close {
  background: transparent;
  border: 1px solid var(--color-line-strong);
  width: 36px; height: 36px;
  font-size: 24px;
  line-height: 1;
  color: var(--color-ink);
  cursor: pointer;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 120ms ease;
}
.drawer__close:hover { background: var(--color-ink); color: var(--color-bg); }

.drawer__decision {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-5);
  margin-bottom: var(--sp-5);
  border-left: 4px solid var(--color-ink);
}
.drawer__decision--neg     { border-left-color: var(--color-terracotta-text); background: var(--color-neg-soft); }
.drawer__decision--warn    { border-left-color: var(--color-amber); background: var(--color-warn-soft); }
.drawer__decision--pos     { border-left-color: var(--color-forest-text); background: var(--color-pos-soft); }
.drawer__decision--neutral { border-left-color: var(--color-graphite); background: var(--color-bg-subtle); }
.drawer__decision--unknown { border-left-color: var(--color-tenue); background: var(--color-bg-subtle); }

.drawer__decision-label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
}
.drawer__decision-value {
  font-family: var(--font-display);
  font-size: 36px;
  font-style: italic;
  font-weight: var(--fw-regular);
  color: var(--color-ink);
  line-height: 1;
}
.drawer__decision-desc {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}

/* Why-card · evidencia que disparó la decisión.
   Vive justo debajo del decision card, mismo tono pero más sutil — el
   border-left une visualmente las dos piezas (regla + evidencia).        */
.drawer__why {
  margin-top: -8px;            /* pegado al decision card */
  margin-bottom: var(--sp-5);
  padding: var(--sp-3) var(--sp-4) var(--sp-4);
  border-left: 3px solid var(--color-line);
  background: var(--color-bg-subtle);
}
.drawer__why--neg     { border-left-color: var(--color-terracotta-text); }
.drawer__why--warn    { border-left-color: var(--color-amber); }
.drawer__why--amber   { border-left-color: var(--color-amber); }
.drawer__why--pos     { border-left-color: var(--color-forest-text); }
.drawer__why--neutral { border-left-color: var(--color-graphite); }
.drawer__why--unknown { border-left-color: var(--color-tenue); }
.drawer__why-eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
  margin-bottom: var(--sp-2);
}
.drawer__why-grid {
  display: grid;
  grid-template-columns: minmax(120px, auto) auto 1fr;
  gap: 6px var(--sp-3);
  align-items: baseline;
}
.drawer__why-label {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}
.drawer__why-actual {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--color-ink);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.drawer__why-verdict {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-weight: 400;
  letter-spacing: 0.005em;
}
@media (max-width: 700px) {
  .drawer__why-grid {
    grid-template-columns: 1fr;
    gap: 2px var(--sp-3);
  }
  .drawer__why-grid > * { grid-column: 1; }
  .drawer__why-actual { margin-top: 1px; }
  .drawer__why-verdict { margin-bottom: var(--sp-2); }
}

.drawer__metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--sp-5);
}
.drawer__metric {
  padding: var(--sp-4) var(--sp-3);
  border-right: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.drawer__metric:last-child { border-right: 0; }
.drawer__metric:first-child { padding-left: 0; }

.drawer__metric-label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
}
.drawer__metric-value {
  font-family: var(--font-body);
  font-size: 22px;
  font-weight: var(--fw-bold);
  font-variant-numeric: tabular-nums;
  color: var(--color-ink);
  letter-spacing: -0.02em;
}
.drawer__metric-sub {
  font-size: 11px;
  color: var(--color-graphite);
}

.drawer__section {
  margin-bottom: var(--sp-5);
  padding-top: var(--sp-2);
}
.drawer__section-title {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
  margin-bottom: var(--sp-3);
}
.drawer__dl {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 6px var(--sp-3);
  margin: 0;
}
.drawer__dl dt {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}
.drawer__dl dd {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
  margin: 0;
}

.drawer__nav-hint {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px dashed var(--color-line);
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  opacity: 0.75;
}
.drawer__nav-hint kbd {
  font-family: var(--font-body);
  font-size: 11px;
  line-height: 1;
  padding: 3px 6px;
  border: 1px solid var(--color-line-strong);
  border-bottom-width: 2px;
  border-radius: 4px;
  background: var(--color-bg-subtle);
  color: var(--color-ink);
}

@media (max-width: 700px) {
  .drawer__metrics { grid-template-columns: 1fr; }
  .drawer__metric { border-right: 0; border-bottom: 1px solid var(--color-line); padding-left: 0 !important; }
  .drawer__dl { grid-template-columns: 1fr; gap: 2px var(--sp-3); }
  .drawer__dl dd { margin-bottom: var(--sp-2); }
}

/* ─── Lifecycle strip (Colecciones · 4 segmentos) ─── */
.lifecycle-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-ink);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--sp-6);
}
.lifecycle-strip__cell {
  padding: var(--sp-4) var(--sp-5) var(--sp-4) 0;
  border-right: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-top: 3px solid transparent;
}
.lifecycle-strip__cell:first-child { padding-left: 0; }
.lifecycle-strip__cell:last-child { border-right: 0; }
.lifecycle-strip__cell:not(:first-child) { padding-left: var(--sp-5); }

.lifecycle-strip__pct {
  font-family: var(--font-body);
  font-size: 28px;
  font-weight: var(--fw-bold);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  color: var(--color-ink);
  line-height: 1;
}
.lifecycle-strip__label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
  margin-top: 2px;
}
.lifecycle-strip__amount {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
}

.lc--nuevas       { border-top-color: var(--color-singolare); }
.lc--continuidad  { border-top-color: var(--color-forest-text); }
.lc--anteriores   { border-top-color: var(--color-amber); }
.lc--marcas       { border-top-color: var(--color-copper); }
.lc--unknown      { border-top-color: var(--color-tenue); }

/* Pills de lifecycle dentro de tabla */
.lc-pill {
  display: inline-block;
  padding: 2px 10px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 999px;
  font-weight: var(--fw-medium);
  background: transparent;
  border: 1px solid var(--color-line-strong);
  color: var(--color-graphite);
  white-space: nowrap;
}
.lc-pill.lc--nuevas      { border-color: var(--color-singolare); color: var(--color-singolare); }
.lc-pill.lc--continuidad { border-color: var(--color-forest-text); color: var(--color-forest-text); }
.lc-pill.lc--anteriores  { border-color: var(--color-amber); color: var(--color-amber); }
.lc-pill.lc--marca,
.lc-pill.lc--marcas      { border-color: var(--color-copper); color: var(--color-copper); }
.lc-pill.lc--sin-clasificar { border-color: var(--color-line); color: var(--color-muted-2); }

@media (max-width: 900px) {
  .lifecycle-strip { grid-template-columns: repeat(2, 1fr); }
  .lifecycle-strip__cell { border-bottom: 1px solid var(--color-line); padding-left: 0 !important; padding-right: 0; border-right: 0; }
}

/* ─── Mapa margen × rotación (scatter editorial) ─── */
.mapa__wrap {
  width: 100%;
  margin-top: var(--sp-3);
}
.mapa {
  width: 100%;
  height: auto;
  display: block;
  font-family: var(--font-body);
}
.mapa__axis      { stroke: var(--color-ink); stroke-width: 1; }
.mapa__tick      { stroke: var(--color-graphite); stroke-width: 1; }
.mapa__ref       { stroke: var(--color-line-strong); stroke-width: 1; }
.mapa__axis-label {
  font-size: 11px;
  fill: var(--color-graphite);
  font-variant-numeric: tabular-nums;
}
.mapa__title {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  fill: var(--color-graphite);
  font-weight: var(--fw-medium);
}
.mapa__quad {
  font-size: 10px;
  letter-spacing: 0.04em;
  fill: var(--color-muted-2);
  font-style: italic;
  font-family: var(--font-display);
}
.mapa__label {
  font-size: 10px;
  fill: var(--color-ink);
  font-weight: var(--fw-medium);
}

.mapa__legend {
  display: flex;
  gap: var(--sp-5);
  margin-top: var(--sp-4);
  flex-wrap: wrap;
}
.mapa__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}
.mapa__legend-item i {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ─── Family detail (sub-info dentro de canal-card) ─── */
.fam-detail {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--color-line);
  margin-top: var(--sp-2);
}
.fam-detail__row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--sp-3);
  align-items: baseline;
}
.fam-detail__lbl {
  font-family: var(--font-body);
  font-size: var(--fs-metadata);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-graphite);
}
.fam-detail__val {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
}
.fam-detail__val.delta--pos { color: var(--color-pos); }
.fam-detail__val.delta--neg { color: var(--color-neg); }

/* ─── Mini bar chart (1 barra por semana, panel SKU) ─── */
.bars { display: block; }
.bars .bar         { fill: var(--color-ink); fill-opacity: 0.55; }
.bars .bar--last   { fill: var(--color-singolare); fill-opacity: 1; }
.bars .bar--zero   { fill: var(--color-tenue); fill-opacity: 0.45; }

/* ─── Spark + ejes ─── */
.spark-wrap { width: 100%; }
.spark {
  width: 100%;
  height: 64px;
  display: block;
  overflow: visible;
}
.spark path.line { fill: none; stroke: var(--color-ink); stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.spark path.area { fill: var(--color-ink); fill-opacity: 0.05; }
.spark .dot { fill: var(--color-ink); }
.spark .axis-line { stroke: var(--color-line); stroke-width: 1; }
.spark .axis-tick { stroke: var(--color-tenue); stroke-width: 1; }
.spark .axis-label {
  fill: var(--color-muted-2);
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* ─── Alertas ─── */
.alert {
  padding: var(--sp-5) var(--sp-6);
  border-left: 3px solid var(--color-amber);
  background: var(--color-warn-soft);
}
.alert--neg  { border-left-color: var(--color-terracotta); background: var(--color-neg-soft); }
.alert--pos  { border-left-color: var(--color-forest); background: var(--color-pos-soft); }
.alert--note { border-left-color: var(--color-ink); background: var(--color-bg-subtle); }

.alert__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline);
  font-style: italic;
  font-weight: var(--fw-regular);
  color: var(--color-ink);
  margin-bottom: var(--sp-2);
}

.alert__body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--color-body);
  line-height: 1.55;
}

.alert-stack { display: flex; flex-direction: column; gap: var(--sp-3); }

/* ─── Footnote ─── */
.footnote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-subtitle);
  color: var(--color-muted-2);
  margin-top: var(--sp-3);
}

/* ─── Layout helpers ─── */
.cols-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
}
.cols-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--sp-5);
}
.cols-asym-12 {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--sp-7);
}
.cols-asym-21 {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--sp-7);
}
@media (max-width: 900px) {
  .cols-2, .cols-3, .cols-asym-12, .cols-asym-21 { grid-template-columns: 1fr; gap: var(--sp-5); }
}

/* ─── Heatmap categoría × tiempo (composición creativa) ─── */
.heatmap {
  display: grid;
  grid-template-columns: 200px repeat(var(--cols, 12), 1fr);
  gap: 2px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
}

.heatmap__cell {
  aspect-ratio: 1.6 / 1;
  background: var(--color-bg-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-variant-numeric: tabular-nums;
  color: var(--color-graphite);
}

.heatmap__row-label {
  display: flex;
  align-items: center;
  font-size: var(--fs-meta);
  color: var(--color-ink);
  padding-right: var(--sp-3);
  font-weight: var(--fw-regular);
}

.heatmap__col-label {
  font-family: var(--font-body);
  font-size: var(--fs-metadata);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
  text-align: center;
  padding-bottom: var(--sp-2);
}

/* ─── Recambio de temporadas — tabla editorial dual bars ─── */
.recambio {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) minmax(180px, 2.4fr) minmax(180px, 2.4fr) auto;
  gap: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
}

.recambio__head,
.recambio__row {
  display: contents;
}

.recambio__head .recambio__cell {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--color-ink);
}
.recambio__head .recambio__cell--year,
.recambio__head .recambio__cell--delta {
  text-align: right;
}

.recambio__row .recambio__cell {
  padding: var(--sp-4) var(--sp-4);
  border-bottom: 1px solid var(--color-line);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.recambio__cell--label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-body-lg);
  color: var(--color-ink);
  font-weight: var(--fw-regular);
}

.recambio__cell--bar {
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
}

.recambio__bar {
  width: 100%;
  height: 8px;
  background: var(--color-bg-subtle);
  position: relative;
}

.recambio__fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--color-graphite);
}

.recambio__fill--past { background: var(--color-tenue); }
.recambio__fill--up   { background: var(--color-singolare); }
.recambio__fill--down { background: var(--color-copper); }

.recambio__amount {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  font-variant-numeric: tabular-nums;
  color: var(--color-graphite);
  text-align: right;
}

.recambio__amount--strong {
  color: var(--color-ink);
  font-weight: var(--fw-medium);
  font-size: var(--fs-body);
}

.recambio__cell--delta { justify-content: flex-end; }

.recambio__chip {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  font-weight: var(--fw-medium);
  font-variant-numeric: tabular-nums;
  padding: 2px 10px;
  border-radius: 999px;
  letter-spacing: 0.02em;
}
.recambio__chip--pos { background: var(--color-pos-soft); color: var(--color-pos); }
.recambio__chip--neg { background: var(--color-neg-soft); color: var(--color-neg); }

/* ─── Tag ─── */
.tag {
  display: inline-block;
  padding: 2px 10px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 1px solid var(--color-line-strong);
  color: var(--color-graphite);
  background: transparent;
  font-weight: var(--fw-medium);
}
.tag--pos    { border-color: var(--color-forest-text); color: var(--color-forest-text); }
.tag--neg    { border-color: var(--color-terracotta-text); color: var(--color-terracotta-text); }
.tag--warn   { border-color: var(--color-amber); color: var(--color-amber); }
.tag--copper { border-color: var(--color-copper); color: var(--color-copper); }

/* ─── Pill (status uniformes — todas mismo ancho) ─── */
.pill {
  display: inline-block;
  min-width: 110px;
  padding: 4px 0;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 999px;
  text-align: center;
  font-weight: var(--fw-medium);
  background: var(--color-bg-subtle);
  color: var(--color-graphite);
  border: 1px solid var(--color-line);
}
.pill--pos { background: var(--color-pos-soft); color: var(--color-pos); border-color: transparent; }
.pill--warn { background: var(--color-warn-soft); color: var(--color-warn); border-color: transparent; }
.pill--neg { background: var(--color-neg-soft); color: var(--color-neg); border-color: transparent; }

.pill-cell { width: 130px; text-align: center !important; }

/* ─── Stats summary (KPIs arriba de tabla) ─── */
.stats-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-ink);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--sp-6);
}

.stats-summary__kpi {
  padding: var(--sp-4) var(--sp-5) var(--sp-4) 0;
  border-right: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.stats-summary__kpi:first-child { padding-left: 0; }
.stats-summary__kpi:last-child  { border-right: 0; padding-right: 0; }
.stats-summary__kpi:not(:first-child) { padding-left: var(--sp-5); }

.stats-summary__label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
}

.stats-summary__value {
  font-family: var(--font-body);
  font-size: 28px;
  font-weight: var(--fw-bold);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  color: var(--color-ink);
  margin-top: 2px;
}

.stats-summary__sub {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}

@media (max-width: 900px) {
  .stats-summary { grid-template-columns: 1fr; }
  .stats-summary__kpi { border-right: 0; border-bottom: 1px solid var(--color-line); padding-left: 0 !important; padding-right: 0; }
  .stats-summary__kpi:last-child { border-bottom: 0; }
}

/* ─── Balance (barra apilada del inventario) ─── */
.balance {
  margin-bottom: var(--sp-7);
}

.balance__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--sp-3);
}

.balance__bar {
  display: flex;
  width: 100%;
  height: 28px;
  overflow: hidden;
  border-radius: 2px;
  background: var(--color-bg-subtle);
}

.balance__seg {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  transition: filter 120ms ease;
}
.balance__seg:hover { filter: brightness(1.05); }

.balance__seg--pos     { background: var(--color-forest-text); color: white; }
.balance__seg--warn    { background: var(--color-amber); color: white; }
.balance__seg--neg     { background: var(--color-terracotta-text); color: white; }
.balance__seg--unknown { background: var(--color-tenue); color: var(--color-graphite); }

.balance__seg-label {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}

.balance__legend {
  display: flex;
  gap: var(--sp-5);
  margin-top: var(--sp-3);
  flex-wrap: wrap;
}

.balance__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
}

.balance__dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  flex-shrink: 0;
}
.balance__dot--pos  { background: var(--color-forest-text); }
.balance__dot--warn { background: var(--color-amber); }
.balance__dot--neg  { background: var(--color-terracotta-text); }

/* ─── Drill-down anchors ─────────────────────────────────────────────
   Texto navegable a SKU & Stock con filtros aplicados.
   Affordance editorial: arrow ↗ siempre visible (sutil) + underline en hover. */
.drill-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dotted #b8ad9d;
  transition: color 120ms ease, border-color 120ms ease;
  cursor: pointer;
}
.drill-link:hover {
  color: var(--color-copper, #B17A3F);
  border-bottom-color: currentColor;
  border-bottom-style: solid;
}
.drill-link::after {
  content: '↗';
  margin-left: 0.2em;
  font-size: 0.7em;
  opacity: 0.45;
  vertical-align: 0.15em;
  transition: opacity 120ms ease, transform 120ms ease;
  display: inline-block;
}
.drill-link:hover::after { opacity: 1; transform: translate(1px, -1px); }

/* ─── Command palette (⌘K) ───────────────────────────────────────── */
.cmdk {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: none;
  font-family: var(--font-body);
}
.cmdk--open { display: block; }

.cmdk__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 40, 38, 0.32);
  backdrop-filter: blur(2px);
  animation: cmdk-fade 140ms ease;
}

.cmdk__panel {
  position: relative;
  margin: 12vh auto 0;
  max-width: 640px;
  width: calc(100% - 32px);
  background: var(--color-surface, #FCFCF9);
  border: 1px solid var(--color-line);
  box-shadow: 0 16px 48px rgba(31,40,38,0.18);
  display: flex;
  flex-direction: column;
  max-height: 70vh;
  animation: cmdk-rise 180ms ease;
}

@keyframes cmdk-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes cmdk-rise {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: none; }
}

.cmdk__searchwrap {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--color-line);
}
.cmdk__icon {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  color: var(--color-graphite);
  flex-shrink: 0;
}
.cmdk__input {
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-ink);
  padding: 4px 0;
}
.cmdk__input::placeholder { color: var(--color-muted-2, #968b7d); }
.cmdk__esc-hint {
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--color-graphite);
  border: 1px solid var(--color-line);
  padding: 2px 6px;
  border-radius: 3px;
  background: var(--color-bg-subtle);
}

.cmdk__results {
  overflow-y: auto;
  flex: 1;
  padding: var(--sp-2) 0;
}
.cmdk__group-label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-graphite);
  padding: var(--sp-3) var(--sp-5) var(--sp-2);
  font-weight: var(--fw-medium);
}
.cmdk__group-label:not(:first-child) {
  border-top: 1px solid var(--color-line);
  margin-top: var(--sp-2);
}

.cmdk__item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-5);
  cursor: pointer;
  border-left: 2px solid transparent;
  transition: background 80ms ease;
}
.cmdk__item:hover { background: var(--color-bg-subtle); }
.cmdk__item--active {
  background: var(--color-bg-subtle);
  border-left-color: var(--color-copper, #B17A3F);
}
.cmdk__item-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cmdk__item-label {
  font-size: 14px;
  color: var(--color-ink);
  font-weight: var(--fw-regular);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cmdk__item-label strong {
  font-weight: var(--fw-semibold);
  font-variant-numeric: tabular-nums;
}
.cmdk__item-desc { color: var(--color-graphite); }
.cmdk__item-sub {
  font-size: 12px;
  color: var(--color-graphite);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cmdk__item-arrow {
  color: var(--color-muted-2, #968b7d);
  font-size: 14px;
  opacity: 0.6;
  flex-shrink: 0;
}
.cmdk__item--active .cmdk__item-arrow {
  color: var(--color-copper);
  opacity: 1;
}
.cmdk__item-tag {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-graphite);
  padding: 2px 6px;
  border: 1px solid var(--color-line);
  border-radius: 3px;
  background: var(--color-bg);
  flex-shrink: 0;
}

.cmdk__empty {
  padding: var(--sp-6) var(--sp-5);
  font-size: 13px;
  color: var(--color-graphite);
  font-style: italic;
}

.cmdk__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-3) var(--sp-5);
  border-top: 1px solid var(--color-line);
  background: var(--color-bg);
  font-size: 11px;
  color: var(--color-graphite);
}
.cmdk__footer kbd {
  font-family: var(--font-body);
  font-size: 10px;
  border: 1px solid var(--color-line);
  padding: 1px 5px;
  border-radius: 3px;
  background: var(--color-bg-subtle);
  margin: 0 2px;
}
.cmdk__brand {
  font-family: var(--font-display);
  font-style: italic;
  letter-spacing: 0.04em;
  color: var(--color-graphite);
}

/* — Botón en el header — */
.cmdk-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-line);
  color: var(--color-graphite);
  font-family: var(--font-body);
  font-size: 12px;
  padding: 6px 10px;
  cursor: pointer;
  transition: border-color 120ms ease, color 120ms ease;
  letter-spacing: 0.02em;
}
.cmdk-trigger:hover {
  border-color: var(--color-ink);
  color: var(--color-ink);
}
.cmdk-trigger__icon {
  font-size: 13px;
  line-height: 1;
}
.cmdk-trigger__hint {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 10px;
  border: 1px solid var(--color-line);
  padding: 1px 5px;
  border-radius: 3px;
  background: var(--color-bg);
  color: var(--color-graphite);
  letter-spacing: 0.04em;
}

@media (max-width: 600px) {
  .cmdk__panel { margin-top: 6vh; max-height: 80vh; }
  .cmdk-trigger__hint { display: none; }
  .cmdk-trigger__label { display: none; }
}

/* ─── Calidad del dato (SKU & Stock) ────────────────────────────────
   Bloque editorial discreto: convierte la deuda de homologación en
   metadata visible. Tono diferente al KPI strip — más sobrio.        */
.qd {
  margin: var(--sp-7) 0 var(--sp-9);
  padding: var(--sp-5) var(--sp-5);
  border: 1px solid var(--color-line);
  border-left: 3px solid var(--color-graphite);
  background: var(--color-bg);
}
.qd__head {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-5);
}
.qd__lede {
  font-size: var(--fs-body);
  color: var(--color-body);
  line-height: 1.55;
  max-width: 76ch;
}
.qd__lede strong {
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
}
.qd__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-line);
  padding-top: var(--sp-4);
}
.qd__cell {
  padding: 0 var(--sp-4) 0 0;
  border-right: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.qd__cell:not(:first-child) { padding-left: var(--sp-4); }
.qd__cell:last-child { border-right: 0; padding-right: 0; }
.qd__value {
  font-family: var(--font-body);
  font-size: 28px;
  font-weight: var(--fw-bold);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  color: var(--color-ink);
}
.qd__cell--ok   .qd__value { color: var(--color-forest, #2F5D4F); }
.qd__cell--warn .qd__value { color: var(--color-amber, #C9A24F); }
.qd__cell--mute .qd__value { color: var(--color-graphite); }
.qd__label {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
  font-weight: var(--fw-medium);
  margin-top: 8px;
}
.qd__sub {
  font-size: 12px;
  color: var(--color-graphite);
  line-height: 1.45;
  margin-top: 4px;
}
.qd__foot {
  font-size: 13px;
  color: var(--color-graphite);
  line-height: 1.55;
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--color-line);
}
.qd__foot strong {
  color: var(--color-ink);
  font-weight: var(--fw-semibold);
}
.qd__foot em {
  font-style: italic;
  color: var(--color-copper);
}
@media (max-width: 900px) {
  .qd__grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
  .qd__cell { border-right: 0; border-bottom: 1px solid var(--color-line); padding: 0 0 var(--sp-3); }
  .qd__cell:not(:first-child) { padding-left: 0; padding-top: var(--sp-3); }
}

/* ─── Foto del modelo en la ficha (drawer SKU) ──────────────────────
   La imagen viene del Excel original (assets/fotos/<codigo>.png).
   Si no existe, onerror remueve la figura entera para no dejar hueco. */
.drawer__foto {
  margin: 0;
  padding: 0;
  background: var(--color-bg-subtle);
  border-bottom: 1px solid var(--color-line);
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.drawer__foto img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* ─── Heatmap Talla × Color (drawer SKU) ───────────────────────────────
   El patrón fashion-specific. Lee mejor cuando las celdas son cuadradas;
   bajamos altura en mobile en lugar de romper el grid.                 */
.drawer__section--hm {
  --hm-color-w: 96px;
  --hm-total-w: 44px;
  --hm-cell-h: 44px;
}
.hm__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.hm__hint {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
}

.hm__grid {
  display: grid;
  gap: 2px;
  background: var(--color-line);
  padding: 2px;
  border: 1px solid var(--color-line-strong);
  border-radius: 4px;
}
.hm__head, .hm__row, .hm__foot {
  display: contents;
}

/* Celdas-encabezado */
.hm__th {
  background: var(--color-bg-subtle);
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-graphite);
  text-align: center;
  padding: 6px 4px;
  font-variant-numeric: tabular-nums;
}
.hm__th--total { color: var(--color-ink); font-weight: 500; }

/* Etiqueta de color (primera columna) */
.hm__color-cell {
  background: var(--color-bg);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0 var(--sp-3);
  min-height: var(--hm-cell-h);
}
.hm__color-cell--head { background: var(--color-bg-subtle); }
.hm__color-cell--foot {
  background: var(--color-bg-subtle);
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-graphite);
  padding: 0 var(--sp-3);
}
.hm__swatch {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid var(--color-line-strong);
  flex-shrink: 0;
}
.hm__color-label {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Celda principal: stock arriba, vendido abajo */
.hm__cell {
  position: relative;
  min-height: var(--hm-cell-h);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-variant-numeric: tabular-nums;
  cursor: default;
  transition: filter 120ms;
}
.hm__cell:hover { filter: brightness(0.96); }
.hm__cell-stock {
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
}
.hm__cell-vend {
  font-size: 10px;
  line-height: 1;
  margin-top: 3px;
  color: currentColor;
  opacity: 0.55;
}

/* Tones — sell-through */
.hm__cell--hot     { background: var(--color-singolare); color: #FFFFFF; }
.hm__cell--warm    { background: var(--color-singolare-soft); color: var(--color-ink); }
.hm__cell--mid     { background: var(--color-bg-subtle); color: var(--color-ink); }
.hm__cell--cool    { background: var(--color-warn-soft); color: var(--color-ink); }
.hm__cell--cold    { background: var(--color-neg-soft); color: var(--color-neg); }
.hm__cell--quiebre {
  background: var(--color-bg);
  color: var(--color-singolare);
  border: 1.5px dashed var(--color-singolare);
  font-style: italic;
}
.hm__cell--quiebre .hm__cell-stock::after {
  content: '✓';
  margin-left: 3px;
  font-style: normal;
  font-size: 11px;
}
.hm__cell--empty {
  background: var(--color-bg);
  color: var(--color-muted-2);
  opacity: 0.45;
}

/* Totales (sell-through% por fila / columna / global) */
.hm__total {
  background: var(--color-bg-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  color: var(--color-graphite);
  letter-spacing: 0.04em;
}
.hm__total--row    { color: var(--color-ink); font-weight: 500; }
.hm__total--col    { color: var(--color-graphite); }
.hm__total--grand  {
  background: var(--color-ink);
  color: var(--color-bg);
  font-weight: 500;
}

/* Insight narrativo */
.hm__insight {
  margin: var(--sp-3) 0 0;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  line-height: 1.55;
  color: var(--color-ink);
  padding: var(--sp-3) var(--sp-4);
  background: var(--color-singolare-soft);
  border-left: 3px solid var(--color-singolare);
  border-radius: 0 4px 4px 0;
}

/* Leyenda compacta */
.hm__legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2) var(--sp-3);
  margin-top: var(--sp-3);
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--color-graphite);
}
.hm__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.hm__legend-swatch {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 2px;
  border: 1px solid var(--color-line-strong);
}
.hm__legend-swatch.hm__cell--quiebre { padding: 0; }

/* Pie: marca de mockup */
.hm__pilot-flag {
  margin: var(--sp-3) 0 0;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted-2);
  font-style: italic;
}

@media (max-width: 700px) {
  .drawer__section--hm {
    --hm-color-w: 78px;
    --hm-total-w: 38px;
    --hm-cell-h: 38px;
  }
  .hm__color-label { font-size: 10px; }
}

/* ─── Lookbook · Grilla de catálogo (pestaña Colecciones) ─────────────
   La sección protagonista. Tarjetas con foto dominante, datos secundarios.
   Status del modelo se comunica con un acento de color sutil (borde + pill)
   no con un fondo agresivo — Singolare es editorial, no un dashboard rojo.
   ────────────────────────────────────────────────────────────────────── */
.section--lookbook { /* hereda .section, sin override por ahora */ }

/* Controles superiores: dropdowns + chips de status */
.lookbook-controls {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.lookbook-controls__row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: end;
}
.lookbook-ctrl {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  min-width: 160px;
}
.lookbook-ctrl__label {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
}
.lookbook-ctrl__select {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-ink);
  background: var(--color-bg);
  border: 1px solid var(--color-line-strong);
  padding: 7px 10px;
  border-radius: 4px;
  cursor: pointer;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--color-graphite) 50%),
                    linear-gradient(135deg, var(--color-graphite) 50%, transparent 50%);
  background-position: calc(100% - 14px) center, calc(100% - 9px) center;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 28px;
}
.lookbook-ctrl__select:focus {
  outline: none;
  border-color: var(--color-singolare);
}

/* Chips de status — pildora con tone + count */
.lookbook-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.lookbook-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px 6px 12px;
  border: 1px solid var(--color-line-strong);
  background: var(--color-bg);
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-ink);
  border-radius: 999px;
  cursor: pointer;
  transition: background 120ms, border-color 120ms;
}
.lookbook-chip:hover { border-color: var(--color-ink); }
.lookbook-chip__count {
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  color: var(--color-graphite);
  padding: 1px 6px;
  background: var(--color-bg-subtle);
  border-radius: 999px;
}
.lookbook-chip--active {
  background: var(--color-ink);
  color: var(--color-bg);
  border-color: var(--color-ink);
}
.lookbook-chip--active .lookbook-chip__count {
  background: rgba(255,255,255,0.18);
  color: var(--color-bg);
}

/* Grid */
.lookbook-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--sp-5) var(--sp-4);
}

/* Tarjeta individual */
.lookbook-card {
  display: flex;
  flex-direction: column;
  text-align: left;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
  position: relative;
  transition: transform 200ms cubic-bezier(.2,.8,.2,1);
}
.lookbook-card:hover {
  transform: translateY(-2px);
}
.lookbook-card:focus-visible {
  outline: 2px solid var(--color-singolare);
  outline-offset: 4px;
  border-radius: 2px;
}

.lookbook-card__foto {
  position: relative;
  margin: 0;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--color-bg-subtle);
  border-radius: 2px;
}
.lookbook-card__foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 600ms cubic-bezier(.2,.8,.2,1);
}
.lookbook-card:hover .lookbook-card__foto img { transform: scale(1.03); }

/* Pill de status sobre la foto, abajo a la izquierda */
.lookbook-card__pill {
  position: absolute;
  bottom: 8px;
  left: 8px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 2px;
  background: rgba(31, 40, 38, 0.9);
  color: var(--color-bg);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.lookbook-card__pill--neg     { background: var(--color-terracotta-text); }
.lookbook-card__pill--pos     { background: var(--color-forest-text); }
.lookbook-card__pill--warn    { background: var(--color-amber); color: var(--color-ink); }
.lookbook-card__pill--amber   { background: var(--color-amber); color: var(--color-ink); }
.lookbook-card__pill--neutral { background: rgba(31, 40, 38, 0.85); }
.lookbook-card__pill--unknown { background: rgba(92, 83, 76, 0.85); }

/* Body de la tarjeta */
.lookbook-card__body {
  padding: var(--sp-3) 2px 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.lookbook-card__eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
}
.lookbook-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 18px;
  line-height: 1.2;
  color: var(--color-ink);
  letter-spacing: 0.005em;
  /* truncado a 2 líneas: dejar lugar pero no romper grid */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.lookbook-card__meta {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}

/* Acento de borde-izquierdo según status — sólo visible en hover para no
   ensuciar la grilla (queremos que la foto domine).                       */
.lookbook-card::before {
  content: '';
  position: absolute;
  left: -6px;
  top: 0;
  bottom: 60px;
  width: 2px;
  background: transparent;
  transition: background 160ms;
}
.lookbook-card:hover::before { background: var(--color-line-strong); }
.lookbook-card--neg:hover::before  { background: var(--color-terracotta-text); }
.lookbook-card--pos:hover::before  { background: var(--color-forest-text); }
.lookbook-card--warn:hover::before { background: var(--color-amber); }
.lookbook-card--amber:hover::before { background: var(--color-amber); }

/* Footer · contador + load more */
.lookbook-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--color-line);
}
.lookbook-count {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
}
.lookbook-loadmore {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  padding: 8px 16px;
  background: var(--color-bg);
  border: 1px solid var(--color-line-strong);
  color: var(--color-ink);
  cursor: pointer;
  border-radius: 2px;
  letter-spacing: 0.04em;
  transition: background 120ms, border-color 120ms;
}
.lookbook-loadmore:hover {
  background: var(--color-bg-subtle);
  border-color: var(--color-ink);
}

.lookbook-empty {
  grid-column: 1 / -1;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  padding: var(--sp-5);
  text-align: center;
  border: 1px dashed var(--color-line-strong);
  border-radius: 4px;
}

@media (max-width: 700px) {
  .lookbook-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
  .lookbook-card__title { font-size: 16px; }
  .lookbook-controls__row { flex-direction: column; align-items: stretch; }
}

/* ─── Lifecycle bell-curve (drawer SKU) ──────────────────────────────── */
.drawer__section--lc { color: var(--color-graphite); }
.lc-curve__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}
.lc-curve__stage {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  font-weight: 500;
  color: var(--color-ink);
}
.lc-curve__stage-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-graphite);
  flex-shrink: 0;
}
.lc-curve__stage--neg     .lc-curve__stage-dot { background: var(--color-terracotta-text); }
.lc-curve__stage--pos     .lc-curve__stage-dot { background: var(--color-forest-text); }
.lc-curve__stage--warn    .lc-curve__stage-dot,
.lc-curve__stage--amber   .lc-curve__stage-dot { background: var(--color-amber); }
.lc-curve__stage--singolare .lc-curve__stage-dot { background: var(--color-singolare); }
.lc-curve__stage--neutral .lc-curve__stage-dot { background: var(--color-graphite); }

.lc-curve__viz {
  width: 100%;
  height: 56px;
  color: var(--color-graphite);
  margin-top: 4px;
}
.lc-curve__svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Marcador del SKU sobre la curva — círculo halo + punto interno */
.lc-curve__dot {
  fill: rgba(31, 40, 38, 0.10);
  stroke: var(--color-graphite);
  stroke-width: 1;
}
.lc-curve__dot-inner { fill: var(--color-graphite); stroke: none; }

.lc-curve__dot--neg     { fill: rgba(184, 80, 66, 0.18); stroke: var(--color-terracotta-text); }
.lc-curve__dot--pos     { fill: rgba(45, 107, 72, 0.18); stroke: var(--color-forest-text); }
.lc-curve__dot--warn,
.lc-curve__dot--amber   { fill: rgba(201, 162, 79, 0.22); stroke: var(--color-amber); }
.lc-curve__dot--singolare { fill: rgba(16, 132, 116, 0.18); stroke: var(--color-singolare); }
.lc-curve__dot-inner--neg     { fill: var(--color-terracotta-text); }
.lc-curve__dot-inner--pos     { fill: var(--color-forest-text); }
.lc-curve__dot-inner--warn,
.lc-curve__dot-inner--amber   { fill: var(--color-amber); }
.lc-curve__dot-inner--singolare { fill: var(--color-singolare); }

.lc-curve__zones {
  position: relative;
  height: 16px;
  margin-top: 2px;
}
.lc-curve__zone {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-graphite);
  white-space: nowrap;
}
.lc-curve__caption {
  margin: var(--sp-2) 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  letter-spacing: 0.005em;
}

/* ─── Transfer suggester (drawer SKU) ────────────────────────────────── */
.drawer__section--tx { }
.tx__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.tx__hint {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-graphite);
}

.tx__table {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto auto;
  gap: 8px var(--sp-3);
  align-items: center;
  background: var(--color-bg-subtle);
  padding: var(--sp-3) var(--sp-4);
  border-radius: 4px;
  border-left: 2px solid var(--color-singolare);
}
.tx__heads {
  display: contents;
}
.tx__heads > span {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-graphite);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--color-line);
}
.tx__row {
  display: contents;
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-ink);
}
.tx__from, .tx__to {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.25;
}
.tx__store { font-weight: 500; color: var(--color-ink); }
.tx__qty-from, .tx__qty-to {
  font-size: 11px;
  color: var(--color-graphite);
  font-variant-numeric: tabular-nums;
}
.tx__arrow {
  font-size: 18px;
  color: var(--color-singolare);
  font-weight: 300;
}
.tx__qty-move {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: var(--fs-body);
  color: var(--color-singolare);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}
.tx__valor {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
  font-weight: 500;
}
.tx__caption {
  margin: var(--sp-3) 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  line-height: 1.4;
}

@media (max-width: 700px) {
  .tx__table { grid-template-columns: 1fr; gap: var(--sp-2); }
  .tx__heads { display: none; }
  .tx__row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 4px var(--sp-2);
    padding: var(--sp-2) 0;
    border-bottom: 1px solid var(--color-line);
  }
  .tx__qty-move, .tx__valor { grid-column: 1 / -1; text-align: left; }
}

/* ─── Calendario operacional · El año de Singolare ─────────────────────
   Pieza editorial. Carriles horizontales por temporada, fases segmentadas,
   hitos como banderitas, cursor "Hoy", eje de meses.                      */
.section--calendar { /* hereda .section */ }

.cal__board {
  --cal-track-h: 38px;
  --cal-lane-gap: 10px;
  --cal-label-w: 110px;
  position: relative;
  margin-top: var(--sp-4);
  padding: var(--sp-4) 0 0;
}

/* Hitos · banderitas arriba */
.cal__hitos {
  position: relative;
  height: 38px;
  margin-left: var(--cal-label-w);
}
.cal__hito {
  position: absolute;
  top: 0;
  bottom: 0;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  pointer-events: auto;
  cursor: default;
}
.cal__hito-label {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-graphite);
  white-space: nowrap;
  transform: translateX(0);
  margin-bottom: 4px;
  transition: color 120ms;
}
.cal__hito-tick {
  width: 1px;
  height: 8px;
  background: var(--color-line-strong);
  margin-bottom: 0;
}
.cal__hito--proximo .cal__hito-label {
  color: var(--color-singolare);
  font-weight: 500;
}
.cal__hito--proximo .cal__hito-tick { background: var(--color-singolare); }
.cal__hito--sale .cal__hito-label   { color: var(--color-terracotta-text); }
.cal__hito--drop .cal__hito-label   { color: var(--color-forest-text); }

/* Carriles · uno por temporada */
.cal__lanes {
  display: flex;
  flex-direction: column;
  gap: var(--cal-lane-gap);
  position: relative;
  z-index: 2;
}
.cal__lane {
  display: grid;
  grid-template-columns: var(--cal-label-w) 1fr;
  align-items: center;
  gap: var(--sp-3);
}
.cal__lane-label {
  display: flex;
  flex-direction: column;
  text-align: right;
  padding-right: var(--sp-2);
  border-right: 1px solid var(--color-line);
}
.cal__lane-key {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 22px;
  line-height: 1;
  color: var(--color-ink);
  letter-spacing: 0.005em;
}
.cal__lane-sub {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-graphite);
  margin-top: 4px;
}
.cal__lane-track {
  position: relative;
  height: var(--cal-track-h);
  background: linear-gradient(to right,
              var(--color-bg-subtle) 0%,
              var(--color-bg-subtle) 100%);
  background-size: 100% 1px;
  background-position: 0 50%;
  background-repeat: no-repeat;
  border-radius: 3px;
}

/* Fases · segmentos absolute */
.cal__phase {
  position: absolute;
  top: 4px;
  bottom: 4px;
  border-radius: 2px;
  display: flex;
  align-items: center;
  padding: 0 var(--sp-2);
  text-decoration: none;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-ink);
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-line-strong);
  overflow: hidden;
  transition: filter 140ms, box-shadow 140ms;
}
.cal__phase:hover {
  filter: brightness(0.95);
  box-shadow: 0 1px 6px rgba(31,40,38, 0.12);
  z-index: 4;
}
.cal__phase-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Tones de fase */
.cal__phase--singolare {
  background: var(--color-singolare-soft);
  border-color: var(--color-singolare);
  color: var(--color-singolare);
}
.cal__phase--neg {
  background: var(--color-neg-soft);
  border-color: var(--color-terracotta-text);
  color: var(--color-terracotta-text);
}
.cal__phase--pos {
  background: var(--color-pos-soft);
  border-color: var(--color-forest-text);
  color: var(--color-forest-text);
}
.cal__phase--neutral,
.cal__phase--preparacion {
  background: repeating-linear-gradient(
    -45deg,
    var(--color-bg-subtle), var(--color-bg-subtle) 6px,
    var(--color-bg) 6px, var(--color-bg) 12px);
  border-style: dashed;
  color: var(--color-graphite);
}
.cal__phase--muted,
.cal__phase--cerrada {
  background: var(--color-bg);
  border-color: var(--color-line);
  color: var(--color-muted-2);
  opacity: 0.7;
}

/* HOY · cursor vertical sobre todo el board */
.cal__today {
  position: absolute;
  top: 0;
  bottom: 26px; /* sobre las lanes pero antes del eje */
  left: var(--cal-label-w);  /* ajustado abajo via JS de left% */
  width: 0;
  z-index: 5;
  pointer-events: none;
  transform: translateX(0);
}
.cal__today {
  /* convertir el left % de la prop a left absoluto considerando el offset
     de la columna izquierda (label) — usamos calc                         */
  left: calc(var(--cal-label-w) + (100% - var(--cal-label-w)) * (var(--hoy-pct, 50) / 100));
}
.cal__today-line {
  position: absolute;
  top: 38px;       /* arranca debajo de los hitos */
  bottom: 0;
  left: 0;
  width: 2px;
  background: var(--color-singolare);
  transform: translateX(-1px);
}
.cal__today-flag {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  background: var(--color-singolare);
  color: #FFFFFF;
  padding: 4px 10px 5px;
  border-radius: 3px;
  white-space: nowrap;
}
.cal__today-flag::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 8px;
  height: 8px;
  background: var(--color-singolare);
}
.cal__today-eyebrow {
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.85;
  line-height: 1;
}
.cal__today-week {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0.005em;
  line-height: 1.1;
}

/* Eje de meses */
.cal__eje {
  position: relative;
  height: 22px;
  margin-top: 6px;
  margin-left: var(--cal-label-w);
  border-top: 1px solid var(--color-line);
}
.cal__mes {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cal__mes-tick {
  width: 1px;
  height: 4px;
  background: var(--color-line-strong);
}
.cal__mes-label {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-graphite);
  margin-top: 2px;
}
.cal__mes--year .cal__mes-label { color: var(--color-ink); font-weight: 500; }
.cal__mes-year {
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 0.12em;
  color: var(--color-graphite);
  margin-top: 1px;
}

/* Caption · próximo hito */
.cal__caption {
  margin: var(--sp-4) 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  text-align: right;
  letter-spacing: 0.005em;
}

@media (max-width: 900px) {
  .cal__board {
    --cal-label-w: 80px;
    --cal-track-h: 30px;
  }
  .cal__lane-key { font-size: 18px; }
  .cal__hitos { height: 30px; }
  .cal__hito-label { font-size: 9px; }
  .cal__phase { font-size: 9px; }
}

/* ─── Botón "Imprimir PDF" en el header ──────────────────────────────── */
.header__print {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-line);
  color: var(--color-graphite);
  font-family: var(--font-body);
  font-size: 12px;
  padding: 6px 10px;
  cursor: pointer;
  transition: border-color 120ms ease, color 120ms ease;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.header__print:hover {
  border-color: var(--color-ink);
  color: var(--color-ink);
}
.header__print-icon { font-size: 14px; line-height: 1; }
@media (max-width: 600px) { .header__print-label { display: none; } }

/* ─── Empty state · tabla SKU ────────────────────────────────────────── */
.tbl-sku__empty-row td { padding: 0 !important; }
.tbl-sku__empty {
  padding: var(--sp-6) var(--sp-4) !important;
  text-align: center;
  border: 1px dashed var(--color-line-strong) !important;
  border-radius: 4px;
  background: var(--color-bg-subtle);
}
.tbl-sku__empty-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 22px;
  color: var(--color-ink);
  margin: 0 0 var(--sp-2);
}
.tbl-sku__empty-sub {
  font-family: var(--font-body);
  font-size: var(--fs-meta);
  color: var(--color-graphite);
  margin: 0;
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
}
