/* ─────────────────────────────────────────────────────────────
   ClaudioBot v2 — estilos para fases nuevas + roles + drive
   ───────────────────────────────────────────────────────────── */

/* Scope pill — collapse on smaller screens */
.cb-scope {
  display: inline-flex; align-items: center; gap: 8px;
  height: 32px; padding: 0 12px;
  background: var(--cb-surf);
  border: 1px solid var(--cb-line);
  border-radius: 8px;
  font-size: 11.5px; color: var(--cb-text-2);
  white-space: nowrap;
  flex-shrink: 0;
}
@media (max-width: 1440px) {
  .cb-scope__txt { display: none; }
  .cb-scope { padding: 0 10px; }
}
.cb-scope__dot { width: 8px; height: 8px; border-radius: 50%; }
.cb-scope__txt strong { color: var(--cb-text); font-weight: 600; }

/* User picker en sidebar ──────────────────────────────── */
.cb-side__user {
  width: 100%;
  display: flex; align-items: center; gap: 10px;
  padding: 8px;
  background: var(--cb-surf);
  border: 1px solid var(--cb-line);
  border-radius: 10px;
  cursor: pointer;
  color: var(--cb-text);
  text-align: left;
  transition: background .12s;
}
.cb-side__user:hover { background: var(--cb-surf-2); }
.cb-side__uwrap { flex: 1; min-width: 0; }

.cb-userpick {
  position: absolute;
  bottom: 70px; left: 12px; right: 12px;
  background: var(--cb-surf-2);
  border: 1px solid var(--cb-line-strong);
  border-radius: 10px;
  box-shadow: var(--cb-shadow-lg);
  padding: 8px;
  z-index: 30;
}
.cb-userpick__hint { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cb-text-3); padding: 4px 6px 8px; }
.cb-userpick__row {
  width: 100%;
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: transparent;
  border: none;
  border-radius: 8px;
  color: var(--cb-text);
  text-align: left;
}
.cb-userpick__row:hover { background: var(--cb-bg-2); }
.cb-userpick__row.is-active { background: color-mix(in oklch, var(--cb-accent) 12%, var(--cb-bg-2)); }
.cb-userpick__row.is-active svg { color: var(--cb-accent); }
.cb-userpick__row > div { flex: 1; min-width: 0; }
.cb-userpick__n { font-size: 12.5px; font-weight: 500; }
.cb-userpick__r { font-size: 10.5px; color: var(--cb-text-3); }

/* Pill scoped en sidebar */
.cb-side__item .cb-pill--warn { padding: 0 5px; font-size: 9.5px; }
.cb-side__priv { color: var(--cb-text-4); display: inline-flex; }
.cb-side__item.is-private .cb-side__label { color: var(--cb-text-2); }
.cb-side__item.is-private:hover .cb-side__label { color: var(--cb-text); }

/* Command palette extras */
.cb-cmdpal__name { flex: 1; }
.cb-cmdpal__group { font-family: var(--cb-font-mono); font-size: 10.5px; color: var(--cb-text-3); }

/* Banner privado para Fase G ─────────────────────────── */
.cb-private-banner {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: var(--cb-space-4);
  padding: 10px 14px;
  background: color-mix(in oklch, var(--cb-danger) 8%, var(--cb-surf));
  border: 1px solid color-mix(in oklch, var(--cb-danger) 28%, transparent);
  border-radius: 8px;
  font-size: 12px;
  color: var(--cb-text);
}
.cb-private-banner svg { color: var(--cb-danger); }
.cb-private-banner strong { color: var(--cb-danger); }
.cb-private-banner span { color: var(--cb-text-3); margin-left: auto; font-family: var(--cb-font-mono); font-size: 11px; }

/* Fase A — Antecedentes ──────────────────────────────── */
.cb-ant__filt { display: flex; justify-content: space-between; gap: 12px; align-items: center; flex-wrap: wrap; }
.cb-ant__search { display: flex; align-items: center; gap: 8px; background: var(--cb-surf); border: 1px solid var(--cb-line); border-radius: 8px; padding: 0 12px; flex: 1; max-width: 360px; }
.cb-ant__search svg { color: var(--cb-text-3); }
.cb-ant__input { border: none; background: transparent; padding: 8px 0; height: 32px; font-family: var(--cb-font-sans); font-size: 13px; }
.cb-ant__card { display: flex; flex-direction: column; }
.cb-ant__card .cb-card__body { display: flex; flex-direction: column; gap: 8px; }
.cb-ant__head { display: flex; justify-content: space-between; align-items: center; }
.cb-ant__t { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.35; text-wrap: pretty; }
.cb-ant__cli { font-size: 11.5px; color: var(--cb-text-3); }
.cb-ant__monto { font-size: 15px; font-weight: 600; margin-top: 4px; }
.cb-ant__stats { display: flex; gap: 14px; font-size: 11px; color: var(--cb-text-2); margin-top: 4px; }
.cb-ant__stats span { display: inline-flex; align-items: center; gap: 4px; }
.cb-ant__stats svg { color: var(--cb-accent); }
.cb-ant__cta { display: flex; gap: 6px; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--cb-line); }

/* Fase P — RRHH ─────────────────────────────────────── */
.cb-vto--na { font-size: 10.5px; color: var(--cb-text-4); }
.cb-rrhh__al { display: flex; flex-direction: column; gap: 2px; }
.cb-rrhh__al span { font-size: 11px; color: var(--cb-danger); }
.cb-rrhh__vto { display: flex; flex-direction: column; }
.cb-rrhh__vrow {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--cb-line);
}
.cb-rrhh__vrow:last-child { border-bottom: none; }
.cb-rrhh__vbody { flex: 1; min-width: 0; }
.cb-rrhh__vname { font-size: 12.5px; }
.cb-rrhh__vdoc  { font-size: 11px; color: var(--cb-text-3); font-family: var(--cb-font-mono); }

/* Fase T — Taller ───────────────────────────────────── */
.cb-grid--taller { grid-template-columns: 1fr 340px; }
@media (max-width: 1180px) { .cb-grid--taller { grid-template-columns: 1fr; } }
.cb-taller__side { display: flex; flex-direction: column; gap: var(--cb-space-4); }
.cb-rep { display: flex; flex-direction: column; }
.cb-rep__row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-rep__row:last-child { border-bottom: none; }
.cb-rep__txt { flex: 1; min-width: 0; }
.cb-rep__name { font-size: 12.5px; }
.cb-rep__sub  { font-size: 10.5px; color: var(--cb-text-3); margin-top: 1px; }

/* Fase D — Docs cliente ─────────────────────────────── */
.cb-docscli { display: grid; grid-template-columns: 320px 1fr; gap: var(--cb-space-4); align-items: start; }
@media (max-width: 1100px) { .cb-docscli { grid-template-columns: 1fr; } }
.cb-docscli__list { max-height: calc(100vh - 280px); overflow: hidden; }
.cb-docscli__items { overflow-y: auto; }
.cb-docscli__item {
  width: 100%;
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 14px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--cb-line);
  border-left: 3px solid transparent;
  text-align: left;
  color: var(--cb-text);
}
.cb-docscli__item:hover { background: var(--cb-bg-2); }
.cb-docscli__item.is-active { background: var(--cb-bg-2); border-left-color: var(--cb-accent); }
.cb-docscli__head { display: flex; justify-content: space-between; align-items: center; }
.cb-docscli__obra { font-size: 12px; color: var(--cb-text-2); }
.cb-docscli__cli { font-size: 12.5px; font-weight: 500; }
.cb-docscli__meta { font-size: 11px; color: var(--cb-text-3); display: flex; align-items: center; gap: 5px; }
.cb-docscli__main { display: flex; flex-direction: column; gap: var(--cb-space-4); }

.cb-pkg { display: flex; flex-direction: column; }
.cb-pkg__row { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--cb-line); }
.cb-pkg__row:last-child { border-bottom: none; }
.cb-pkg__icon.is-good { color: var(--cb-good); }
.cb-pkg__icon.is-warn { color: var(--cb-warn); }
.cb-pkg__body { flex: 1; }
.cb-pkg__n { font-size: 12.5px; }
.cb-pkg__meta { font-size: 11px; color: var(--cb-text-3); }

/* Fase S — Seguros · usa estilos existentes */

/* Fase G — Gastos dueños ────────────────────────────── */
.cb-inv { display: flex; flex-direction: column; }
.cb-inv__row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-inv__row:last-of-type { border-bottom: 1px solid var(--cb-line); }
.cb-inv__body { flex: 1; }
.cb-inv__t { font-size: 12.5px; font-weight: 500; }
.cb-inv__meta { font-size: 11px; color: var(--cb-text-3); }
.cb-inv__monto { font-size: 13px; font-weight: 500; }
.cb-inv__total { display: flex; justify-content: space-between; padding: 12px 14px; margin-top: 8px; background: color-mix(in oklch, var(--cb-accent) 14%, var(--cb-bg-2)); border-radius: 8px; }
.cb-inv__total span { font-size: 12.5px; color: var(--cb-text); font-weight: 500; }
.cb-inv__total strong { font-size: 14px; color: var(--cb-accent); }

/* Mapa Drive ────────────────────────────────────────── */
.cb-drive-graph {
  display: grid; grid-template-columns: 1fr 80px 1.4fr;
  gap: 0;
  padding: 22px;
  background: var(--cb-surf);
  border: 1px solid var(--cb-line);
  border-radius: var(--cb-radius-lg);
}
.cb-drive-graph__title {
  font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--cb-text-3); margin-bottom: 10px;
}
.cb-drive-graph__areas, .cb-drive-graph__master { display: flex; flex-direction: column; gap: 6px; }
.cb-drive-graph__center { position: relative; }
.cb-drive-graph__svg { width: 100%; height: 100%; min-height: 380px; }

.cb-drive-area {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  background: var(--cb-bg-2);
  border: 1px solid var(--cb-line);
  border-radius: 8px;
  color: var(--cb-text);
  font-size: 13px; font-weight: 500;
  text-align: left;
  transition: border-color .12s, transform .12s, background .12s;
}
.cb-drive-area:hover { border-color: var(--cb-line-strong); background: var(--cb-surf-2); }
.cb-drive-area span { flex: 1; }
.cb-drive-area svg { color: var(--cb-text-3); }
.cb-drive-area__count {
  font-family: var(--cb-font-mono); font-size: 10.5px;
  padding: 1px 6px; background: var(--cb-surf); border-radius: 999px;
  flex: none !important;
}
.cb-drive-area.is-active { border-color: var(--cb-accent); background: color-mix(in oklch, var(--cb-accent) 10%, var(--cb-bg-2)); }
.cb-drive-area.is-active svg { color: var(--cb-accent); }
.cb-drive-area--accent.is-active { border-color: var(--cb-accent); }
.cb-drive-area--info.is-active   { border-color: var(--cb-info); background: color-mix(in oklch, var(--cb-info) 12%, var(--cb-bg-2)); }
.cb-drive-area--info.is-active svg { color: var(--cb-info); }
.cb-drive-area--warn.is-active   { border-color: var(--cb-warn); background: color-mix(in oklch, var(--cb-warn) 12%, var(--cb-bg-2)); }
.cb-drive-area--warn.is-active svg { color: var(--cb-warn); }
.cb-drive-area--good.is-active   { border-color: var(--cb-good); background: color-mix(in oklch, var(--cb-good) 12%, var(--cb-bg-2)); }
.cb-drive-area--good.is-active svg { color: var(--cb-good); }

.cb-drive-master {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 12px;
  background: var(--cb-bg-2);
  border: 1px solid var(--cb-line);
  border-radius: 6px;
  font-size: 12px;
  color: var(--cb-text-3);
  transition: border-color .15s, color .15s, background .15s;
}
.cb-drive-master.is-active { border-color: color-mix(in oklch, var(--cb-accent) 40%, var(--cb-line)); color: var(--cb-text); background: var(--cb-surf-2); }
.cb-drive-master.is-private { border-style: dashed; border-color: color-mix(in oklch, var(--cb-danger) 40%, var(--cb-line)); }
.cb-drive-master.is-private svg { color: var(--cb-danger); }
.cb-drive-master__id { font-size: 10.5px; color: var(--cb-text-4); width: 18px; }
.cb-drive-master__name { font-size: 11.5px; flex: 1; }

/* Detalle de área */
.cb-grid--detail { grid-template-columns: 1.6fr 1fr; }
@media (max-width: 1080px) { .cb-grid--detail { grid-template-columns: 1fr; } }
.cb-area-desc { font-size: 12.5px; color: var(--cb-text-2); margin: 0 0 14px; line-height: 1.6; }
.cb-area-desc strong { color: var(--cb-accent); font-weight: 600; }
.cb-area-list { display: flex; flex-direction: column; }
.cb-area-row { display: flex; align-items: center; gap: 12px; padding: 9px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-area-row:last-child { border-bottom: none; }
.cb-area-row > div { flex: 1; min-width: 0; }
.cb-area-row svg { color: var(--cb-accent); flex-shrink: 0; }
.cb-area-row__n { font-size: 12px; color: var(--cb-text); }
.cb-area-row__d { font-size: 11px; color: var(--cb-text-3); margin-top: 2px; }

.cb-acc-users { display: flex; flex-direction: column; }
.cb-acc-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-acc-row:last-child { border-bottom: none; }
.cb-acc-row__body { flex: 1; min-width: 0; }
.cb-acc-row__n { font-size: 12.5px; }
.cb-acc-row__r { font-size: 11px; color: var(--cb-text-3); }
.cb-acc-row__icon.is-ok { color: var(--cb-good); }
.cb-acc-row__icon.is-no { color: var(--cb-text-4); }

/* Matriz de permisos ────────────────────────────────── */
.cb-permmtx {
  display: flex; flex-direction: column;
  overflow-x: auto;
}
.cb-permmtx__head, .cb-permmtx__row { display: flex; }
.cb-permmtx__head { background: var(--cb-bg-2); border-bottom: 1px solid var(--cb-line); }
.cb-permmtx__row { border-bottom: 1px solid var(--cb-line); }
.cb-permmtx__row:last-child { border-bottom: none; }
.cb-permmtx__row:hover { background: color-mix(in oklch, var(--cb-bg-2) 50%, transparent); }
.cb-permmtx__cell {
  padding: 10px 12px;
  display: flex; align-items: center; gap: 8px;
  font-size: 12px;
  flex: 1;
  min-width: 70px;
  border-right: 1px dashed var(--cb-line);
}
.cb-permmtx__cell:last-child { border-right: none; }
.cb-permmtx__cell--label { flex: 2.5; min-width: 220px; gap: 6px; }
.cb-permmtx__cell--th { flex-direction: column; align-items: center; gap: 3px; padding: 12px 8px; min-width: 90px; }
.cb-permmtx__cell--th span { font-size: 11.5px; font-weight: 600; }
.cb-permmtx__role { font-size: 10px; color: var(--cb-text-3); font-weight: 400 !important; }
.cb-permmtx__id { font-size: 10.5px; color: var(--cb-text-3); }
.cb-permmtx__name { font-size: 11.5px; flex: 1; }
.cb-permmtx__priv { color: var(--cb-danger); }
.cb-permmtx__cell--v { justify-content: center; min-width: 90px; }
.cb-permmtx__cell--v.is-ok { color: var(--cb-good); }
.cb-permmtx__cell--v.is-ok svg { background: color-mix(in oklch, var(--cb-good) 22%, transparent); border-radius: 50%; padding: 4px; width: 20px; height: 20px; box-sizing: content-box; padding: 2px; }
.cb-permmtx__cell--v.is-no { color: var(--cb-text-4); }
.cb-permmtx__cell--v.is-no svg { opacity: 0.4; }

/* Reglas + beneficios ───────────────────────────────── */
.cb-rules { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.cb-rules li { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; line-height: 1.45; color: var(--cb-text-2); }
.cb-rules__ok, .cb-rules__no {
  width: 18px; height: 18px;
  display: grid; place-items: center;
  border-radius: 50%; flex-shrink: 0;
}
.cb-rules__ok { background: color-mix(in oklch, var(--cb-good) 18%, transparent); color: var(--cb-good); }
.cb-rules__no { background: color-mix(in oklch, var(--cb-danger) 18%, transparent); color: var(--cb-danger); }
.cb-bnf { display: flex; flex-direction: column; gap: 10px; }
.cb-bnf__row { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; line-height: 1.5; color: var(--cb-text-2); }
.cb-bnf__row svg { color: var(--cb-accent); margin-top: 2px; flex-shrink: 0; }
.cb-bnf__row strong { color: var(--cb-text); font-weight: 600; }

/* Compact density */
:root[data-density="compact"] .cb-drive-graph { padding: 14px; }
:root[data-density="compact"] .cb-drive-area { padding: 9px 12px; }
:root[data-density="compact"] .cb-drive-master { padding: 5px 10px; }

/* Mobile */
@media (max-width: 900px) {
  .cb-drive-graph { grid-template-columns: 1fr; }
  .cb-drive-graph__center { display: none; }
  .cb-ant__filt { flex-direction: column; align-items: stretch; }
  .cb-ant__search { max-width: none; }
  .cb-scope { display: none; }
}
