/* ──────────────────────────────────────────────────────────────────────────
 * sv-tooltip.css — Tooltip del sparkline SmartView
 *
 * Aparece al hover sobre cada barra del sparkline.
 * Muestra hora, citas, ocupación, breakdown por estado, insight contextual.
 * ────────────────────────────────────────────────────────────────────────── */

.sv-tip {
  position: absolute;
  z-index: 60;
  width: 280px;
  padding: 12px 14px;
  border-radius: 10px;
  background: var(--bg-card);
  border: 0.5px solid var(--lk-brand-border, rgba(127, 119, 221, 0.30));
  box-shadow:
    0 12px 36px rgba(0, 0, 0, 0.45),
    0 2px 8px rgba(0, 0, 0, 0.20);
  font-family: inherit;
  color: var(--tx-base);
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .15s ease, transform .15s ease;
}

.sv-tip-show {
  opacity: 1;
  transform: translateY(0);
}

.sv-hidden {
  display: none !important;
}

/* ── Flecha apuntando a la barra activa ─────────────────────────────────── */
.sv-tip::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  background: var(--bg-card);
  border-left: 0.5px solid var(--lk-brand-border, rgba(127, 119, 221, 0.30));
  border-top: 0.5px solid var(--lk-brand-border, rgba(127, 119, 221, 0.30));
  top: -5px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
}

.sv-tip.sv-tip-up::before {
  top: auto;
  bottom: -5px;
  border-left: none;
  border-top: none;
  border-right: 0.5px solid var(--lk-brand-border, rgba(127, 119, 221, 0.30));
  border-bottom: 0.5px solid var(--lk-brand-border, rgba(127, 119, 221, 0.30));
}

/* ── Header: hora + tag ─────────────────────────────────────────────────── */
.sv-tip-head {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 10px;
}

.sv-tip-hour {
  font-size: 14px;
  font-weight: 500;
  color: var(--tx-base);
  font-variant-numeric: tabular-nums;
  font-family: ui-monospace, "SF Mono", Menlo, Monaco, monospace;
}

.sv-tip-tag {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 7px;
  border-radius: 8px;
  font-weight: 500;
  border: 0.5px solid;
}

.sv-tip-tag.sv-muted {
  background: var(--bg-surface);
  color: var(--tx-muted);
  border-color: var(--border);
}
.sv-tip-tag.sv-purple {
  background: var(--c-brand-muted);
  color: var(--c-brand-soft);
  border-color: var(--lk-brand-border, rgba(127, 119, 221, 0.30));
}
.sv-tip-tag.sv-warn {
  background: rgba(186, 117, 23, 0.14);
  color: #EF9F27;
  border-color: rgba(186, 117, 23, 0.30);
}
.sv-tip-tag.sv-ok {
  background: rgba(29, 158, 117, 0.14);
  color: #5DCAA5;
  border-color: rgba(29, 158, 117, 0.30);
}
.sv-tip-tag.sv-danger {
  background: rgba(163, 45, 45, 0.12);
  color: #F09595;
  border-color: rgba(226, 75, 74, 0.30);
}

/* ── Stats principales (citas + ocupación) ──────────────────────────────── */
.sv-tip-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 11px;
  padding: 10px;
  border-radius: 8px;
  background: var(--bg-surface);
  border: 0.5px solid var(--border);
}

.sv-tip-stat {
  display: flex;
  flex-direction: column;
  gap: 3px;
  line-height: 1;
}

.sv-tip-stat-lbl {
  font-size: 9.5px;
  color: var(--tx-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sv-tip-stat-val {
  font-size: 16px;
  font-weight: 500;
  color: var(--tx-base);
  font-variant-numeric: tabular-nums;
}

.sv-tip-stat-val.sv-red    { color: #F09595; }
.sv-tip-stat-val.sv-amber  { color: #EF9F27; }
.sv-tip-stat-val.sv-green  { color: #5DCAA5; }

/* ── Breakdown por estado ───────────────────────────────────────────────── */
.sv-tip-bd {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 11px;
  padding: 9px 10px;
  border-radius: 8px;
  background: var(--bg-surface);
  border: 0.5px solid var(--border);
}

.sv-tip-bd-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11.5px;
  color: var(--tx-base);
  line-height: 1.4;
}

.sv-tip-bd-row strong {
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  color: var(--tx-base);
}

.sv-tip-bd-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.sv-tip-bd-dot.sv-confirmed { background: #85B7EB; }
.sv-tip-bd-dot.sv-reserved  { background: var(--c-brand); }
.sv-tip-bd-dot.sv-attended  { background: #5DCAA5; }
.sv-tip-bd-dot.sv-cancelled { background: #E24B4A; }
.sv-tip-bd-dot.sv-pending   { background: #EF9F27; }

/* ── Insight contextual (recuadro lila) ─────────────────────────────────── */
.sv-tip-insight {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 9px 10px;
  border-radius: 8px;
  background: var(--c-brand-muted);
  border: 0.5px solid var(--lk-brand-border, rgba(127, 119, 221, 0.30));
  margin-bottom: 9px;
}

.sv-tip-insight svg {
  color: var(--c-brand-soft);
  flex-shrink: 0;
  margin-top: 1px;
}

.sv-tip-insight-text {
  font-size: 11.5px;
  color: var(--c-brand-soft);
  line-height: 1.4;
  font-weight: 500;
}

/* ── Footer (meta info) ─────────────────────────────────────────────────── */
.sv-tip-foot {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 9px;
  border-top: 0.5px solid var(--border);
}

.sv-tip-foot-meta {
  font-size: 10.5px;
  color: var(--tx-muted);
  line-height: 1.3;
  font-variant-numeric: tabular-nums;
}

/* ── Reduced motion ─────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .sv-tip {
    transition: opacity .05s ease;
    transform: none !important;
  }
}
