/* ═══════════════════════════════════════════════════════════════
   TEAMS WORKSPACE — Fase 7b
   ═══════════════════════════════════════════════════════════════ */

:root {
  --ws-open:        #7c3aed;
  --ws-open-soft:   rgba(124, 58, 237, 0.12);
  --ws-open-border: rgba(124, 58, 237, 0.40);
  --ws-priv:        #d97706;
  --ws-priv-soft:   rgba(217, 119, 6, 0.12);
  --ws-priv-border: rgba(217, 119, 6, 0.40);
}

.teams-page { padding: 1.5rem 0; }
.teams-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }
.teams-title { font-size: 1.15rem; font-weight: 700; margin: 0; }

.teams-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(440px, 1fr));
  gap: 1rem;
}

@media (max-width: 640px) {
  .teams-grid {
    grid-template-columns: 1fr;
  }
}

.team-card {
  background: var(--card-bg, #1e1e2e);
  border: 1px solid var(--border-color, rgba(255,255,255,0.08));
  border-radius: 12px;
  padding: 1.25rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  cursor: pointer;
  position: relative;
  transition: transform 0.15s, box-shadow 0.15s;
  overflow: visible;
}
.team-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.3); }
.team-card:has(.team-card__dropdown:not([hidden])) { z-index: 100; }

.team-card--open  { border-color: var(--ws-open-border); background: var(--ws-open-soft); }
.team-card--open:hover { box-shadow: 0 8px 24px rgba(124,58,237,0.18); }

.team-card--private { border-color: var(--ws-priv-border); background: var(--ws-priv-soft); }
.team-card--private:hover { box-shadow: 0 8px 24px rgba(217,119,6,0.18); }

/* ── Tarjeta de espacio compartido (invitado) ── */
.team-card--member {
  border-color: rgba(59,130,246,0.28);
  background: rgba(59,130,246,0.04);
}
.team-card--member:hover { box-shadow: 0 8px 24px rgba(59,130,246,0.15); }
.team-card--member .team-card__actions { display: none !important; }

/* Badge "Invitado" */
.team-card__type-badge--invited {
  background: rgba(59,130,246,0.18);
  color: #93c5fd;
  border: 1px solid rgba(59,130,246,0.35);
}

/* Avatar inicial del dueño */
.team-card__owner-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: var(--text-muted, #888);
}
.team-card__owner-avatar {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3b82f6, #6366f1);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.6rem; font-weight: 800; color: #fff; flex-shrink: 0;
}

/* Estado leaving: countdown activo */
.team-card--leaving {
  border-color: rgba(239,68,68,0.45) !important;
  background: rgba(239,68,68,0.06) !important;
  pointer-events: none;
  transform: none !important;
}
.team-card--leaving .team-card__countdown-wrap { pointer-events: all; }

/* Overlay de countdown */
.team-card__countdown-wrap {
  position: absolute; inset: 0;
  border-radius: 12px;
  display: none;
  flex-direction: column;
  align-items: stretch; justify-content: flex-end;
  z-index: 20;
  overflow: hidden;
  background: rgba(15,15,20,0.72);
  backdrop-filter: blur(2px);
}
.team-card--leaving .team-card__countdown-wrap { display: flex; }

/* Barra de progreso que depleta (misma animación que canvas-undo-inline) */
.team-card__countdown-bar {
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: rgba(239,68,68,0.2);
}
.team-card__countdown-bar__fill {
  height: 100%; width: 100%;
  background: linear-gradient(90deg, #ef4444, #f97316);
  transform-origin: left center;
  animation: wsCountdown 5s linear forwards;
}

/* Cuerpo del overlay: label + deshacer */
.team-card__countdown-body {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  font-size: 12px; white-space: nowrap;
  pointer-events: all;
}
.team-card__countdown-label {
  flex: 1; color: #d1d5db; font-size: 0.75rem;
}
.team-card__countdown-label b {
  color: #fff; font-variant-numeric: tabular-nums;
}

/* Botón deshacer */
.team-card__undo-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  background: rgba(124,77,255,0.22);
  color: #c4b5fd;
  border: 1px solid rgba(124,77,255,0.4);
  border-radius: 7px;
  font-size: 0.75rem; font-weight: 600;
  cursor: pointer; pointer-events: all;
  transition: background .12s, border-color .12s;
}
.team-card__undo-btn:hover { background: rgba(124,77,255,0.38); border-color: rgba(124,77,255,0.6); }

/* Tooltip de confirmación */
.team-card__confirm-tooltip {
  position: absolute; top: 36px; right: 10px; z-index: 200;
  background: var(--card-bg, #1e1e2e);
  border: 1px solid rgba(239,68,68,0.38);
  border-radius: 10px; padding: 12px 14px; min-width: 205px;
  box-shadow: 0 8px 32px rgba(0,0,0,.55);
  display: none;
}
.team-card__confirm-tooltip.is-open { display: block; }
.team-card__confirm-tooltip__title {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.83rem; font-weight: 700; color: #f87171; margin-bottom: 4px;
}
.team-card__confirm-tooltip__title svg { width: 14px; height: 14px; flex-shrink: 0; }
.team-card__confirm-tooltip__body {
  font-size: 0.75rem; color: var(--text-muted, #888);
  line-height: 1.45; margin-bottom: 11px;
}
.team-card__confirm-tooltip__actions { display: flex; gap: 6px; }
.team-card__confirm-btn {
  flex: 1; border: none; border-radius: 7px;
  padding: 6px 8px; font-size: 0.78rem; font-weight: 600;
  cursor: pointer; transition: opacity .15s;
}
.team-card__confirm-btn:hover { opacity: 0.82; }
.team-card__confirm-btn--cancel { background: rgba(255,255,255,0.08); color: var(--text-muted, #999); }
.team-card__confirm-btn--confirm { background: #ef4444; color: #fff; }
.team-card__confirm-btn:disabled { opacity: 0.55; cursor: wait; }

/* [v5.7.23] Variante --email del tooltip de confirmación: gradiente premium,
   borde sutil con glow violeta-rojo (refleja "vamos a enviar email para
   confirmar"), animación de entrada con scale + fade. Mejora visual sobre el
   tooltip base manteniendo posición y dimensiones para no romper layout. */
.team-card__confirm-tooltip--email {
  background: linear-gradient(180deg, #1f1f2e 0%, #18181f 100%);
  border: 1px solid rgba(239, 68, 68, 0.45);
  box-shadow:
    0 12px 36px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(124, 77, 255, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  min-width: 240px;
  padding: 14px 16px;
  transform-origin: top right;
  animation: team-card__confirm-pop 180ms cubic-bezier(0.22, 1, 0.36, 1);
}
.team-card__confirm-tooltip--email .team-card__confirm-tooltip__title {
  font-size: 0.86rem;
  letter-spacing: -0.1px;
  color: #fca5a5;
  margin-bottom: 6px;
}
.team-card__confirm-tooltip--email .team-card__confirm-tooltip__title svg {
  width: 15px; height: 15px;
  color: #ef4444;
  filter: drop-shadow(0 0 6px rgba(239, 68, 68, 0.4));
}
.team-card__confirm-tooltip--email .team-card__confirm-tooltip__body {
  font-size: 0.78rem;
  color: rgba(220, 220, 230, 0.78);
  line-height: 1.5;
  margin-bottom: 13px;
}
.team-card__confirm-tooltip--email .team-card__confirm-tooltip__body strong {
  color: #f5f5f7;
  font-weight: 600;
}
.team-card__confirm-tooltip--email .team-card__confirm-btn--cancel {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(220, 220, 230, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.team-card__confirm-tooltip--email .team-card__confirm-btn--cancel:hover {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  opacity: 1;
}
.team-card__confirm-tooltip--email .team-card__confirm-btn--confirm {
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  color: #fff;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.3);
}
.team-card__confirm-tooltip--email .team-card__confirm-btn--confirm:hover {
  background: linear-gradient(135deg, #f87171 0%, #ef4444 100%);
  box-shadow: 0 6px 18px rgba(220, 38, 38, 0.4);
  opacity: 1;
}
@keyframes team-card__confirm-pop {
  from { opacity: 0; transform: translateY(-6px) scale(0.94); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* [v5.7.23] Landing page de confirmación de eliminación (/ws-delete/:token).
   Layout centrado vertical + card premium con CSS sobre el tema dark.
   Variantes: --danger (confirmar), --success (post-delete), --invalid (token
   roto), --auth (pide login). */
.ws-delete-confirm-page {
  min-height: calc(100vh - 60px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  background: radial-gradient(ellipse at top, rgba(124, 77, 255, 0.04), transparent 60%);
}
.ws-delete-confirm-card {
  background: linear-gradient(180deg, #1f1f2e 0%, #16161f 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  padding: 40px 36px 32px;
  max-width: 440px;
  width: 100%;
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.55),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  text-align: center;
  animation: ws-delete-confirm-pop 240ms cubic-bezier(0.22, 1, 0.36, 1);
}
.ws-delete-confirm-card--danger { border-color: rgba(239, 68, 68, 0.28); }
.ws-delete-confirm-card--success { border-color: rgba(74, 222, 128, 0.28); }
.ws-delete-confirm-card--invalid { border-color: rgba(251, 191, 36, 0.28); }
.ws-delete-confirm-icon {
  width: 64px; height: 64px;
  margin: 0 auto 20px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.04);
}
.ws-delete-confirm-icon svg { width: 30px; height: 30px; }
.ws-delete-confirm-icon--danger {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.18), rgba(220, 38, 38, 0.12));
  border: 1px solid rgba(239, 68, 68, 0.35);
  color: #f87171;
}
.ws-delete-confirm-icon--success {
  background: linear-gradient(135deg, rgba(74, 222, 128, 0.18), rgba(34, 197, 94, 0.12));
  border: 1px solid rgba(74, 222, 128, 0.35);
  color: #4ade80;
}
.ws-delete-confirm-icon--warning {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.18), rgba(245, 158, 11, 0.12));
  border: 1px solid rgba(251, 191, 36, 0.35);
  color: #fbbf24;
}
.ws-delete-confirm-icon--auth {
  background: linear-gradient(135deg, rgba(124, 77, 255, 0.18), rgba(99, 102, 241, 0.12));
  border: 1px solid rgba(124, 77, 255, 0.35);
  color: #a78bfa;
}
.ws-delete-confirm-title {
  font-size: 22px;
  font-weight: 700;
  color: #f5f5f7;
  letter-spacing: -0.4px;
  margin: 0 0 12px;
}
.ws-delete-confirm-desc {
  font-size: 14.5px;
  line-height: 1.55;
  color: rgba(220, 220, 230, 0.75);
  margin: 0 0 20px;
}
.ws-delete-confirm-desc strong { color: #f5f5f7; font-weight: 600; }
.ws-delete-confirm-warning {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px;
  background: rgba(251, 191, 36, 0.06);
  border: 1px solid rgba(251, 191, 36, 0.18);
  border-radius: 10px;
  font-size: 13px;
  color: rgba(251, 191, 36, 0.95);
  text-align: left;
  line-height: 1.5;
  margin-bottom: 18px;
}
.ws-delete-confirm-warning svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px; }
.ws-delete-confirm-expires {
  font-size: 12px;
  color: rgba(180, 180, 200, 0.55);
  margin: 0 0 24px;
}
.ws-delete-confirm-actions {
  display: flex; gap: 10px;
  justify-content: center;
  margin-top: 8px;
}
.ws-delete-confirm-btn {
  border: none;
  border-radius: 10px;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 160ms cubic-bezier(0.22, 1, 0.36, 1);
  font-family: inherit;
}
.ws-delete-confirm-btn:disabled { opacity: 0.55; cursor: wait; }
.ws-delete-confirm-btn--ghost {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(220, 220, 230, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.ws-delete-confirm-btn--ghost:hover {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
}
.ws-delete-confirm-btn--danger {
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  color: #fff;
  box-shadow: 0 6px 16px rgba(220, 38, 38, 0.3);
}
.ws-delete-confirm-btn--danger:hover {
  background: linear-gradient(135deg, #f87171 0%, #ef4444 100%);
  box-shadow: 0 8px 22px rgba(220, 38, 38, 0.4);
  transform: translateY(-1px);
}
.ws-delete-confirm-btn--primary {
  background: linear-gradient(135deg, #7c4dff 0%, #6366f1 100%);
  color: #fff;
  box-shadow: 0 6px 16px rgba(99, 102, 241, 0.3);
}
.ws-delete-confirm-btn--primary:hover {
  background: linear-gradient(135deg, #a78bfa 0%, #7c4dff 100%);
  box-shadow: 0 8px 22px rgba(99, 102, 241, 0.4);
  transform: translateY(-1px);
}
.ws-delete-confirm-loading {
  font-size: 13px;
  color: rgba(180, 180, 200, 0.6);
  margin-top: 16px;
}
@keyframes ws-delete-confirm-pop {
  from { opacity: 0; transform: translateY(8px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Sección header de la grilla */
.teams-section { margin-bottom: 2rem; }
.teams-section__header {
  display: flex; align-items: center; gap: 0.6rem;
  margin-bottom: 0.9rem; padding-bottom: 0.4rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.teams-section__title {
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-muted, #888);
}
.teams-section__count {
  font-size: 0.7rem; background: rgba(255,255,255,0.07);
  color: var(--text-muted, #888); border-radius: 999px; padding: 1px 7px;
}
.teams-section__icon { width: 14px; height: 14px; color: var(--text-muted, #888); flex-shrink: 0; }

.team-card--pending-delete {
  opacity: 0.45;
  pointer-events: none;
  border-color: rgba(239,68,68,0.4);
}
.team-card--pending-delete .canvas-undo-inline {
  pointer-events: auto;
}

.team-card__type-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 22px;             /* altura fija — homologa con ai-badge */
  box-sizing: border-box;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0 10px;          /* sin padding vertical, height fija lo controla */
  border-radius: 999px;
  line-height: 1;
  margin-bottom: 0.25rem;
  align-self: flex-start;
}
.team-card__type-badge--open    { background: var(--ws-open); color: #fff; }
.team-card__type-badge--private { background: var(--ws-priv); color: #fff; }

/* v5.7.2 — Diferenciación visual de workspaces con análisis IA activo.
   El badge IA se renderiza inline junto al badge de tipo (OPEN/PRIVADO) en
   la esquina superior izquierda. La card recibe accent border-top + glow
   violeta sutil para identificación de un vistazo entre todas. */
.team-card__badges-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.team-card__ai-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 22px;             /* misma altura que type-badge */
  box-sizing: border-box;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0 10px;
  border-radius: 999px;
  line-height: 1;
  background: linear-gradient(135deg, #7c3aed 0%, #a78bfa 100%);
  color: #fff;
  box-shadow: 0 2px 8px rgba(124, 58, 237, 0.45), 0 0 0 1px rgba(167, 139, 250, 0.6) inset;
  pointer-events: none;
  align-self: flex-start;
}
/* Forzar dimensiones idénticas en los SVG de Lucide dentro de los badges
   (algunos iconos como sparkles tienen viewBox con padding interno que
   los hace ver más altos a igualdad de width/height). */
.team-card__ai-badge i,
.team-card__type-badge i,
.team-card__ai-badge svg,
.team-card__type-badge svg {
  width: 12px !important;
  height: 12px !important;
  flex-shrink: 0;
  display: block;
}
.team-card.has-ai-reports {
  position: relative;
  border-color: rgba(124, 58, 237, 0.4) !important;
  box-shadow: 0 0 0 1px rgba(124, 58, 237, 0.25), 0 6px 20px rgba(124, 58, 237, 0.15);
}
.team-card.has-ai-reports::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, #a78bfa 30%, #7c3aed 70%, transparent 100%);
  border-radius: 12px 12px 0 0;
  pointer-events: none;
}

/* Botón de toolbar para toggle ai_reports en el workspace abierto */
.canvas-toolbar__btn.ws-ai-reports-btn.is-active {
  background: rgba(124, 58, 237, 0.18) !important;
  border-color: rgba(167, 139, 250, 0.5) !important;
}
.canvas-toolbar__btn.ws-ai-reports-btn.is-locked {
  cursor: help;
  opacity: 0.85;
}

/* v5.7.6 — Barra de progreso del auto-save (debounce 10s).
   Rediseñado sobre v5.7.3: el dot pulsante se reemplaza por una barra
   horizontal en el borde superior del textarea que llena de 0% a 100%
   en 10s linear. Cada 'input' reinicia la animación (ver views-teams.js
   — toggle del atributo con force reflow). Al llegar al 100% se dispara
   el save y el atributo se remueve (la barra desaparece).

   Comportamiento independiente del foco: aunque el usuario haga blur,
   la barra sigue llenándose porque el timer corre en JS — lo único que
   la resetea es teclear de nuevo. */
.canvas-note-text[contenteditable] {
  position: relative;  /* anchor para la barra */
}
.canvas-note-text::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: 2.5px;
  width: 0%;
  background: linear-gradient(90deg, #fbbf24 0%, #f59e0b 100%);
  box-shadow: 0 0 5px rgba(251, 191, 36, 0.55);
  border-radius: 2px 2px 0 0;
  opacity: 0;
  pointer-events: none;
  z-index: 3;
}
.canvas-note-text[data-pending-save="1"]::before {
  opacity: 1;
  animation: noteAutosaveFill 5s linear forwards;
}
@keyframes noteAutosaveFill {
  from { width: 0%; }
  to   { width: 100%; }
}

.team-card__name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary, #fff);
  line-height: 1.3;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  word-break: break-word;
}
.team-card__meta { font-size: 0.75rem; color: var(--text-muted, #888); }
.team-card__meta-piece { white-space: nowrap; display: inline-block; }

.team-card__actions { display: none; gap: 0.3rem; flex-wrap: wrap; margin-top: 0.5rem; }
.team-card:hover .team-card__actions { display: flex; }

.team-card__action-btn {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 6px;
  color: var(--text-primary, #fff);
  font-size: 0.72rem;
  padding: 3px 9px;
  cursor: pointer;
  transition: background 0.12s;
}
.team-card__action-btn:hover { background: rgba(255,255,255,0.12); }

/* Kebab menu (top-right del card) */
.team-card__menu-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 26px;
  height: 26px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  color: var(--text-muted, #999);
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.15s, background 0.12s, color 0.12s;
  z-index: 2;
}
.team-card:hover .team-card__menu-btn,
.team-card__menu-btn:focus-visible { opacity: 1; }
.team-card__menu-btn:hover { background: rgba(255,255,255,0.12); color: var(--text-primary, #fff); }
.team-card__menu-btn i, .team-card__menu-btn svg { width: 16px; height: 16px; }

/* Dropdown del kebab */
@keyframes ws-dropdown-in {
  from { opacity: 0; transform: translateY(-6px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.team-card__dropdown {
  position: absolute;
  top: 36px;
  right: 4px;
  min-width: 192px;
  background: linear-gradient(160deg, #1f1f2b 0%, #17171f 100%);
  border: 1px solid rgba(255,255,255,0.13);
  border-radius: 10px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.55), 0 2px 8px rgba(0,0,0,0.3);
  padding: 6px;
  z-index: 200;
  display: flex;
  flex-direction: column;
  gap: 1px;
  animation: ws-dropdown-in 0.14s cubic-bezier(0.16,1,0.3,1);
}
.team-card__dropdown[hidden] { display: none; }

.team-card__dropdown-header {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-muted, #666);
  padding: 4px 10px 6px;
}

.team-card__dropdown-divider {
  height: 1px;
  background: rgba(255,255,255,0.07);
  margin: 4px 6px;
}

.team-card__dropdown-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  background: transparent;
  border: none;
  border-left: 2px solid transparent;
  border-radius: 7px;
  color: var(--text-primary, #fff);
  font-size: 0.82rem;
  text-align: left;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
  width: 100%;
}
.team-card__dropdown-item:not([disabled]):hover {
  background: rgba(255,255,255,0.07);
  border-left-color: rgba(255,255,255,0.18);
}
.team-card__dropdown-item i, .team-card__dropdown-item svg { width: 14px; height: 14px; flex-shrink: 0; opacity: 0.75; }
.team-card__dropdown-item:not([disabled]):hover i,
.team-card__dropdown-item:not([disabled]):hover svg { opacity: 1; }

/* Danger */
.team-card__dropdown-item--danger { color: #f87171; }
.team-card__dropdown-item--danger i,
.team-card__dropdown-item--danger svg { opacity: 0.8; }
.team-card__dropdown-item--danger:hover {
  background: rgba(239,68,68,0.10) !important;
  border-left-color: #ef4444 !important;
  color: #fca5a5 !important;
}
.team-card__dropdown-item--danger:hover i,
.team-card__dropdown-item--danger:hover svg { opacity: 1; }

/* Disabled (workspace con contenido) */
.team-card__dropdown-item--disabled {
  opacity: 0.45;
  cursor: not-allowed;
  align-items: flex-start;
}
.team-card__dropdown-item-col {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.team-card__dropdown-item-hint {
  font-size: 0.68rem;
  color: var(--text-muted, #888);
  line-height: 1.2;
}

/* Inline rename input (sustituye al .team-card__name) */
.team-card__name-input {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary, #fff);
  line-height: 1.3;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--accent, #7c3aed);
  border-radius: 6px;
  padding: 4px 8px;
  width: 100%;
  outline: none;
  font-family: inherit;
}

/* ── Workspace 3-column interior ── */
.ws-layout {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.ws-toolbar { display: none; }

/* ── Watch Party — panel de video compartido ─────────────────────────────── */
.ws-video-bar {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  background: #0d0d1a;
  border-bottom: 2px solid #6c63ff;
  flex-shrink: 0;
  z-index: 20;
}

.ws-video-leave-corner {
  position: absolute;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  background: #c0392b;
  border: none;
  color: #fff;
  border-radius: 6px;
  padding: 6px 12px;
  font-size: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.15s;
  z-index: 21;
}

.ws-video-leave-corner:hover {
  background: #e04b3a;
}

.ws-video-thumb {
  width: 240px;
  height: 136px;
  border-radius: 6px;
  overflow: hidden;
  flex-shrink: 0;
  background: #000;
  border: 1px solid rgba(108,99,255,0.3);
}

.ws-video-thumb iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

.ws-video-info {
  flex: 1;
  min-width: 0;
}

.ws-video-title {
  color: #fff;
  font-size: 0.72rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
}

.ws-video-subtitle {
  color: #888;
  font-size: 0.68rem;
  margin-bottom: 5px;
}

.ws-video-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.ws-video-controls .ws-vbtn {
  background: #1e1e2e;
  color: #ccc;
  border: 1px solid #333;
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 0.68rem;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}

.ws-video-controls .ws-vbtn:hover {
  background: #2a2a40;
  color: #fff;
}

.ws-video-controls .ws-vbtn--end {
  background: #7b1f1f;
  border-color: #c0392b;
  color: #fff;
}

.ws-video-controls .ws-vbtn--end:hover {
  background: #c0392b;
}

.ws-video-live-badge {
  background: #c0392b;
  color: #fff;
  font-size: 0.62rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 3px;
  letter-spacing: 0.03em;
}

.ws-mode-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  user-select: none;
}
.ws-mode-chip--admin {
  background: rgba(220, 38, 38, 0.18);
  color: #fca5a5;
  border: 1px solid rgba(220, 38, 38, 0.5);
}
.ws-mode-chip--autonomous {
  background: rgba(108, 99, 255, 0.18);
  color: #c4b5fd;
  border: 1px solid rgba(108, 99, 255, 0.5);
}
.ws-mode-chip--clickable {
  cursor: pointer;
  transition: opacity 120ms ease;
}
.ws-mode-chip--clickable:hover { opacity: 0.85; }
.ws-mode-chip--clickable:focus-visible {
  outline: 2px solid #6c63ff;
  outline-offset: 2px;
}

.ws-mode-popover {
  z-index: 10000;
  background: #0d0d1a;
  border: 1px solid #6c63ff;
  border-radius: 8px;
  padding: 8px;
  min-width: 260px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ws-mode-popover__title {
  font-size: 0.7rem;
  font-weight: 700;
  color: #888;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 6px 6px;
}
.ws-mode-popover__option {
  display: grid;
  grid-template-columns: 16px 1fr;
  grid-template-rows: auto auto;
  column-gap: 8px;
  padding: 8px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  text-align: left;
  color: #ddd;
  font-size: 0.78rem;
}
.ws-mode-popover__option:hover:not([disabled]) { background: rgba(108, 99, 255, 0.12); }
.ws-mode-popover__option[data-selected="1"] { background: rgba(108, 99, 255, 0.18); border-color: rgba(108, 99, 255, 0.5); }
.ws-mode-popover__option[disabled] { cursor: not-allowed; opacity: 0.85; }
.ws-mode-popover__radio {
  grid-row: 1 / span 2;
  align-self: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 2px solid #6c63ff;
  background: transparent;
  position: relative;
}
.ws-mode-popover__option[data-selected="1"] .ws-mode-popover__radio::after {
  content: ''; position: absolute;
  inset: 2px; border-radius: 50%;
  background: #6c63ff;
}
.ws-mode-popover__label { font-weight: 700; }
.ws-mode-popover__desc { font-size: 0.7rem; color: #888; }

.ws-admin-countdown-banner {
  position: absolute;
  bottom: -28px;
  left: 14px;
  background: rgba(108, 99, 255, 0.94);
  color: #fff;
  padding: 4px 10px;
  font-size: 0.72rem;
  border-radius: 4px;
  font-weight: 600;
  animation: ws-chat-toast-in 180ms ease-out;
  z-index: 22;
}

.ws-video-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(108,99,255,0.15);
  border: 1px solid rgba(108,99,255,0.4);
  color: #a29bfe;
  border-radius: 5px;
  padding: 4px 10px;
  font-size: 0.7rem;
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}

.ws-video-share-btn:hover {
  background: rgba(108,99,255,0.3);
  color: #fff;
}

/* Título flotante del workspace — debajo de la canvas-toolbar */
.canvas-ws-title {
  position: absolute;
  top: 62px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9;
  background: rgba(30, 30, 46, 0.88);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 24px;
  padding: 5px 20px;
  font-weight: 600;
  font-size: 0.88rem;
  letter-spacing: 0.01em;
  color: rgba(255,255,255,0.70);
  white-space: nowrap;
  backdrop-filter: blur(6px);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.canvas-ws-title.is-visible { opacity: 1; }
#ws-canvas-viewport.bg-light .canvas-ws-title {
  background: rgba(255,255,255,0.88);
  border-color: rgba(0,0,0,0.08);
  color: rgba(0,0,0,0.55);
}
.ws-toolbar__title-input {
  flex: 1;
  font-weight: 600;
  font-size: 0.95rem;
  background: rgba(255,255,255,0.12);
  border: 1px solid var(--accent, #7c3aed);
  border-radius: 4px;
  color: inherit;
  padding: 4px 10px;
  margin-left: 16px;
  outline: none;
  text-align: center;
}
.ws-toolbar__actions { display: flex; gap: 0.4rem; }

/* Stage = canvas full-width + drawers flotantes */
.ws-stage {
  position: relative;
  flex: 1;
  overflow: hidden;
}
.ws-stage__canvas {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
}
.ws-stage__canvas .ws-canvas-area {
  position: relative;
  flex: 1;
  overflow: hidden;
  background: var(--canvas-bg, #0f0f1a);
  transition: background 200ms ease;
}

/* Drawers flotantes sobre el canvas — bordes púrpura moderados (C1) para
   destacar como tarjetas independientes. Asimétrico: 2px en el lado hacia el
   canvas + 1.5px en los otros tres lados. Invariante v5.6.1: siempre paleta
   oscura, independiente del toggle .bg-light/.bg-dark del canvas. */
.ws-drawer {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 360px;
  max-width: 90vw;
  background: rgba(18, 18, 28, 0.96);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.18);
  display: flex;
  flex-direction: column;
  z-index: 20;
  transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1), opacity 200ms ease;
  pointer-events: none;
  opacity: 0;
}
.ws-drawer.is-open { pointer-events: auto; opacity: 1; }
.ws-drawer--feed {
  left: 10px;
  top: 10px;
  bottom: 10px;
  border-radius: 14px;
  border: 1.5px solid rgba(124,77,255,0.35);
  border-right: 2px solid rgba(124,77,255,0.80);
  overflow: hidden;
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  box-shadow:
    32px 0 64px -8px rgba(0,0,0,0.80),
    0 0 0 1px rgba(124,77,255,0.25),
    0 0 32px 4px rgba(124,77,255,0.28),
    inset 0 1px 0 rgba(255,255,255,0.12);
  transform: translateX(calc(-100% - 12px));
}
.ws-drawer--feed.is-open { transform: translateX(0); }

/* Scrollbar custom del drawer del feed — espejo del chat, acento violeta */
.ws-drawer--feed .ws-drawer__body::-webkit-scrollbar { width: 6px; }
.ws-drawer--feed .ws-drawer__body::-webkit-scrollbar-track { background: transparent; }
.ws-drawer--feed .ws-drawer__body::-webkit-scrollbar-thumb {
  background: rgba(124,58,237,0.28);
  border-radius: 3px;
}
.ws-drawer--feed .ws-drawer__body::-webkit-scrollbar-thumb:hover {
  background: rgba(124,58,237,0.5);
}
.ws-drawer--chat {
  right: 10px;
  top: 10px;
  bottom: 10px;
  border-radius: 14px;
  border: 1.5px solid rgba(124,77,255,0.35);
  border-left: 2px solid rgba(124,77,255,0.80);
  overflow: hidden;
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  box-shadow:
    -32px 0 64px -8px rgba(0,0,0,0.80),
    0 0 0 1px rgba(124,77,255,0.25),
    0 0 32px 4px rgba(124,77,255,0.28),
    inset 0 1px 0 rgba(255,255,255,0.12);
  transform: translateX(calc(100% + 12px));
}
.ws-drawer--chat.is-open { transform: translateX(0); }

/* Pill CTA "Cargar mensajes anteriores" — sticky al top del drawer, fuera del
   scroll container. Solo visible cuando el usuario está cerca del top y aún
   queda histórico. La carga es siempre explícita por clic. */
.ws-chat-load-older {
  position: absolute;
  top: 10px;
  left: 50%;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: rgba(20,20,32,0.92);
  backdrop-filter: blur(12px) saturate(1.1);
  -webkit-backdrop-filter: blur(12px) saturate(1.1);
  border: 1px solid rgba(124,58,237,0.35);
  border-radius: 999px;
  color: var(--text-primary, #fff);
  font-family: inherit;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -12px);
  transition:
    opacity 180ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 180ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 160ms ease,
    box-shadow 160ms ease;
  box-shadow:
    0 6px 20px -6px rgba(0,0,0,0.55),
    0 0 0 1px rgba(124,58,237,0.12);
}
.ws-chat-load-older.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
.ws-chat-load-older:hover {
  border-color: var(--accent, #7c3aed);
  transform: translate(-50%, -1px);
  box-shadow:
    0 8px 24px -6px rgba(0,0,0,0.6),
    0 0 0 1px rgba(124,58,237,0.28);
}
.ws-chat-load-older:disabled,
.ws-chat-load-older.is-loading {
  cursor: default;
}
.ws-chat-load-older.is-end {
  cursor: default;
  border-color: rgba(255,255,255,0.12);
  background: rgba(20,20,32,0.75);
  color: var(--text-muted, #9ca3af);
  box-shadow: 0 4px 12px -4px rgba(0,0,0,0.4);
}
.ws-chat-load-older.is-end:hover {
  transform: translate(-50%, 0);
  box-shadow: 0 4px 12px -4px rgba(0,0,0,0.4);
}
.ws-chat-load-older__icon {
  font-size: 0.78rem;
  line-height: 1;
  color: var(--accent, #a78bfa);
}
.ws-chat-load-older.is-end .ws-chat-load-older__icon {
  color: var(--text-muted, #9ca3af);
}
.ws-chat-load-older__spinner {
  width: 12px;
  height: 12px;
  border: 2px solid rgba(255,255,255,0.15);
  border-top-color: var(--accent, #7c3aed);
  border-radius: 50%;
  animation: ws-chat-spin 0.7s linear infinite;
}
@keyframes ws-chat-spin {
  to { transform: rotate(360deg); }
}

/* Scrollbar custom del drawer del chat — tinte de acento sutil */
.ws-drawer--chat .ws-drawer__body::-webkit-scrollbar { width: 6px; }
.ws-drawer--chat .ws-drawer__body::-webkit-scrollbar-track { background: transparent; }
.ws-drawer--chat .ws-drawer__body::-webkit-scrollbar-thumb {
  background: rgba(124,58,237,0.28);
  border-radius: 3px;
}
.ws-drawer--chat .ws-drawer__body::-webkit-scrollbar-thumb:hover {
  background: rgba(124,58,237,0.5);
}
.ws-drawer__body { flex: 1; overflow-y: auto; padding: 0.5rem; }
.ws-drawer--feed .ws-drawer__body { padding: 0.4rem; }

/* Toggles en la toolbar */
.ws-toolbar__toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-color, rgba(255,255,255,0.08));
  color: var(--text-muted, #888);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.ws-toolbar__toggle i, .ws-toolbar__toggle svg { width: 14px; height: 14px; }
.ws-toolbar__toggle:hover { background: rgba(255,255,255,0.08); color: var(--text-primary, #fff); }
.ws-toolbar__toggle.is-active {
  background: rgba(124,58,237,0.18);
  border-color: var(--accent, #7c3aed);
  color: var(--accent, #a78bfa);
}

.ws-col {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-right: 1px solid var(--border-color, rgba(255,255,255,0.08));
}
.ws-col:last-child { border-right: none; }

.ws-col__header {
  padding: 0.35rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-muted, #888);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border-color, rgba(255,255,255,0.08));
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-shrink: 0;
  background: var(--card-bg, #1e1e2e);
}
.ws-col__header i, .ws-col__header svg { width: 14px; height: 14px; }

.ws-col__body { flex: 1; overflow-y: auto; padding: 0.5rem; }

.ws-col--feed .ws-col__body { padding: 0.4rem; }

.ws-col--canvas .ws-col__body {
  position: relative;
  overflow: hidden;
  background: var(--canvas-bg, #0f0f1a);
  padding: 0;
  transition: background 200ms ease;
}
/* Canvas en modo claro — fondo blanco cálido (sin grid por default) */
#ws-canvas-viewport.bg-light {
  background: #fafaf7;
}
/* Grid en modo claro — líneas oscuras sutiles */
#ws-canvas-viewport.bg-light.grid-on {
  background:
    linear-gradient(rgba(0,0,0,0.06) 1px, transparent 1px) 0 0 / 24px 24px,
    linear-gradient(90deg, rgba(0,0,0,0.06) 1px, transparent 1px) 0 0 / 24px 24px,
    #fafaf7;
}
/* Grid en modo oscuro — líneas claras sutiles que contrasten ligeramente */
#ws-canvas-viewport.bg-dark.grid-on {
  background:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px) 0 0 / 24px 24px,
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px) 0 0 / 24px 24px,
    var(--canvas-bg, #0f0f1a);
}
#ws-canvas-viewport.bg-light .canvas-toolbar {
  background: rgba(255,255,255,0.82);
  border-color: rgba(0,0,0,0.08);
  box-shadow:
    0 10px 32px -12px rgba(0,0,0,0.18),
    0 0 0 1px rgba(0,0,0,0.04);
}
#ws-canvas-viewport.bg-light .canvas-toolbar__btn {
  color: rgba(0,0,0,0.55);
}
#ws-canvas-viewport.bg-light .canvas-toolbar__btn:hover {
  background: rgba(0,0,0,0.05);
  color: rgba(0,0,0,0.85);
}
#ws-canvas-viewport.bg-light .canvas-toolbar__btn.active {
  background: rgba(124,58,237,0.15);
  border-color: rgba(124,58,237,0.4);
  color: var(--accent, #7c3aed);
  box-shadow: 0 0 0 1px rgba(124,58,237,0.2) inset;
}
#ws-canvas-viewport.bg-light .canvas-toolbar__sep {
  background: rgba(0,0,0,0.10);
}

#ws-canvas-items {
  position: relative;
  width: 100%;
  height: 100%;
  transform-origin: 0 0;
  will-change: transform;
}
/* Toolbar flotante del canvas */
.canvas-toolbar {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px;
  background: linear-gradient(180deg, var(--cv-panel-raised), var(--cv-panel));
  border: 1px solid var(--cv-border-strong);
  border-radius: 12px;
  box-shadow: 0 10px 32px rgba(0,0,0,0.4), 0 0 0 1px rgba(139,92,246,0.04);
  font-family: Inter, -apple-system, system-ui, sans-serif;
  z-index: 10;
}
.canvas-toolbar__btn {
  width: 32px; height: 32px;
  border-radius: 7px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--cv-text-dim);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: all 0.12s;
  position: relative;
}
.canvas-toolbar__btn:hover {
  background: var(--cv-panel-hover);
  color: var(--cv-text);
}
.canvas-toolbar__btn.active {
  background: var(--sbr-violet-soft);
  border-color: var(--sbr-violet-border);
  color: var(--cv-violet-bright);
}
.canvas-toolbar__btn i,
.canvas-toolbar__btn svg { width: 16px; height: 16px; }
.canvas-toolbar__sep {
  width: 1px;
  height: 20px;
  background: var(--cv-border);
  margin: 0 4px;
}

/* Grupo contenedor — opcional, pero ayuda a alinear */
.canvas-toolbar__group {
  display: flex;
  align-items: center;
  gap: 2px;
}

/* Label del zoom (reset %) */
.canvas-toolbar__zoom-label {
  padding: 0 10px;
  font-size: 12px;
  color: var(--cv-text-dim);
  min-width: 50px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  user-select: none;
}

/* Botón de añadir — acción primaria con gradient */
.canvas-toolbar__btn--add {
  background: linear-gradient(135deg, var(--sbr-violet), var(--cv-violet-deep));
  color: #fff;
  box-shadow: 0 4px 12px var(--cv-violet-glow);
}
.canvas-toolbar__btn--add:hover {
  background: linear-gradient(135deg, var(--sbr-violet), var(--cv-violet-deep));
  color: #fff;
  filter: brightness(1.15);
}

/* Botón "Compartir video" (solo owner) — pill con texto */
.canvas-toolbar__share-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: rgba(139,92,246,0.10);
  border: 1px solid var(--sbr-violet-border);
  border-radius: 7px;
  color: var(--cv-violet-bright);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.12s;
}
.canvas-toolbar__share-btn:hover { background: var(--sbr-violet-soft); }
.canvas-toolbar__share-btn svg,
.canvas-toolbar__share-btn i { width: 13px; height: 13px; }

/* Botón Salir — texto + icono, dentro del toolbar */
.canvas-toolbar__exit {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 6px 12px 6px 10px;
  background: transparent;
  border: 1px solid var(--cv-border);
  border-radius: 7px;
  color: var(--cv-text-dim);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s;
}
.canvas-toolbar__exit:hover {
  background: var(--cv-panel-hover);
  color: var(--cv-text);
  border-color: var(--cv-border-strong);
}
.canvas-toolbar__exit svg,
.canvas-toolbar__exit i { width: 13px; height: 13px; }

.canvas-toolbar__zoom {
  min-width: 52px;
  justify-content: center;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  font-size: 0.72rem;
}
/* ── Off-screen element beacons ── */
@keyframes beacon-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(124,58,237,0.35); }
  50%       { box-shadow: 0 0 0 6px rgba(124,58,237,0); }
}
.ws-beacon {
  position: absolute;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  background: rgba(124,58,237,0.82);
  backdrop-filter: blur(6px);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  border: none;
  border-radius: 20px;
  padding: 4px 10px;
  cursor: pointer;
  pointer-events: all;
  transition: opacity 0.15s, transform 0.15s, background 0.12s,
              left 0.24s cubic-bezier(0.22,1,0.36,1),
              right 0.24s cubic-bezier(0.22,1,0.36,1);
  animation: beacon-pulse 2s ease-in-out infinite;
}
.ws-beacon:hover { background: rgba(124,58,237,1); transform: scale(1.08); }
.ws-beacon[hidden] { display: none; }
.ws-beacon--top    { top: 56px;  left: 50%; transform: translateX(-50%); }
.ws-beacon--bottom { bottom: 12px; left: 50%; transform: translateX(-50%); }
.ws-beacon--left   { left: 12px; top: 50%; transform: translateY(-50%); }
.ws-beacon--right  { right: 12px; top: 50%; transform: translateY(-50%); }
.ws-beacon--top:hover    { transform: translateX(-50%) scale(1.08); }
.ws-beacon--bottom:hover { transform: translateX(-50%) scale(1.08); }
.ws-beacon--left:hover   { transform: translateY(-50%) scale(1.08); }
.ws-beacon--right:hover  { transform: translateY(-50%) scale(1.08); }

/* Cursor del viewport según modo */
#ws-canvas-viewport                    { cursor: grab; }
#ws-canvas-viewport.mode-pan           { cursor: all-scroll; }
#ws-canvas-viewport.panning            { cursor: grabbing; }
#ws-canvas-viewport .canvas-item       { cursor: grab; }
#ws-canvas-viewport .canvas-toolbar    { cursor: default; }

.ws-add-note-btn {
  margin-left: auto;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 6px;
  color: var(--text-primary, #fff);
  font-size: 0.72rem;
  padding: 3px 9px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.3rem;
}
.ws-add-note-btn:hover { background: rgba(255,255,255,0.12); }

.ws-col--chat { display: flex; flex-direction: column; }
.ws-col--chat .ws-col__body,
.ws-drawer--chat .ws-drawer__body {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 0.5rem 0.6rem;
}

.ws-chat-input-row {
  display: flex; gap: 0.35rem;
  padding: 0.55rem 0.6rem 0.6rem;
  border-top: 1px solid rgba(255,255,255,0.04);
  background: linear-gradient(to top, rgba(20,20,32,0.92) 60%, rgba(20,20,32,0));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  flex-shrink: 0;
}
.ws-chat-input {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border-color, rgba(255,255,255,0.10));
  border-radius: 6px;
  padding: 5px 9px;
  color: var(--text-primary, #fff);
  font-size: 0.8rem;
}
.ws-chat-input:focus { outline: none; border-color: var(--accent, #7c3aed); }
.ws-chat-send-btn {
  background: var(--accent, #7c3aed);
  border: none; border-radius: 6px;
  color: #fff; padding: 5px 11px;
  cursor: pointer; font-size: 0.78rem;
  /* [v5.7.27.122] flex-shrink:0 evita que el botón "Enviar" se trunque
     cuando el container es estrecho (theater chat: 260px). El input tiene
     flex:1 y consume el espacio disponible; sin esto, el botón colapsaba
     bajo su ancho natural y el texto quedaba clipped al borde derecho. */
  flex-shrink: 0;
  white-space: nowrap;
}
.ws-chat-send-btn:hover { opacity: 0.85; }

.ws-chat-msg { display: flex; flex-direction: column; max-width: 82%; }
.ws-chat-msg--mine { align-self: flex-end; align-items: flex-end; }
.ws-chat-msg__sender { font-size: 0.68rem; color: var(--accent, #7c3aed); font-weight: 700; margin-bottom: 2px; padding-left: 4px; }
.ws-chat-msg__text {
  font-size: 0.8rem;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 4px 14px 14px 14px;
  padding: 6px 10px;
  line-height: 1.45;
  word-break: break-word;
  color: var(--text-primary, #fff);
}
.ws-chat-msg--mine .ws-chat-msg__text {
  background: rgba(124,58,237,0.35);
  border-color: rgba(124,58,237,0.4);
  border-radius: 14px 4px 14px 14px;
  color: #e9d5ff;
}
.ws-chat-msg__time { font-size: 0.62rem; color: var(--text-muted, #888); margin-top: 3px; padding-right: 2px; }

/* [v5.7.16] Separador de fecha estilo WhatsApp — pill centrado entre
   bloques de mensajes, semi-transparente, bordes redondeados.
   El JS de _renderChatHtml inyecta un .ws-chat-date-sep cada vez que
   el día del mensaje actual difiere del anterior. */
.ws-chat-date-sep {
  display: flex;
  justify-content: center;
  width: 100%;
  margin: 12px 0 6px;
  pointer-events: none;
}
.ws-chat-date-sep__label {
  display: inline-block;
  padding: 3px 10px;
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgba(232, 226, 244, 0.75);
  background: rgba(15, 13, 26, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 999px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  text-transform: capitalize;
  font-variant-numeric: tabular-nums;
}

/* ── Buscador del feed del workspace ── */
/* ── Workspace feed tag filter ─────────────────────────────────── */
.ws-feed-tag-bar {
  position: relative;
  padding: 8px 10px 4px;
  flex-shrink: 0;
}
.ws-feed-tag-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 4px;
}
.ws-feed-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: rgba(124,77,255,0.22);
  border: 1px solid rgba(124,77,255,0.4);
  border-radius: 20px;
  color: #c4b0ff;
  font-size: 11.5px;
  white-space: nowrap;
}
.ws-feed-tag-chip-remove {
  background: none;
  border: none;
  color: #c4b0ff;
  cursor: pointer;
  padding: 0;
  font-size: 13px;
  line-height: 1;
  opacity: 0.7;
}
.ws-feed-tag-chip-remove:hover { opacity: 1; }
.ws-feed-tag-input-wrap {
  position: relative;
}
.ws-feed-tag-icon {
  position: absolute;
  left: 10px; top: 50%;
  transform: translateY(-50%);
  width: 13px; height: 13px;
  color: rgba(255,255,255,0.4);
  pointer-events: none;
}
.ws-feed-tag-input {
  width: 100%;
  padding: 7px 10px 7px 30px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  color: var(--text-primary, #fff);
  font-size: 12.5px;
  outline: none;
  box-sizing: border-box;
  transition: border-color 120ms ease, background 120ms ease;
}
.ws-feed-tag-input:focus {
  border-color: rgba(124,77,255,0.45);
  background: rgba(255,255,255,0.06);
}
.ws-feed-tag-input::placeholder { color: rgba(255,255,255,0.35); }
.ws-feed-tag-suggestions {
  position: absolute;
  top: calc(100% + 2px);
  left: 10px; right: 10px;
  background: #1e1b2e;
  border: 1px solid rgba(124,77,255,0.3);
  border-radius: 8px;
  z-index: 200;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
/* ws-feed-tag-suggestion classes removed — reusing feed-tag-check-item from main feed */

/* ── Feed articles en workspace: reutiliza 100% los estilos de .feed-card del feed principal ── */
/* Solo ajustes propios del panel lateral: grid de 1 columna + cursor grab */
.ws-feed-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.ws-feed-grid .feed-card {
  cursor: grab;
}
.ws-feed-grid .feed-card:active { cursor: grabbing; }

/* ── Article card embebida dentro de sticky notes (mini premium) ── */
.canvas-article-card {
  display: flex;
  flex-direction: column;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  margin-bottom: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: transform 150ms ease, box-shadow 150ms ease;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}

/* Pill "Preguntar sobre este artículo" — horizontal, debajo del article card */
.canvas-article-card__ask-ai {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin: 0 0 10px;
  padding: 8px 12px;
  background: linear-gradient(135deg, rgba(139,92,246,0.18), rgba(124,58,237,0.22));
  border: 1px solid rgba(139,92,246,0.38);
  border-radius: 8px;
  color: #5b21b6;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.12s, transform 0.1s, box-shadow 0.12s;
  box-shadow: 0 2px 6px rgba(139,92,246,0.12);
}
.canvas-article-card__ask-ai:hover {
  background: linear-gradient(135deg, rgba(139,92,246,0.28), rgba(124,58,237,0.32));
  box-shadow: 0 4px 10px rgba(139,92,246,0.20);
}
.canvas-article-card__ask-ai:active {
  transform: translateY(1px);
}
.canvas-article-card__ask-ai:disabled {
  opacity: 0.55;
  cursor: wait;
}
.canvas-article-card__ask-ai-icn {
  font-size: 14px;
  line-height: 1;
}
.canvas-article-card__ask-ai-txt {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.canvas-article-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px -6px rgba(0,0,0,0.32);
}
.canvas-article-card__imgwrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
}
.canvas-article-card__img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.canvas-article-card__yt {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 30px; height: 30px;
  border-radius: 50%;
  background: rgba(255,255,255,0.95);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.canvas-article-card__source-pill {
  position: absolute;
  left: 6px; bottom: 6px;
  max-width: calc(100% - 12px);
  font-size: 9px; font-weight: 700;
  padding: 2px 6px;
  background: rgba(0,0,0,0.72);
  color: #fff;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  backdrop-filter: blur(4px);
}
.canvas-article-card__body {
  padding: 7px 9px 8px;
}
.canvas-article-card__title {
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.3;
  color: rgba(0,0,0,0.88);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 6px 0;
}
.canvas-article-card__footer {
  display: flex; justify-content: space-between; align-items: center;
  gap: 6px;
}
.canvas-article-card__badges { display: flex; gap: 4px; flex-wrap: wrap; }
.canvas-article-card__badge {
  font-size: 9px; font-weight: 600;
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.02em;
}
.canvas-article-card__badge--pais   { background: rgba(14,165,233,0.14); color: #0369a1; border: 1px solid rgba(14,165,233,0.28); }
.canvas-article-card__badge--idioma { background: rgba(16,185,129,0.14); color: #047857; border: 1px solid rgba(16,185,129,0.28); }
.canvas-article-card__date {
  font-size: 9.5px;
  color: rgba(0,0,0,0.5);
  white-space: nowrap;
}

.ws-article-card__hover {
  display: none; gap: 0.4rem;
  padding: 0.3rem 0.65rem 0.5rem;
  background: rgba(255,255,255,0.03);
  border-top: 1px solid var(--border-color, rgba(255,255,255,0.05));
}
.ws-article-card:hover .ws-article-card__hover { display: flex; }
.ws-article-action {
  font-size: 0.72rem;
  background: rgba(255,255,255,0.07);
  border: none; border-radius: 5px;
  color: var(--text-primary, #fff);
  padding: 2px 8px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}
.ws-article-action:hover { background: rgba(255,255,255,0.14); }
.ws-article-action--remove:hover { background: rgba(239,68,68,0.18); color: #fca5a5; }

/* ── Canvas items ── */
.canvas-item {
  position: absolute;
  min-width: 140px; min-height: 60px;
  width: 200px;
  background: #f59e0b;
  color: #1a1a1a;
  border-radius: 3px;
  padding: 8px 10px 42px 10px; /* espacio inferior para los controles (delete + action bar) */
  font-size: 0.78rem; line-height: 1.4;
  cursor: grab;
  box-shadow: 2px 4px 10px rgba(0,0,0,0.35);
  user-select: none;
  z-index: 5;
  word-break: break-word;
  /* [v5.7.27.13] content-visibility: auto removido — aplicaba `contain: paint`
     implícito que cortaba la actionbar (bottom: -46px sale del padding box).
     El lazy render se difiere a Fase 2 (SSE eliminará el polling destructivo
     que era el principal motivo de necesitar lazy paint). */
}
/* [v5.7.20] Sticky en interacción sale al frente para que su action bar
   (lock/copy/move/delete) no quede tapada por otros posts solapados.
   Transitorio: al quitar hover/focus vuelve a z:5 y el orden por z_order
   del backend manda como siempre. :focus-within cubre el caso "estoy
   editando el contenteditable" — el post sigue al frente aunque saques el
   mouse. El color-picker-popover ya estaba arriba (fixed, z:1100). */
.canvas-item:hover,
.canvas-item:focus-within {
  z-index: 100;
}
.canvas-item--article {
  background: var(--card-bg, #1e1e2e);
  color: var(--text-primary, #fff);
  border: 1px solid var(--accent, #7c3aed);
  font-size: 0.74rem;
}
/* ── Canvas item tools ── */
.canvas-item__tool {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.08);
  border: none; border-radius: 6px;
  cursor: pointer; color: rgba(0,0,0,0.65);
  padding: 0;
  transition: background 120ms ease, color 120ms ease, transform 120ms ease;
}
.canvas-item__tool:hover {
  background: rgba(0,0,0,0.18);
  color: rgba(0,0,0,0.9);
  transform: scale(1.08);
}
.canvas-item__tool i { width: 13px; height: 13px; }

/* [v5.7.27.11] Banner global de modo offline — aparece cuando un flush de
   autoguardado falló por red y hay items dirty pendientes. Se oculta al
   reconectar (evento 'online' gatilla retry de la cola). Fixed bottom-center
   para no tapar la UI principal. */
.canvas-offline-banner {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: rgba(30, 30, 30, 0.95);
  color: #fef3c7;
  border: 1px solid rgba(245, 158, 11, 0.4);
  border-radius: 24px;
  font-size: 13px;
  font-weight: 500;
  box-shadow: 0 6px 24px rgba(0,0,0,0.35);
  z-index: 9999;
  backdrop-filter: blur(8px);
  animation: canvas-offline-banner-in 0.3s ease-out;
}
.canvas-offline-banner__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.3);
  animation: canvas-pending-pulse 1.6s ease-in-out infinite;
}
@keyframes canvas-offline-banner-in {
  from { opacity: 0; transform: translate(-50%, 10px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}

/* [v5.7.27.7] Indicador visual de "save pendiente" — punto sutil en la
   esquina superior izquierda del sticky mientras hay cambios sin persistir.
   Aplicado por _markCanvasItemDirty (atributo data-pending-save="1") y
   removido por _flushDirtyCanvasItems al recibir confirmación del backend. */
.canvas-item[data-pending-save="1"]::before {
  content: '';
  position: absolute;
  top: 6px;
  left: 6px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #f59e0b;
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.25);
  animation: canvas-pending-pulse 1.6s ease-in-out infinite;
  pointer-events: none;
  z-index: 5;
}
@keyframes canvas-pending-pulse {
  0%, 100% { opacity: 0.85; }
  50%      { opacity: 0.45; }
}

/* Action bar flotante centrado en la parte inferior */
.canvas-item__actionbar {
  position: absolute;
  bottom: 6px;
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  display: flex; gap: 3px;
  padding: 3px;
  background: rgba(0, 0, 0, 0.10);
  border-radius: 8px;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity 150ms ease, transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
  z-index: 2;
  pointer-events: none;
}
.canvas-item:hover .canvas-item__actionbar {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.canvas-item__actionbar .canvas-item__tool {
  position: static;
  background: transparent;
}
.canvas-item__actionbar .canvas-item__tool:hover {
  background: rgba(0,0,0,0.15);
}


.canvas-item__color-swatch {
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1.5px solid rgba(0,0,0,0.3);
  display: block;
  box-shadow: inset 0 1px 1px rgba(255,255,255,0.25);
}

/* Indicador de visibilidad (lock / users) junto al nickname */
.canvas-note-visibility {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  width: 18px; height: 18px;
  padding: 0;
  border: none;
  border-radius: 5px;
  background: rgba(0,0,0,0.08);
  color: rgba(0,0,0,0.7);
  pointer-events: auto;
  transition: background 120ms ease, transform 120ms ease;
}
.canvas-note-visibility i { width: 11px; height: 11px; }
.canvas-note-visibility--btn { cursor: pointer; }
.canvas-note-visibility--btn:hover {
  background: rgba(0,0,0,0.18);
  transform: scale(1.1);
}
/* Variante compartida: acento índigo */
.canvas-note-visibility[data-shared="1"] {
  background: rgba(99, 102, 241, 0.25);
  color: rgba(55, 60, 180, 0.95);
}
.canvas-note-visibility[data-shared="1"]:hover {
  background: rgba(99, 102, 241, 0.4);
}

/* Cuando la nota es compartida, la etiqueta "Compartida" debe verse como label en vez de autor */
.canvas-item--shared .canvas-note-author__name {
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* ── Bloques de notas compartidas ───────────────────────────────────── */
.canvas-note-blocks {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
}
.canvas-note-block {
  background: rgba(255,255,255,0.22);
  border-radius: 6px;
  padding: 6px 8px 4px;
  font-size: 0.78rem;
  line-height: 1.38;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06);
}
.canvas-note-block__text {
  white-space: pre-wrap;
  word-break: break-word;
  color: rgba(0,0,0,0.88);
  margin-bottom: 2px;
}
.canvas-note-block__attrib {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  font-size: 0.65rem;
  font-weight: 500;
  color: rgba(0,0,0,0.55);
  font-style: italic;
  user-select: none;
}
.canvas-note-block__del {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px; height: 14px;
  margin-left: 2px;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  color: rgba(180, 30, 30, 0.55);
  transition: background 120ms ease, color 120ms ease;
}
.canvas-note-block__del i { width: 10px; height: 10px; }
.canvas-note-block__del:hover {
  background: rgba(220, 38, 38, 0.2);
  color: rgb(180, 30, 30);
}

/* Bloques de solo-lectura: la nota está privada pero conserva historial compartido */
.canvas-note-blocks--readonly { opacity: 0.92; }
.canvas-note-block--readonly {
  background: rgba(255,255,255,0.14);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.04);
}
.canvas-note-block--readonly .canvas-note-block__text { color: rgba(0,0,0,0.78); }
.canvas-note-readonly-hint {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 4px;
  padding: 5px 8px;
  font-size: 0.68rem;
  font-style: italic;
  color: rgba(0,0,0,0.55);
  background: rgba(0,0,0,0.04);
  border-radius: 4px;
  line-height: 1.3;
}
.canvas-note-readonly-hint i { width: 11px; height: 11px; flex-shrink: 0; }

/* Input para nuevo bloque */
.canvas-note-newblock {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  padding: 4px 2px 0;
  border-top: 1px dashed rgba(0,0,0,0.18);
}
.canvas-note-newblock__input {
  flex: 1;
  resize: none;
  min-height: 28px;
  max-height: 100px;
  padding: 5px 8px;
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 6px;
  font-size: 0.75rem;
  font-family: inherit;
  background: rgba(255,255,255,0.35);
  color: rgba(0,0,0,0.85);
  outline: none;
  transition: border-color 120ms ease, background 120ms ease;
}
.canvas-note-newblock__input:focus {
  border-color: rgba(99, 102, 241, 0.6);
  background: rgba(255,255,255,0.55);
}
.canvas-note-newblock__input::placeholder {
  color: rgba(0,0,0,0.45);
}
.canvas-note-newblock__send {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  background: rgba(99, 102, 241, 0.85);
  border: none; border-radius: 6px;
  color: #fff;
  cursor: pointer;
  transition: background 120ms ease, transform 120ms ease;
}
.canvas-note-newblock__send:hover {
  background: rgba(79, 70, 229, 1);
  transform: scale(1.05);
}
.canvas-note-newblock__send i { width: 13px; height: 13px; }

/* Nota compartida: indicador visual gestionado por ícono en el footer */
.canvas-item--shared {
  /* ownership border handled by canvas-item--mine / :not rules below */
}

/* [v5.7.27.54 — Sprint D] Nota de seguimiento admin-only.
   Marca visual distintiva: borde violeta + esquina con escudo. Backend ya
   garantiza que solo space admins ven el sticky — el badge le señala al admin
   "ojo: este sticky NO es visible para los demás miembros". */
.canvas-item--admin-only {
  outline: 2px dashed color-mix(in srgb, #8b5cf6 70%, transparent);
  outline-offset: -2px;
  position: relative;
}
.canvas-item--admin-only::before {
  content: '\F4FE'; /* lucide shield codepoint via font fallback */
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, #8b5cf6, #6d28d9);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.6px;
  padding: 3px 8px;
  border-radius: 4px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
  text-transform: uppercase;
  /* fallback con texto: 'admin' por si la fuente no resuelve el codepoint */
  content: 'ADMIN';
  z-index: 2;
  pointer-events: none;
}

/* Badge inline en el autor — indicador pequeño de "compartida" */
.canvas-note-shared-badge {
  display: inline-flex;
  align-items: center;
  margin-left: auto;
  padding: 1px 5px;
  border-radius: 10px;
  background: rgba(99, 102, 241, 0.18);
  color: rgba(55, 60, 180, 0.9);
  pointer-events: auto;
}
.canvas-note-shared-badge i { width: 10px; height: 10px; }

/* ── Color picker popover ── */
.color-picker-popover {
  position: fixed;
  z-index: 1100;
  display: grid;
  grid-template-columns: repeat(5, 26px);
  gap: 6px;
  padding: 10px;
  background: linear-gradient(180deg, #1f1f2e 0%, #16161f 100%);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  box-shadow: 0 12px 32px -8px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.04);
  opacity: 0;
  transform: translateY(-4px) scale(0.96);
  transition: opacity 150ms ease, transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
}
.color-picker-popover.is-open {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.color-picker-popover .color-swatch {
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  transition: transform 120ms ease, border-color 120ms ease;
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
}
.color-picker-popover .color-swatch:hover { transform: scale(1.12); }
.color-picker-popover .color-swatch.is-active {
  border-color: #fff;
  box-shadow: 0 0 0 2px rgba(99,102,241,0.4), 0 1px 3px rgba(0,0,0,0.4);
}
.canvas-note-text {
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: break-word;
  min-height: 40px;
  width: 100%;
  outline: none;
  user-select: text;
  cursor: text;
  line-height: 1.4;
  font-size: 0.82rem;
}

/* ── [v5.7.27.40 Sprint B] Tipografía configurable por sticky ──────────────
   Aplicado a la raíz del sticky (.canvas-item) — todos los descendientes
   heredan la familia. El tamaño usa una CSS variable propagada con alta
   especificidad para vencer al cc:text-xs de la island React de comentarios. */
.canvas-item[data-font-family="serif"] { font-family: Georgia, 'Times New Roman', serif; }
.canvas-item[data-font-family="mono"]  { font-family: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace; }
/* sans = default heredado del root, no necesita override */

/* CSS variable como fuente única de verdad del tamaño. Todos los selectores
   abajo leen `var(--canvas-font-size)`. */
.canvas-item[data-font-size="sm"] { --canvas-font-size: 0.72rem; }
.canvas-item[data-font-size="md"] { --canvas-font-size: 0.82rem; }
.canvas-item[data-font-size="lg"] { --canvas-font-size: 1.00rem; }
.canvas-item[data-font-size="xl"] { --canvas-font-size: 1.25rem; }

/* Personal note (.canvas-note-text contenteditable). */
.canvas-item[data-font-size] .canvas-note-text,
.canvas-item[data-font-size] .canvas-note-block__text { font-size: var(--canvas-font-size); }

/* AI question — pregunta + respuesta del LLM. */
.canvas-item[data-font-size] .ai-q-input,
.canvas-item[data-font-size] .ai-q-answer,
.canvas-item[data-font-size] .ai-q-question,
.canvas-item[data-font-size] .canvas-ai-answer { font-size: var(--canvas-font-size); }

/* Article — título y descripción dentro del card embebido. */
.canvas-item[data-font-size] .canvas-article-card__title,
.canvas-item[data-font-size] .canvas-article-card__desc { font-size: var(--canvas-font-size); }

/* Comments island React — vencer la especificidad 0,1,0 de cc:text-xs.
   Solo el texto del comentario (<p>) y el textarea de edición; metadata
   (autor, fecha, menú dropdown) se queda en xs para no inflar la UI. */
.canvas-item[data-font-size] .canvas-comments-root p,
.canvas-item[data-font-size] .canvas-comments-root textarea { font-size: var(--canvas-font-size); }

/* [v5.7.27.67] Título de la nota (.canvas-note-title) — recibe el mismo
   --canvas-font-size que el cuerpo. El font-size base de 12px hardcodeado
   en .canvas-note-title no respondía al picker de tamaño; ahora escala
   con sm/md/lg/xl como el resto de los elementos del sticky. */
.canvas-item[data-font-size] .canvas-note-title { font-size: var(--canvas-font-size); }

/* [v5.7.27.67] Familia explícita sobre el título. La herencia del padre
   .canvas-item normalmente cubriría serif/mono, pero esta regla blinda
   contra cualquier override futuro que defina font-family directamente
   sobre .canvas-note-title (regresión silenciosa muy difícil de detectar). */
.canvas-item[data-font-family="serif"] .canvas-note-title { font-family: Georgia, 'Times New Roman', serif; }
.canvas-item[data-font-family="mono"]  .canvas-note-title { font-family: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace; }

/* Picker UI — popover similar al color-picker. Sub-secciones para family
   (3 opciones con preview "Aa") y size (4 opciones S/M/L/XL). */
.font-picker-popover {
  position: fixed; z-index: 1100;
  background: rgba(28,26,42,0.98);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 10px 12px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.45);
  display: flex; flex-direction: column; gap: 10px;
  min-width: 200px;
}
.font-picker-popover__section {
  display: flex; flex-direction: column; gap: 6px;
}
.font-picker-popover__label {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.55);
  font-weight: 600;
}
.font-picker-popover__row {
  display: flex; gap: 6px;
}
.font-picker-popover__btn {
  flex: 1;
  padding: 6px 0;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  color: #ebe7f4;
  cursor: pointer;
  font-size: 13px;
  transition: background 120ms, border-color 120ms;
  text-align: center;
}
.font-picker-popover__btn:hover {
  background: rgba(255,255,255,0.1);
}
.font-picker-popover__btn.is-active {
  border-color: rgba(167,139,250,0.85);
  background: rgba(124,58,237,0.18);
  color: #fff;
}
.font-picker-popover__btn[data-family="serif"] { font-family: Georgia, serif; }
.font-picker-popover__btn[data-family="mono"]  { font-family: 'JetBrains Mono', ui-monospace, monospace; }

/* Botón "Aa" en la action bar del sticky para abrir el picker. */
.canvas-item__font-btn {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.5px;
}
/* [v5.7.16] Reglas legacy de `.canvas-note-author` removidas — eran las que
   sobrescribían left/right/max-width y hacían que el footer quedara limitado
   al 55% derecho del sticky con elipsis. La definición canónica vive ahora
   más abajo en este archivo (search: ".canvas-note-author { position: absolute"). */

/* [v5.7.17] Sticky-imagen pegada con Ctrl+V. Wrapper toma el body completo
   (descontando el footer del autor); la <img> usa object-fit:contain para
   no recortarse y mantener aspect ratio incluso si el usuario redimensiona
   el sticky. */
.canvas-note-image-wrap {
  position: absolute;
  top: 6px;
  left: 6px;
  right: 6px;
  bottom: 28px; /* deja espacio para canvas-note-author */
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 4px;
  background: rgba(0,0,0,0.04);
}
.canvas-note-image {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
  /* [v5.7.17] pointer-events:auto (default) para que el dblclick abra el
     lightbox. El drag del sticky sigue funcionando vía bubbling al .canvas-item. */
}

/* [v5.7.17] Imagen inline pegada/arrastrada DENTRO de un sticky personal.
   Selector descendant (no depende de class) porque el sanitizer del backend
   strip-ea `class` y `style` — solo sobrevive `data-storage-path`, `alt`.
   `width: 100%` (en lugar de `auto`) hace que la imagen ESCALE con el
   sticky al redimensionarlo: agrandar el sticky agranda la imagen, al
   mismo ratio. Para ver al tamaño original con que se incrustó, doble-click
   abre el lightbox. cursor:zoom-in indica la affordance. */
.canvas-note-text img,
.canvas-item--note .canvas-item__content .canvas-note-text img {
  display: block;
  width: 100%;
  height: auto;
  margin: 4px 0;
  border-radius: 4px;
  user-select: none;
  -webkit-user-drag: none;
  cursor: zoom-in;
}
.canvas-note-text__inline-img--pending {
  opacity: 0.55;
  filter: blur(0.5px);
}
/* Misma affordance para sticky-imagen dedicado */
.canvas-note-image { cursor: zoom-in; }

/* ── Lightbox: doble-click en imagen del canvas para verla a tamaño máximo. ── */
.canvas-image-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  cursor: zoom-out;
  animation: canvasLightboxFade 0.15s ease-out;
}
.canvas-image-lightbox img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
  border-radius: 4px;
  cursor: default;
  pointer-events: none; /* clicks pasan al backdrop para cerrar */
}
.canvas-image-lightbox__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s;
}
.canvas-image-lightbox__close:hover { background: rgba(255, 255, 255, 0.22); }
@keyframes canvasLightboxFade {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* [v5.7.17] Placeholder mientras se sube la imagen pegada con Ctrl+V.
   Shimmer diagonal indica progreso; aparece sobre la imagen local mostrada
   inmediatamente con objectURL. Se elimina cuando _loadCanvas trae el
   sticky real desde DB. */
.canvas-paste-placeholder { pointer-events: none; opacity: 0.92; }
.canvas-paste-placeholder__shimmer {
  position: absolute;
  inset: 0;
  border-radius: 4px;
  background: linear-gradient(
    100deg,
    rgba(255,255,255,0) 30%,
    rgba(255,255,255,0.45) 50%,
    rgba(255,255,255,0) 70%
  );
  background-size: 200% 100%;
  animation: canvasPasteShimmer 1.2s linear infinite;
  pointer-events: none;
}
@keyframes canvasPasteShimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.canvas-note-author__avatar {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  object-fit: cover;
  background: rgba(0,0,0,0.15);
  flex-shrink: 0;
}
.canvas-note-author__avatar--anon {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 11px;
  color: rgba(0,0,0,0.45);
  background: rgba(0,0,0,0.18);
  font-style: italic;
}
/* [v5.7.16] `.canvas-note-author__name` ya NO trunca con elipsis — definición
   canónica con `flex-shrink: 0` vive más abajo (footer en una sola fila). */

/* ── Nota título editable (dueño de notas compartidas / anónimas) ── */
.canvas-note-title {
  display: block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: rgba(0,0,0,0.75);
  padding: 5px 8px 6px;
  margin: -8px -10px 10px -10px;  /* sangra hasta los bordes del padding del canvas-item */
  background: rgba(0,0,0,0.10);
  border-bottom: 2px solid rgba(0,0,0,0.18);
  border-radius: 3px 3px 0 0;
  /* [v5.7.27.22] Wrapping permitido — antes era nowrap+ellipsis, lo que
     truncaba títulos largos a una sola línea. Ahora se rompe en palabras
     y muestra hasta 3 líneas (line-clamp); si sigue siendo más largo, sí
     trunca. word-break:break-word evita que palabras gigantes (URLs)
     desborden el sticky horizontalmente. */
  white-space: normal;
  word-break: break-word;
  overflow-wrap: break-word;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.3;
}
.canvas-note-title--editable {
  cursor: move; /* modo normal: permite arrastrar la nota desde el título */
  outline: none;
  border-radius: 4px 4px 0 0;
  transition: background 100ms;
}
.canvas-note-title--editable[contenteditable] {
  cursor: text;
}
.canvas-note-title--editable:empty::before {
  content: attr(data-placeholder);
  color: rgba(0,0,0,0.28);
  font-weight: 400;
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
}
.canvas-note-title--editable:hover,
.canvas-note-title--editable:focus {
  background: rgba(0,0,0,0.06);
}

/* ── Poll status bar ── */
.canvas-poll-status {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px 4px;
  background: rgba(0,0,0,0.06);
  border-bottom: 1px solid rgba(0,0,0,0.09);
  flex-wrap: wrap;
}
.canvas-poll-badge {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 10px;
  padding: 2px 7px;
}
.canvas-poll-badge--open  { background: rgba(16,185,129,0.18); color: #059669; }
.canvas-poll-badge--closed{ background: rgba(0,0,0,0.1);       color: rgba(0,0,0,0.5); }
.canvas-poll-pts-info {
  font-size: 10px;
  color: rgba(0,0,0,0.5);
  flex: 1;
  white-space: nowrap;
}
/* [v5.7.14] Pill de votantes únicos — visible para todos en sticky tipo encuesta. */
.canvas-poll-voters {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  color: rgba(0,0,0,0.55);
  padding: 2px 7px;
  background: rgba(0,0,0,0.06);
  border-radius: 10px;
  white-space: nowrap;
}
.canvas-poll-voters i { color: rgba(0,0,0,0.45); }
.canvas-poll-toggle {
  margin-left: auto;
  width: 22px !important;
  height: 22px !important;
  padding: 0 !important;
  border-radius: 4px !important;
  opacity: 0.7;
}
.canvas-poll-toggle:hover { opacity: 1; }
.canvas-poll-toggle i { width: 12px; height: 12px; }

/* ── Poll blocks ── */
.canvas-note-blocks--poll { padding: 4px 0; }
.canvas-note-block--poll  { padding: 5px 8px; }
.canvas-note-block__poll-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
}
.canvas-vote-total {
  font-size: 10px;
  font-weight: 700;
  color: rgba(0,0,0,0.45);
  min-width: 28px;
}
.canvas-vote-stepper {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid rgba(0,0,0,0.18);
  border-radius: 6px;
  overflow: hidden;
  margin-left: auto;
  background: rgba(255,255,255,0.5);
}
.canvas-vote-btn {
  width: 22px;
  height: 22px;
  border: none;
  background: transparent;
  font-size: 14px;
  font-weight: 700;
  color: rgba(0,0,0,0.55);
  cursor: pointer;
  line-height: 1;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 80ms, color 80ms;
}
.canvas-vote-btn:hover:not(:disabled) { background: rgba(99,102,241,0.15); color: #4338ca; }
.canvas-vote-btn:disabled { opacity: 0.3; cursor: default; }
.canvas-vote-count {
  font-size: 11px;
  font-weight: 700;
  min-width: 18px;
  text-align: center;
  color: rgba(0,0,0,0.65);
  border-left: 1px solid rgba(0,0,0,0.12);
  border-right: 1px solid rgba(0,0,0,0.12);
  line-height: 22px;
}
.canvas-vote-mine {
  margin-left: auto;
  font-size: 10px;
  font-weight: 700;
  color: #4338ca;
  background: rgba(99,102,241,0.12);
  border-radius: 8px;
  padding: 1px 6px;
}
.canvas-poll-hint {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin: 4px 8px;
  padding: 4px 8px;
  font-size: 10px;
  color: rgba(0,0,0,0.5);
  background: rgba(0,0,0,0.04);
  border-radius: 4px;
}
.canvas-poll-hint i { width: 10px; height: 10px; flex-shrink: 0; }

/* ── Convert-to-poll toolbar button ── */
.canvas-item__to-poll i { color: var(--accent, #7c3aed); }

/* ── Modal pequeño (convert poll) ── */
.modal-box {
  background: linear-gradient(180deg, #1f1f2e 0%, #16161f 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 24px 24px 20px;
  width: 92%;
  box-shadow: 0 20px 60px -20px rgba(0,0,0,0.8);
}
.modal-box--sm { max-width: 340px; }
.modal-box__title {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 600;
  color: #f5f5f7;
}
.modal-box__desc {
  margin: 0 0 4px;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.5;
}
.modal-box__actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
}
.btn--primary {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 8px; border: none;
  background: var(--accent, #7c3aed); color: #fff;
  font-size: 0.84rem; font-weight: 600; cursor: pointer;
  transition: background 120ms;
}
.btn--primary:hover { background: #6d28d9; }
.btn--ghost {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.12);
  background: transparent; color: rgba(255,255,255,0.65);
  font-size: 0.84rem; font-weight: 500; cursor: pointer;
  transition: background 120ms;
}
.btn--ghost:hover { background: rgba(255,255,255,0.08); }
.modal-box__label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text, #e2e8f0);
  margin: 12px 0 8px;
}
.modal-box__input {
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.08);
  color: var(--text, #e2e8f0);
  font-size: 14px;
  outline: none;
}
.modal-box__input:focus { border-color: var(--accent, #7c3aed); }

/* ── Ownership borders — contextual por modo de canvas ───────────────── */
/* Sombra base de .canvas-item (línea 9029) aplica a todos; aquí solo se agrega el indicador de ownership */

/* Mío — canvas oscuro: outline blanco discontinuo flotante */
#ws-canvas-viewport.bg-dark .canvas-item--mine {
  outline: 2.5px dashed rgba(255,255,255,0.9);
  outline-offset: 3px;
}

/* Mío — canvas claro: outline violeta discontinuo flotante */
#ws-canvas-viewport.bg-light .canvas-item--mine {
  outline: 2.5px dashed #6d28d9;
  outline-offset: 3px;
}

/* Artículos propios: suprimir border accent para evitar doble borde
   (canvas-item--article tiene border: 1px solid accent por defecto) */
#ws-canvas-viewport.bg-dark .canvas-item--article.canvas-item--mine,
#ws-canvas-viewport.bg-light .canvas-item--article.canvas-item--mine {
  border-color: transparent;
}

/* No mío — canvas oscuro: sombra base + borde sutil blanco */
#ws-canvas-viewport.bg-dark .canvas-item:not(.canvas-item--mine) {
  box-shadow: 2px 4px 10px rgba(0,0,0,0.35), 0 0 0 1.5px rgba(255,255,255,0.13);
}

/* No mío — canvas claro: sombra reducida (0.2 vs 0.35 en oscuro — sombras son más visibles sobre fondo claro) + borde sutil */
#ws-canvas-viewport.bg-light .canvas-item:not(.canvas-item--mine) {
  box-shadow: 2px 4px 10px rgba(0,0,0,0.2), 0 0 0 1.5px rgba(0,0,0,0.14);
}

.canvas-item--readonly {
  cursor: default;
}
.canvas-item--readonly .canvas-note-text {
  user-select: text;
  cursor: text;
}
.canvas-item__resize {
  position: absolute;
  width: 14px;
  height: 14px;
  opacity: 0.35;
  z-index: 6;
}
.canvas-item__resize:hover { opacity: 0.7; }
.canvas-item__resize--se { bottom: 0; right:  0; cursor: nwse-resize; }
.canvas-item__resize--nw { top:    0; left:   0; cursor: nwse-resize; }
.canvas-item__resize--ne { top:    0; right:  0; cursor: nesw-resize; }
.canvas-item__resize--sw { bottom: 0; left:   0; cursor: nesw-resize; }
/* Indicadores "L" de resize — uno por esquina (NE, NW, SE, SW).
   La pill de action bar se desplaza suficientemente abajo (bottom:-64px) para
   no colisionar contra los indicadores SE/SW. */
.canvas-item__resize--ne::after,
.canvas-item__resize--nw::after,
.canvas-item__resize--se::after,
.canvas-item__resize--sw::after {
  content: '';
  position: absolute;
  width: 8px;
  height: 8px;
}
.canvas-item__resize--ne::after {
  top: 3px; right: 3px;
  border-right: 2px solid rgba(0,0,0,0.4);
  border-top: 2px solid rgba(0,0,0,0.4);
}
.canvas-item__resize--nw::after {
  top: 3px; left: 3px;
  border-left: 2px solid rgba(0,0,0,0.4);
  border-top: 2px solid rgba(0,0,0,0.4);
}
.canvas-item__resize--se::after {
  bottom: 3px; right: 3px;
  border-right: 2px solid rgba(0,0,0,0.4);
  border-bottom: 2px solid rgba(0,0,0,0.4);
}
.canvas-item__resize--sw::after {
  bottom: 3px; left: 3px;
  border-left: 2px solid rgba(0,0,0,0.4);
  border-bottom: 2px solid rgba(0,0,0,0.4);
}
.canvas-item:hover .canvas-item__resize { opacity: 0.7; }

/* ── Modals ── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

/* ── Premium Confirm Dialog ─────────────────────────────────────────── */
.confirm-overlay {
  background: rgba(8, 10, 18, 0.72);
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  opacity: 0;
  transition: opacity 180ms ease;
}
.confirm-overlay.is-open { opacity: 1; }

.confirm-card {
  position: relative;
  width: 92%;
  max-width: 420px;
  background: linear-gradient(180deg, #1f1f2e 0%, #16161f 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 28px 28px 22px;
  box-shadow:
    0 20px 60px -20px rgba(0,0,0,0.8),
    0 8px 24px -8px rgba(220, 38, 38, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.05);
  text-align: center;
  transform: translateY(8px) scale(0.96);
  opacity: 0;
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms ease;
}
.confirm-overlay.is-open .confirm-card {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.confirm-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 16px;
  padding: 1px;
  background: linear-gradient(180deg, rgba(220,38,38,0.35), rgba(255,255,255,0.03) 60%);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}
.confirm-card__icon {
  width: 52px; height: 52px;
  margin: 0 auto 14px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 30% 20%, rgba(248, 113, 113, 0.25), rgba(220, 38, 38, 0.12));
  border: 1px solid rgba(248, 113, 113, 0.35);
  color: #fca5a5;
}
.confirm-card__icon i { width: 24px; height: 24px; }
.confirm-card__title {
  margin: 0 0 8px;
  font-size: 1.1rem;
  font-weight: 600;
  color: #f5f5f7;
  letter-spacing: -0.01em;
}
.confirm-card__desc {
  margin: 0 0 14px;
  font-size: 0.85rem;
  line-height: 1.5;
  color: rgba(255,255,255,0.6);
}
.confirm-card__quote {
  margin: 0 0 20px;
  padding: 10px 14px;
  background: rgba(255,255,255,0.04);
  border-left: 3px solid rgba(248,113,113,0.55);
  border-radius: 6px;
  font-size: 0.82rem;
  font-style: italic;
  color: rgba(255,255,255,0.72);
  line-height: 1.45;
  text-align: left;
  max-width: 420px;
  white-space: pre-wrap;
  word-break: break-word;
}
.confirm-card__actions {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.confirm-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  border-radius: 10px;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 140ms ease;
  border: 1px solid transparent;
  min-width: 110px;
  justify-content: center;
}
.confirm-btn i { width: 15px; height: 15px; }
.confirm-btn--ghost {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.75);
}
.confirm-btn--ghost:hover {
  background: rgba(255,255,255,0.08);
  color: #fff;
}
.confirm-btn--danger {
  background: linear-gradient(180deg, #ef4444, #dc2626);
  color: #fff;
  border-color: rgba(220,38,38,0.6);
  box-shadow: 0 4px 12px -4px rgba(220,38,38,0.5);
}
.confirm-btn--danger:hover {
  background: linear-gradient(180deg, #f87171, #ef4444);
  box-shadow: 0 6px 18px -4px rgba(220,38,38,0.7);
  transform: translateY(-1px);
}
.confirm-btn--danger:active { transform: translateY(0); }

/* Variante info (azul índigo) para confirmaciones no-destructivas */
.confirm-card--info::before {
  background: linear-gradient(180deg, rgba(99, 102, 241, 0.4), rgba(255,255,255,0.03) 60%);
}
.confirm-card__icon--info {
  background: radial-gradient(circle at 30% 20%, rgba(129, 140, 248, 0.25), rgba(79, 70, 229, 0.12));
  border: 1px solid rgba(129, 140, 248, 0.35);
  color: #a5b4fc;
}
.confirm-btn--primary {
  background: linear-gradient(180deg, #6366f1, #4f46e5);
  color: #fff;
  border-color: rgba(79, 70, 229, 0.6);
  box-shadow: 0 4px 12px -4px rgba(79, 70, 229, 0.5);
}
.confirm-btn--primary:hover {
  background: linear-gradient(180deg, #818cf8, #6366f1);
  box-shadow: 0 6px 18px -4px rgba(79, 70, 229, 0.7);
  transform: translateY(-1px);
}
.confirm-btn--primary:active { transform: translateY(0); }
.ws-modal {
  background: var(--card-bg, #1e1e2e);
  border: 1px solid var(--border-color, rgba(255,255,255,0.10));
  border-radius: 12px;
  padding: 1.5rem;
  width: 92%; max-width: 380px;
  max-height: 90vh; overflow-y: auto;
}
.ws-modal--open    { max-width: 420px; }
.ws-modal--private { max-width: 360px; }
.ws-modal--visibility { max-width: 460px; }

.ws-visibility-hint {
  margin: 0 0 0.9rem;
  font-size: 0.82rem;
  color: var(--text-muted, #9a9a9a);
  line-height: 1.4;
}
.ws-visibility-options { display: flex; flex-direction: column; gap: 0.6rem; }
.ws-visibility-option {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.85rem 0.9rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}
.ws-visibility-option:hover { background: rgba(255,255,255,0.06); }
.ws-visibility-option.is-active {
  border-color: var(--accent, #7c3aed);
  background: rgba(124,58,237,0.10);
}
.ws-visibility-option input[type="radio"] { display: none; }
.ws-visibility-option__icon {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.06);
  border-radius: 8px;
  color: var(--text-primary, #fff);
  flex-shrink: 0;
}
.ws-visibility-option.is-active .ws-visibility-option__icon {
  background: var(--accent, #7c3aed);
  color: #fff;
}
.ws-visibility-option__icon i, .ws-visibility-option__icon svg { width: 18px; height: 18px; }
.ws-visibility-option__body { flex: 1; }
.ws-visibility-option__title {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text-primary, #fff);
  margin-bottom: 2px;
}
.ws-visibility-option__desc {
  font-size: 0.78rem;
  color: var(--text-muted, #9a9a9a);
  line-height: 1.4;
}

.ws-modal__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.ws-modal__header h3 { margin: 0; font-size: 1rem; }
.ws-modal__close {
  background: none; border: none;
  color: var(--text-muted, #888);
  cursor: pointer; font-size: 1.2rem; line-height: 1;
}
.ws-modal__close:hover { color: var(--text-primary, #fff); }
.ws-modal__close--labeled {
  font-size: 0.78rem;
  line-height: 1;
  padding: 0.38rem 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ws-modal__section { margin-bottom: 1rem; }
.ws-modal__label {
  display: block; font-size: 0.75rem; font-weight: 600;
  color: var(--text-muted, #888);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 0.4rem;
}
.ws-modal__divider { border: none; border-top: 1px solid var(--border-color, rgba(255,255,255,0.08)); margin: 0.75rem 0; }
.ws-modal__footer { display: flex; gap: 0.5rem; margin-top: 1rem; }

/* Sección de cuotas de preguntas IA dentro del modal de configuración del workspace */
.ws-config-ai-questions .ws-config-section__desc {
  margin: 0 0 0.6rem 0;
  font-size: 0.8rem;
  color: var(--text-muted, #888);
}
.ws-config-ai-questions .ws-config-field {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.6rem;
  margin: 0.4rem 0;
  font-size: 0.85rem;
}
.ws-config-ai-questions .ws-config-field input[type="number"] {
  width: 90px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border-color, rgba(255,255,255,0.10));
  border-radius: 6px;
  color: var(--text-primary, #fff);
  padding: 0.3rem 0.5rem;
  text-align: right;
}
.ws-config-ai-questions .ws-config-section__used {
  margin: 0.5rem 0 0.75rem 0;
  font-size: 0.8rem;
  color: var(--text-muted, #888);
}

.ws-modal__link-row { display: flex; gap: 0.4rem; align-items: center; }
.ws-modal__link-input {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border-color, rgba(255,255,255,0.10));
  border-radius: 6px;
  padding: 6px 9px;
  color: var(--text-primary, #fff);
  font-size: 0.76rem;
  font-family: monospace;
}

.ws-modal__toggle-row { display: flex; gap: 0.75rem; align-items: flex-start; }
.ws-toggle { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; margin-top: 2px; }
.ws-toggle input { opacity: 0; width: 0; height: 0; }
.ws-toggle__slider {
  position: absolute; cursor: pointer; inset: 0;
  background: rgba(255,255,255,0.12); border-radius: 24px; transition: 0.2s;
}
.ws-toggle__slider:before {
  content: ''; position: absolute;
  width: 18px; height: 18px; left: 3px; bottom: 3px;
  background: #fff; border-radius: 50%; transition: 0.2s;
}
.ws-toggle input:checked + .ws-toggle__slider { background: #16a34a; }
.ws-toggle input:checked + .ws-toggle__slider:before { transform: translateX(20px); }
.ws-toggle__label { font-size: 0.85rem; font-weight: 600; color: var(--text-primary, #fff); }
.ws-toggle__hint { font-size: 0.73rem; color: var(--text-muted, #888); margin-top: 2px; }
.ws-modal__manage-link { background: none; border: none; color: var(--accent, #7c3aed); cursor: pointer; font-size: 0.82rem; padding: 0; }
.ws-modal__manage-link:hover { text-decoration: underline; }

/* Tabs in PRIVADO modal */
.ws-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border-color, rgba(255,255,255,0.08)); margin-bottom: 0.75rem; }
.ws-tab {
  background: none; border: none;
  padding: 0.5rem 0.85rem;
  color: var(--text-muted, #888);
  cursor: pointer; font-size: 0.82rem;
  border-bottom: 2px solid transparent;
  transition: color 0.15s;
}
.ws-tab:hover  { color: var(--text-primary, #fff); }
.ws-tab.active { color: var(--accent, #7c3aed); border-bottom-color: var(--accent, #7c3aed); }
.ws-tab-panel  { min-height: 160px; }

.ws-modal__search {
  width: 100%; box-sizing: border-box;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border-color, rgba(255,255,255,0.10));
  border-radius: 6px;
  padding: 7px 10px;
  color: var(--text-primary, #fff);
  font-size: 0.82rem;
  margin-bottom: 0.6rem;
}
.ws-modal__search:focus { outline: none; border-color: var(--accent, #7c3aed); }

.ws-search-results { display: flex; flex-direction: column; gap: 0.35rem; }
.ws-search-row { display: flex; align-items: center; gap: 0.6rem; padding: 0.3rem 0; }
.ws-search-row__avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--accent, #7c3aed);
  color: #fff; font-size: 0.78rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ws-search-row__name { flex: 1; font-size: 0.83rem; }

.ws-token-rules { margin-bottom: 0.85rem; }
.ws-token-rules__title { font-size: 0.75rem; font-weight: 600; color: var(--text-muted, #888); text-transform: uppercase; margin-bottom: 0.4rem; }
.ws-token-rules__list { margin: 0; padding-left: 1.2rem; }
.ws-token-rules__list li { font-size: 0.78rem; color: var(--text-secondary, #ccc); margin-bottom: 0.25rem; line-height: 1.4; }
.ws-token-warning { font-size: 0.74rem; color: var(--warning, #fcd34d); margin: 0.5rem 0 0; }

.ws-members-list { display: flex; flex-direction: column; gap: 0.35rem; min-height: 80px; }
.ws-member-row { display: flex; align-items: center; gap: 0.6rem; padding: 0.3rem 0; }
.ws-member-row__avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--accent, #7c3aed);
  color: #fff; font-size: 0.78rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ws-member-row__avatar--pending { background: var(--ws-priv, #d97706); }
.ws-member-row__info { flex: 1; min-width: 0; }
.ws-member-row__name { font-size: 0.82rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ws-member-row__status { font-size: 0.7rem; }
.status--active  { color: #4ade80; }
.status--pending { color: var(--ws-priv, #d97706); }
.status--revoked { color: var(--text-muted, #888); }

.ws-empty-msg { font-size: 0.82rem; color: var(--text-muted, #888); padding: 0.5rem 0; }
.ws-error-msg { font-size: 0.82rem; color: var(--error, #fca5a5); padding: 0.5rem 0; }
.teams-loading { display: flex; justify-content: center; padding: 2rem; color: var(--text-muted, #888); }
.teams-error { color: var(--error, #fca5a5); padding: 1rem; text-align: center; }

.invite-accept-page { display: flex; justify-content: center; align-items: center; min-height: 60vh; }
.invite-accept-card {
  background: var(--card-bg, #1e1e2e);
  border: 1px solid var(--border-color, rgba(255,255,255,0.08));
  border-radius: 16px;
  padding: 2.5rem 2rem;
  max-width: 400px; width: 90%;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
}
.invite-accept-card .btn { justify-content: center; }

/* ── PIN Join (form de acceso /ws-join/:id) — UX MVP 2026-04-28 ──────────
   Variante de .invite-accept-card con header rico (avatar + nombre del
   espacio + nickname del owner), CTA primario sólido violeta, branding
   sutil al pie. Tokens canónicos del manual de marca.
*/
.pin-join-card {
  background: linear-gradient(180deg, #1a1330 0%, #130d22 100%);
  border: 1px solid rgba(139, 92, 246, 0.18);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(139, 92, 246, 0.05) inset;
  max-width: 440px;
  padding: 2.25rem 2rem 1.5rem;
  gap: 0;
}
.pin-join-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, #4ade80, #16a34a);
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  margin: 0 auto 1.1rem;
  box-shadow: 0 8px 20px rgba(74, 222, 128, 0.25);
}
.pin-join-icon i, .pin-join-icon svg { width: 24px; height: 24px; }
.pin-join-avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(139, 92, 246, 0.4);
  background: linear-gradient(135deg, #7c3aed, #a78bfa);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1rem;
  box-shadow: 0 8px 20px rgba(124, 58, 237, 0.3);
}
.pin-join-avatar img { width: 100%; height: 100%; object-fit: cover; }
.pin-join-avatar__fallback {
  font-size: 1.6rem;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.pin-join-eyebrow {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #a78bfa;
  margin: 0 0 0.4rem;
  opacity: 0.9;
}
.pin-join-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: #ebe7f4;
  margin: 0 0 0.3rem;
  line-height: 1.3;
}
.pin-join-title--workspace {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  background: linear-gradient(180deg, #ffffff 0%, #d8d2ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: 0 0 0.35rem;
}
.pin-join-owner {
  font-size: 0.85rem;
  color: #8a84a0;
  margin: 0 0 1.5rem;
  line-height: 1.4;
}
.pin-join-owner strong {
  color: #ebe7f4;
  font-weight: 600;
}
.pin-join-desc {
  font-size: 0.86rem;
  color: #8a84a0;
  margin: 0 0 1.4rem;
  line-height: 1.55;
}
.pin-join-pin-label {
  display: block;
  width: 100%;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5a526b;
  margin: 0 0 0.55rem;
  text-align: center;
}
.pin-join-input {
  width: 100%;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 1.65rem;
  font-weight: 700;
  letter-spacing: 0.4em;
  text-align: center;
  text-transform: uppercase;
  padding: 1rem 0.75rem 1rem 1.15rem; /* compensar letter-spacing del último char */
  background: #0a0712;
  border: 1.5px solid rgba(74, 222, 128, 0.28);
  border-radius: 12px;
  color: #4ade80;
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease;
  margin-bottom: 0.55rem;
}
.pin-join-input::placeholder { color: rgba(74, 222, 128, 0.18); }
.pin-join-input:focus {
  border-color: rgba(74, 222, 128, 0.65);
  box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.12);
}
.pin-join-help {
  font-size: 0.73rem;
  color: #5a526b;
  margin: 0 0 1.1rem;
  text-align: center;
  line-height: 1.4;
}
.pin-join-error {
  display: none;
  font-size: 0.78rem;
  color: #f87171;
  margin: 0 0 0.75rem;
  text-align: center;
  background: rgba(248, 113, 113, 0.08);
  border: 1px solid rgba(248, 113, 113, 0.22);
  border-radius: 8px;
  padding: 0.5rem 0.75rem;
  line-height: 1.4;
}
.pin-join-error.is-visible { display: block; }
.pin-join-submit {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1rem;
  background: linear-gradient(180deg, #8b5cf6 0%, #7c3aed 100%);
  border: none;
  border-radius: 12px;
  color: #fff;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 160ms ease, opacity 160ms ease;
  box-shadow: 0 8px 22px rgba(124, 58, 237, 0.35);
  margin-top: 0.25rem;
}
.pin-join-submit:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(124, 58, 237, 0.45);
}
.pin-join-submit:active:not(:disabled) { transform: translateY(0); }
.pin-join-submit:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(167, 139, 250, 0.45), 0 8px 22px rgba(124, 58, 237, 0.35);
}
.pin-join-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  transform: none;
}
.pin-join-submit__spinner {
  display: none;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-top-color: #fff;
  animation: pinJoinSpin 700ms linear infinite;
}
.pin-join-submit.is-loading .pin-join-submit__spinner { display: inline-block; }
@keyframes pinJoinSpin { to { transform: rotate(360deg); } }
.pin-join-brand {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #5a526b;
  margin: 1.4rem 0 0;
  opacity: 0.65;
}
@keyframes pinJoinShake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-8px); }
  40% { transform: translateX(8px); }
  60% { transform: translateX(-5px); }
  80% { transform: translateX(5px); }
}
.pin-join-card.is-shaking { animation: pinJoinShake 380ms cubic-bezier(.36,.07,.19,.97) both; }

/* Countdown "ya eres miembro": UX premium con badge + progress bar */
.invite-countdown-wrap {
  margin-top: 0.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.9rem;
  width: 100%;
}
.invite-countdown-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: rgba(74, 222, 128, 0.1);
  border: 1px solid rgba(74, 222, 128, 0.28);
  border-radius: 999px;
  font-size: 0.78rem;
  color: #4ade80;
  font-weight: 500;
  letter-spacing: 0.01em;
}
.invite-countdown-badge i { color: #4ade80; }
.invite-countdown-msg {
  font-size: 0.92rem;
  color: var(--text-secondary, #b0b0b8);
  text-align: center;
  line-height: 1.55;
  margin: 0;
}
.invite-countdown-num {
  display: inline-block;
  min-width: 1.2em;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: #fff;
  font-size: 1.1em;
  padding: 0 2px;
}
.invite-countdown-bar {
  width: 100%;
  max-width: 240px;
  height: 3px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}
.invite-countdown-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, #7c4dff 0%, #a78bfa 100%);
  border-radius: inherit;
  transform-origin: left center;
  animation: inviteCountdownShrink 5s linear forwards;
  box-shadow: 0 0 8px rgba(124, 77, 255, 0.4);
}
@keyframes inviteCountdownShrink {
  from { transform: scaleX(1); }
  to   { transform: scaleX(0); }
}

/* Vista de invitación pública: ocultar sidebar y chrome de app */
body.invite-view .sidebar { display: none; }
body.invite-view .privacy-footer { display: none; }
.invite-owner-avatar { width: 72px; height: 72px; border-radius: 50%; overflow: hidden; border: 2px solid rgba(124,58,237,0.5); background: rgba(124,58,237,0.08); display: flex; align-items: center; justify-content: center; }
.invite-owner-avatar img { width: 100%; height: 100%; object-fit: cover; }
.invite-owner-avatar img.invite-owner-avatar__brand-img { object-fit: contain; padding: 14px; }
.invite-workspace-name { font-size: 1.35rem; font-weight: 800; margin: 0.25rem 0 0; }
.invite-owner-name { font-size: 0.85rem; color: var(--text-muted, #888); margin: 0; }
.invite-meta { display: flex; gap: 0.5rem; flex-wrap: wrap; justify-content: center; margin-top: 0.25rem; }
.invite-meta__chip { display: inline-flex; align-items: center; gap: 4px; font-size: 0.78rem; color: var(--text-secondary, #aaa); background: rgba(255,255,255,0.07); border-radius: 999px; padding: 3px 10px; }
.invite-type-note { font-size: 0.83rem; color: var(--text-muted, #888); }
.invite-mode-selector { width: 100%; text-align: left; }

/* ── Pending-delete (nota o comentario): dim sutil + outline rojo ── */
.canvas-item--pending-delete,
.canvas-note-block--pending-delete {
  opacity: 0.82;
  filter: saturate(0.85);
  pointer-events: none;
  outline: 2px dashed rgba(248,113,113,0.6);
  outline-offset: -2px;
  transition: opacity 200ms ease, filter 200ms ease;
}
.canvas-note-block { position: relative; }
.canvas-note-block--pending-delete { outline-width: 1px; outline-offset: 1px; border-radius: 4px; }
@keyframes wsCountdown {
  from { transform: scaleX(1); }
  to   { transform: scaleX(0); }
}

/* ── Undo inline (pill justo debajo del objeto a eliminar) ── */
.canvas-undo-inline {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  opacity: 0;
  min-width: 280px;
  max-width: 400px;
  background: #1a1a20;
  color: #f3f4f6;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  box-shadow: 0 14px 36px -14px rgba(0,0,0,0.75), 0 2px 8px rgba(0,0,0,0.35);
  overflow: hidden;
  z-index: 50;
  transition: opacity 180ms ease, transform 220ms cubic-bezier(0.22,1,0.36,1);
  pointer-events: auto;
}
.canvas-undo-inline.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
/* Barra de llenado de fondo: drena de izquierda a derecha en 5s */
.canvas-undo-inline__fill {
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 100%;
  background: linear-gradient(90deg, rgba(239,68,68,0.42), rgba(249,115,22,0.28));
  transform-origin: left center;
  animation: wsCountdown 5s linear forwards;
  pointer-events: none;
  z-index: 0;
}
.canvas-undo-inline__body {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px 8px 12px;
  font-size: 12.5px;
  white-space: nowrap;
}
.canvas-undo-inline > i,
.canvas-undo-inline__body > i { width: 14px; height: 14px; color: #fca5a5; flex-shrink: 0; }
.canvas-undo-inline__label { flex: 1; }
.canvas-undo-inline__count { font-weight: 700; color: #fff; font-variant-numeric: tabular-nums; }
.canvas-undo-inline__btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  background: rgba(124,77,255,0.22);
  color: #c4b5fd;
  border: 1px solid rgba(124,77,255,0.4);
  border-radius: 7px;
  font-size: 12px; font-weight: 600;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease;
}
.canvas-undo-inline__btn:hover {
  background: rgba(124,77,255,0.34);
  border-color: rgba(124,77,255,0.6);
}
.canvas-undo-inline__btn i { width: 12px; height: 12px; }

/* Cuando el undo está sobre un comentario (más pequeño): reducimos tamaños */
.canvas-note-block .canvas-undo-inline {
  min-width: 260px;
  top: calc(100% + 4px);
}
.canvas-note-block .canvas-undo-inline__body { padding: 6px 8px 6px 10px; font-size: 11.5px; }
.canvas-note-block .canvas-undo-inline__btn { padding: 4px 8px; font-size: 11px; }

/* El canvas-item debe permitir que su hijo absoluto (undo pill) se vea fuera */
.canvas-item { overflow: visible; }

/* ── Autosave pill (toast mínimo "✓ Guardado") ── */
.ws-autosave-pill {
  position: fixed;
  bottom: 20px; right: 20px;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px;
  background: rgba(16,185,129,0.92);
  color: #fff;
  font-size: 12px; font-weight: 600;
  border-radius: 999px;
  box-shadow: 0 6px 20px -8px rgba(16,185,129,0.55), 0 2px 6px rgba(0,0,0,0.3);
  backdrop-filter: blur(6px);
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 200ms ease, transform 260ms cubic-bezier(0.22,1,0.36,1);
}
.ws-autosave-pill.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.ws-autosave-pill i { width: 13px; height: 13px; }

/* ── Undo toast (al borrar) ── */
.ws-undo-toast {
  position: fixed;
  bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(14px);
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 14px 10px 16px;
  background: rgba(28,28,34,0.96);
  color: #f3f4f6;
  font-size: 13px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  box-shadow: 0 14px 40px -12px rgba(0,0,0,0.8), 0 2px 8px rgba(0,0,0,0.4);
  backdrop-filter: blur(10px);
  opacity: 0;
  z-index: 9998;
  transition: opacity 220ms ease, transform 280ms cubic-bezier(0.22,1,0.36,1);
}
.ws-undo-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.ws-undo-toast > i { width: 15px; height: 15px; color: #f87171; flex-shrink: 0; }
.ws-undo-toast__msg { flex: 1; white-space: nowrap; }
.ws-undo-toast__btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  background: rgba(124,77,255,0.18);
  color: #c4b5fd;
  border: 1px solid rgba(124,77,255,0.35);
  border-radius: 8px;
  font-size: 12px; font-weight: 600;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease;
}
.ws-undo-toast__btn:hover {
  background: rgba(124,77,255,0.30);
  border-color: rgba(124,77,255,0.55);
}
.ws-undo-toast__btn i { width: 13px; height: 13px; }
.ws-undo-toast__close {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.45);
  cursor: pointer;
  padding: 3px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 6px;
}
.ws-undo-toast__close:hover { color: #fff; background: rgba(255,255,255,0.06); }
.ws-undo-toast__close i { width: 13px; height: 13px; }

/* ── Estado vacío del canvas ── */
.canvas-empty-state {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  max-width: 360px;
  text-align: center;
  pointer-events: none; /* no bloquear dblclick */
  color: rgba(255,255,255,0.55);
  z-index: 0;
  animation: canvasEmptyFadeIn 420ms cubic-bezier(0.22,1,0.36,1) both;
}
@keyframes canvasEmptyFadeIn {
  from { opacity: 0; transform: translate(-50%, calc(-50% + 6px)); }
  to   { opacity: 1; transform: translate(-50%, -50%); }
}
.canvas-empty-state__icon {
  width: 64px; height: 64px;
  margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(124,77,255,0.08);
  border: 1px dashed rgba(124,77,255,0.25);
  border-radius: 16px;
  color: #a78bfa;
}
.canvas-empty-state__icon i { width: 28px; height: 28px; }
.canvas-empty-state__title {
  font-size: 1.05rem;
  font-weight: 600;
  margin: 0 0 8px 0;
  color: rgba(255,255,255,0.78);
}
.canvas-empty-state__desc {
  font-size: 0.85rem;
  line-height: 1.55;
  margin: 0;
  color: rgba(255,255,255,0.48);
}
.canvas-empty-state strong {
  color: rgba(255,255,255,0.72);
  font-weight: 600;
}
#ws-canvas-viewport.bg-light .canvas-empty-state { color: rgba(17,24,39,0.55); }
#ws-canvas-viewport.bg-light .canvas-empty-state__title { color: rgba(17,24,39,0.8); }
#ws-canvas-viewport.bg-light .canvas-empty-state__desc  { color: rgba(17,24,39,0.55); }
#ws-canvas-viewport.bg-light .canvas-empty-state strong { color: rgba(17,24,39,0.78); }

/* Touch: evita que el navegador use gestos nativos sobre canvas/notas */
#ws-canvas-viewport, .canvas-item, .canvas-item__resize {
  touch-action: none;
}

@media (max-width: 600px) {
  .ws-drawer { width: 100%; max-width: 100%; }
}

/* Modal "Configurar fuentes" — cards con toggle + filtros */
.ws-modal--sources { width: min(960px, 94vw); max-width: min(960px, 94vw); max-height: 88vh; display: flex; flex-direction: column; padding: 1.25rem 1.5rem; }
.ws-sources-filters {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 0.55rem;
  padding: 0.75rem 0.9rem 0.85rem;
  border-bottom: 1px solid var(--border-color, rgba(255,255,255,0.08));
  align-items: stretch;
}
.ws-sources-filter {
  padding: 8px 12px;
  border-radius: 10px;
  font-size: 13px;
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
}
/* Wrapper con tooltip que contiene el select de scope: el grid lo estira,
   pero el select interno debe ocupar el alto completo del wrapper. */
.ws-sources-filters > .feed-filter-wrap.ws-sources-filter {
  padding: 0;
  display: flex;
}
.ws-sources-filters > .feed-filter-wrap.ws-sources-filter > select {
  width: 100%;
  height: 100%;
}
@media (max-width: 720px) {
  .ws-sources-filters { grid-template-columns: 1fr 1fr; }
}
.ws-sources-bulk {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.55rem 0.9rem;
  border-bottom: 1px solid var(--border-color, rgba(255,255,255,0.06));
}
.ws-sources-bulk__btn {
  font-size: 0.78rem;
  padding: 0.35rem 0.8rem;
}
.ws-sources-bulk__hint {
  font-size: 0.72rem;
  color: var(--text-muted, #888);
  letter-spacing: 0.02em;
}
.ws-sources-grid {
  flex: 1;
  overflow-y: auto;
  padding: 0.7rem 0.9rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.6rem;
  align-content: start;
}
.ws-source-card {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.7rem 0.85rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-color, rgba(255,255,255,0.08));
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.ws-source-card:hover { background: rgba(255,255,255,0.06); }
.ws-source-card.is-active {
  background: rgba(124,58,237,0.12);
  border-color: var(--accent, #7c3aed);
}
.ws-source-card__body { flex: 1; min-width: 0; }
.ws-source-card__name {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-primary, #fff);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 0.25rem;
}
.ws-source-card__badges { display: flex; gap: 0.3rem; flex-wrap: wrap; }
.ws-source-card__badge {
  font-size: 0.66rem;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 4px;
  background: rgba(96, 165, 250, 0.15);
  color: #60a5fa;
  letter-spacing: 0.02em;
}
.ws-source-card__badge--lang { background: rgba(34,197,94,0.15); color: #4ade80; }
.ws-source-card__badge--public {
  background: rgba(139, 92, 246, 0.18);
  color: #a78bfa;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.ws-source-card__badge--public i { width: 10px; height: 10px; }

.jobs-selector-list {
  max-height: 50vh;
  overflow-y: auto;
  padding: 0.4rem 0.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.job-check-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.7rem;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
  color: var(--text-primary, #fff);
  font-size: 0.88rem;
}
.job-check-row:hover { background: rgba(255,255,255,0.05); }
.job-check-row input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: var(--accent, #7c3aed);
  cursor: pointer;
  flex-shrink: 0;
}
.job-check-row span {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ws-feed-loading {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem;
  color: var(--text-muted, #888);
}
.ws-feed-loading i, .ws-feed-loading svg {
  width: 20px; height: 20px;
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Wrapper de card + topics (grid item único) ────────────────────────────── */
.ws-source-card-wrap {
  display: flex;
  flex-direction: column;
  height: 100%;  /* estira el item a la altura de la fila del grid */
}
.ws-source-card-wrap > .ws-source-card {
  flex: 1;       /* el card ocupa toda la altura del wrapper */
}

/* ── Job topic filters — panel colapsable en modal de fuentes (legacy, ya no se usa tras refactor a filtro global) ──────────────── */
.ws-job-topics {
  background: rgba(124,58,237,0.07);
  border: 1px solid var(--accent, #7c3aed);
  border-top: none;
  border-radius: 0 0 10px 10px;
}
.ws-job-topics__toggle {
  width: 100%;
  background: none;
  border: none;
  border-bottom: 1px solid transparent;
  padding: 0.45rem 0.85rem;
  color: #a78bfa;
  font-size: 0.73rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: background 0.15s, border-color 0.15s;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
.ws-job-topics__toggle:hover {
  background: rgba(124,58,237,0.1);
}
.ws-job-topics__toggle.is-open {
  border-bottom-color: rgba(124,58,237,0.25);
}
.ws-job-topics__toggle-chevron {
  margin-left: auto;
  font-style: normal;
  font-size: 0.85rem;
  transition: transform 0.2s;
  color: rgba(167,139,250,0.6);
}
.ws-job-topics__toggle.is-open .ws-job-topics__toggle-chevron {
  transform: rotate(180deg);
}
.ws-job-topics__count {
  background: var(--accent, #7c3aed);
  color: #fff;
  font-size: 0.6rem;
  padding: 1px 5px;
  border-radius: 8px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}
.ws-job-topics__body {
  padding: 0.6rem 0.85rem 0.75rem;
}
.ws-job-topics__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-bottom: 0.5rem;
  min-height: 0;
}
.ws-job-topic-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 3px 9px;
  background: rgba(124,77,255,0.18);
  border: 1px solid rgba(124,77,255,0.4);
  border-radius: 20px;
  font-size: 0.75rem;
  color: #c4b5fd;
}
.ws-job-topic-chip__remove {
  background: none;
  border: none;
  color: rgba(196,181,253,0.6);
  cursor: pointer;
  font-size: 0.9rem;
  padding: 0;
  line-height: 1;
  transition: color 0.15s;
}
.ws-job-topic-chip__remove:hover { color: #f87171; }
.ws-job-topics__input-wrap { position: relative; }
.ws-job-topics__input {
  width: 100%;
  padding: 6px 11px;
  font-size: 0.8rem;
  border-radius: 8px;
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(124,77,255,0.25);
  color: #e8e8f0;
  outline: none;
  transition: border-color 0.15s;
  box-sizing: border-box;
}
.ws-job-topics__input:focus {
  border-color: rgba(124,77,255,0.6);
  background: rgba(0,0,0,0.35);
}
.ws-job-topics__input::placeholder { color: rgba(184,184,204,0.45); }
.ws-job-topics__suggestions {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: #141428;
  border: 1px solid rgba(124,77,255,0.35);
  border-radius: 9px;
  z-index: 1000;
  max-height: 150px;
  overflow-y: auto;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.ws-job-topics__suggestion {
  padding: 7px 13px;
  font-size: 0.8rem;
  cursor: pointer;
  color: #d4d4e8;
  transition: background 0.1s;
}
.ws-job-topics__suggestion:first-child { border-radius: 9px 9px 0 0; }
.ws-job-topics__suggestion:last-child  { border-radius: 0 0 9px 9px; }
.ws-job-topics__suggestion:hover { background: rgba(124,77,255,0.15); color: #e8e8f0; }
.ws-job-topics__hint {
  font-size: 0.68rem;
  color: rgba(152,152,180,0.7);
  margin-top: 0.45rem;
  margin-bottom: 0;
  font-style: italic;
}

/* ── Filtro global de temas en modal de fuentes (patrón feed: chips + dropdown check + Aplicar) ── */
.ws-global-topics {
  padding: 0.8rem 0.95rem 0.85rem;
  background: rgba(124,58,237,0.06);
  border: 1px solid rgba(124,58,237,0.28);
  border-radius: 10px;
  margin: 0.85rem 0.9rem 0;
  position: relative;
}
.ws-global-topics__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.55rem;
}
.ws-global-topics__label {
  font-size: 0.72rem;
  font-weight: 700;
  color: #a78bfa;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ws-global-topics__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-bottom: 0.55rem;
  min-height: 0;
}
.ws-global-topics__chips:empty { display: none; }
.ws-global-topic-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 4px 10px;
  background: rgba(124,77,255,0.22);
  border: 1px solid rgba(124,77,255,0.45);
  border-radius: 999px;
  font-size: 0.75rem;
  color: #c4b5fd;
  font-weight: 600;
}
.ws-global-topic-chip__remove {
  background: none;
  border: none;
  color: rgba(196,181,253,0.65);
  cursor: pointer;
  font-size: 0.95rem;
  padding: 0;
  line-height: 1;
  transition: color 0.15s;
}
.ws-global-topic-chip__remove:hover { color: #f87171; }
.ws-global-topics__clear-all {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 4px 10px;
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.35);
  border-radius: 999px;
  font-size: 0.72rem;
  color: #fca5a5;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.ws-global-topics__clear-all:hover { background: rgba(239,68,68,0.2); color: #fecaca; }
.ws-global-topics__input-wrap { position: relative; }
.ws-global-topics__input {
  width: 100%;
  padding: 8px 13px;
  font-size: 0.82rem;
  border-radius: 9px;
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(124,77,255,0.28);
  color: #e8e8f0;
  outline: none;
  transition: border-color 0.15s, opacity 0.15s;
  box-sizing: border-box;
}
.ws-global-topics__input:focus {
  border-color: rgba(124,77,255,0.65);
  background: rgba(0,0,0,0.4);
}
.ws-global-topics__input::placeholder { color: rgba(184,184,204,0.48); }
.ws-global-topics__input:disabled { opacity: 0.4; cursor: not-allowed; }
.ws-global-topics__dropdown {
  position: absolute;
  top: calc(100% + 5px);
  left: 0;
  right: 0;
  background: #141428;
  border: 1px solid rgba(124,77,255,0.4);
  border-radius: 10px;
  z-index: 1200;
  max-height: 320px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 12px 28px rgba(0,0,0,0.45);
  overflow: hidden;
}
.ws-global-topics__list {
  flex: 1;
  overflow-y: auto;
  padding: 0.3rem 0;
}
.ws-global-topics__check-item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 8px 14px;
  cursor: pointer;
  font-size: 0.82rem;
  color: #d4d4e8;
  transition: background 0.1s;
  user-select: none;
}
.ws-global-topics__check-item:hover { background: rgba(124,77,255,0.13); }
.ws-global-topics__check-item.is-checked { color: #e8e8f0; }
.ws-global-topics__checkbox {
  width: 16px; height: 16px;
  border: 1.5px solid rgba(124,77,255,0.55);
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.12s, border-color 0.12s;
  color: #fff;
}
.ws-global-topics__check-item.is-checked .ws-global-topics__checkbox {
  background: #7c3aed;
  border-color: #7c3aed;
}
.ws-global-topics__check-label { flex: 1; }
.ws-global-topics__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.85rem;
  border-top: 1px solid rgba(124,77,255,0.2);
  background: rgba(0,0,0,0.2);
}
.ws-global-topics__count-text {
  font-size: 0.72rem;
  color: #a78bfa;
  font-weight: 600;
}
.ws-global-topics__apply-btn {
  background: linear-gradient(135deg, #7c3aed, #6d28d9);
  border: none;
  color: #fff;
  padding: 5px 14px;
  border-radius: 7px;
  font-size: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  box-shadow: 0 2px 8px rgba(124,58,237,0.3);
  transition: filter 0.15s;
}
.ws-global-topics__apply-btn:hover { filter: brightness(1.12); }
.ws-global-topics__apply-btn[disabled] { opacity: 0.5; cursor: not-allowed; filter: none; }
.ws-global-topics__empty {
  padding: 0.85rem 1rem;
  font-size: 0.78rem;
  color: rgba(152,152,180,0.65);
  font-style: italic;
  text-align: center;
}
.ws-global-topics__hint {
  font-size: 0.68rem;
  color: rgba(152,152,180,0.7);
  margin: 0.6rem 0 0;
  font-style: italic;
}

/* ── Watch Party v2 ─────────────────────────────────────────────────────── */

/* Barra de invitación (phase: inviting) */
.ws-invite-bar {
  background: var(--bg-secondary, #0d0d1a);
  border-bottom: 2px solid #e67e22;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 25;
  flex-shrink: 0;
  animation: ws-slidein 0.25s ease;
}
.ws-invite-bar__title { color: #fff; font-size: 0.8rem; font-weight: 600; }
.ws-invite-bar__sub   { color: #aaa; font-size: 0.7rem; }
.ws-invite-btn-join   {
  background: #10b981; color: #fff;
  border: none; border-radius: 6px;
  padding: 6px 14px; font-size: 0.75rem; font-weight: 700; cursor: pointer;
  flex-shrink: 0;
}
.ws-invite-btn-dismiss {
  background: transparent; color: #888;
  border: 1px solid #444; border-radius: 6px;
  padding: 6px 10px; font-size: 0.75rem; cursor: pointer;
  flex-shrink: 0;
}

/* Barra de sala de espera (phase: waiting_room) */
.ws-waiting-bar {
  background: var(--bg-secondary, #0d0d1a);
  border-bottom: 2px solid #3b82f6;
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  z-index: 25;
  flex-shrink: 0;
}
.ws-waiting-thumb {
  width: 80px; height: 45px;
  border-radius: 4px; overflow: hidden; flex-shrink: 0;
}
.ws-waiting-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ws-waiting-info  { flex: 1; min-width: 0; }
.ws-waiting-title { color: #fff; font-size: 0.78rem; font-weight: 600; }
.ws-waiting-sub   { color: #888; font-size: 0.68rem; margin-top: 2px; }
.ws-waiting-badge {
  background: rgba(59,130,246,0.15);
  border: 1px solid #3b82f6;
  color: #3b82f6;
  border-radius: 99px;
  padding: 2px 10px;
  font-size: 0.68rem; font-weight: 600;
  flex-shrink: 0;
}
.ws-seek-btn {
  background: rgba(59,130,246,0.15);
  border: 1px solid #3b82f6;
  color: #3b82f6;
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 0.7rem; cursor: pointer;
}
.ws-seek-btn:hover { background: rgba(59,130,246,0.3); }
.ws-start-btn {
  background: #10b981; color: #fff;
  border: none; border-radius: 6px;
  padding: 6px 12px; font-size: 0.75rem; font-weight: 700; cursor: pointer;
  flex-shrink: 0;
}
.ws-cancel-btn {
  background: transparent; color: #888;
  border: 1px solid #444; border-radius: 6px;
  padding: 5px 10px; font-size: 0.7rem; cursor: pointer;
}

#ws-yt-player-theater iframe { width: 100%; height: 100%; border: none; }

/* Toast discreto de rate limit de chat — aparece debajo del input del chat */
.ws-chat-rate-toast {
  background: rgba(20, 20, 32, 0.94);
  color: #ddd;
  border: 1px solid rgba(255, 200, 100, 0.5);
  border-left: 3px solid #ffc864;
  border-radius: 6px;
  padding: 5px 10px;
  margin: 0 0.6rem 0.5rem;
  font-size: 0.72rem;
  flex-shrink: 0;
  animation: ws-chat-toast-in 180ms ease-out;
}

/* Toast violeta del guest cuando admin cambia a autonomo */
.ws-mode-auto-toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 10001;
  background: rgba(20, 20, 32, 0.94);
  color: #ddd;
  border: 1px solid rgba(108, 99, 255, 0.5);
  border-left: 3px solid #6c63ff;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 0.8rem;
  line-height: 1.4;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  animation: ws-chat-toast-in 180ms ease-out;
  max-width: 340px;
}

/* Modal guest de countdown cuando admin hace flip autónomo→admin. Overlay
   semi-opaco + dialog centrado con 30s contador y opciones Continuar / Salir. */
.ws-resync-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 10002;
  display: flex; align-items: center; justify-content: center;
  animation: ws-chat-toast-in 180ms ease-out;
}
.ws-resync-dialog {
  background: #0d0d1a;
  border: 2px solid #6c63ff;
  border-radius: 12px;
  padding: 24px 28px;
  max-width: 420px;
  width: 90vw;
  text-align: center;
  color: #e9d5ff;
}
.ws-resync-dialog h3 {
  margin: 0 0 12px;
  font-size: 1.1rem;
  color: #fff;
}
.ws-resync-dialog p {
  font-size: 0.88rem;
  line-height: 1.5;
  margin: 0 0 10px;
  color: #ddd;
}
.ws-resync-dialog__countdown {
  font-weight: 700;
  color: #c4b5fd !important;
}
.ws-resync-dialog__actions {
  display: flex;
  gap: 10px;
  margin-top: 18px;
  justify-content: center;
}
.ws-resync-dialog__accept,
.ws-resync-dialog__leave {
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
}
.ws-resync-dialog__accept {
  background: #6c63ff;
  color: #fff;
}
.ws-resync-dialog__accept:hover { background: #7d72ff; }
.ws-resync-dialog__leave {
  background: transparent;
  color: #aaa;
  border: 1px solid #444;
}
.ws-resync-dialog__leave:hover { background: rgba(255,255,255,0.05); }

@keyframes ws-chat-toast-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes ws-slidein {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

/* ── Note type picker (doble-click canvas) ─────────────────────────── */
.note-type-picker {
  position: fixed;
  width: 290px;
  background: var(--cv-panel);
  border: 1px solid var(--cv-border-strong);
  border-radius: 12px;
  padding: 6px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.55), 0 0 0 1px rgba(139,92,246,0.04);
  font-family: Inter, -apple-system, system-ui, sans-serif;
  z-index: 9500;
  opacity: 0;
  transform: scale(0.96);
  transition: opacity 0.12s, transform 0.12s;
  pointer-events: none;
}
.note-type-picker.is-open {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}
.note-type-picker__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.12s;
  background: transparent;
  border: none;
  width: 100%;
  text-align: left;
  color: inherit;
  font-family: inherit;
}
.note-type-picker__item:hover,
.note-type-picker__item:focus,
.note-type-picker__item.is-focused {
  background: var(--cv-panel-hover);
  outline: none;
}
.note-type-picker__icn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--cv-panel-raised);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cv-violet-bright);
  flex-shrink: 0;
  font-size: 16px;
}
.note-type-picker__item--ai .note-type-picker__icn {
  background: linear-gradient(135deg, var(--sbr-violet), var(--cv-violet-deep));
  color: #fff;
  box-shadow: 0 2px 10px var(--cv-violet-glow);
}
.note-type-picker__header {
  padding: 8px 12px 6px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.8px;
  color: var(--cv-text-faint);
  text-transform: uppercase;
}
.note-type-picker__body {
  flex: 1;
  min-width: 0;
}
.note-type-picker__label {
  font-size: 13px;
  font-weight: 500;
  color: var(--cv-text);
}
.note-type-picker__desc {
  font-size: 11px;
  color: var(--cv-text-faint);
  margin-top: 1px;
}
.note-type-picker__shortcut {
  font-size: 10px;
  color: var(--cv-text-dim);
  padding: 2px 6px;
  border: 1px solid var(--cv-border);
  border-radius: 4px;
  font-family: ui-monospace, monospace;
}
/* ── Poll hint tooltip (tras crear un poll con el picker) ──────────── */
.poll-hint-tooltip {
  position: absolute;
  z-index: 8500;
  background: #7c3aed;
  color: #ffffff;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1.4;
  max-width: 240px;
  box-shadow: 0 6px 16px rgba(124, 58, 237, 0.35);
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}
.poll-hint-tooltip.is-open {
  opacity: 1;
  transform: translateY(0);
}
.poll-hint-tooltip::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 20px;
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid #7c3aed;
}

/* ── Cursores fantasma del canvas ───────────────────────────────────────── */
.ws-canvas-cursors {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
  overflow: hidden;
}

.ghost-cursor {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: flex-start;
  gap: 4px;
  transform-origin: top left;
  will-change: transform, opacity;
  transition: opacity 250ms ease;
  user-select: none;
  pointer-events: none;
  opacity: 0.72;
}

.ghost-cursor__pointer {
  flex: 0 0 auto;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.35));
  stroke-dasharray: 2 1.5;
}

.ghost-cursor__label {
  font-size: 11px;
  line-height: 1;
  padding: 3px 6px;
  border-radius: 4px;
  max-width: 120px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
  color: #fff;
  border: 1.5px dotted transparent;
}

.ghost-cursor--idle {
  opacity: 0.3;
}


