/* Demo HITL (PND-004 / PND-017 / PND-018) - Yujin Design System: Art Deco
   azul medianoche, oro/laton, marfil parchment, rojo laca y jade.
   geometria simetrica, dobles filetes dorados, titulos en versales. */

:root {
  /* grounds + tinta */
  --washi: #ece2c8;        /* parchment ground */
  --washi-claro: #f8f1de;  /* panel marfil */
  --sumi: #16223c;         /* azul medianoche (tinta / barras) */
  --sumi-suave: #44506b;   /* azul pizarra atenuado */

  /* acentos art deco */
  --bermellon: #8a2b22;        /* rojo laca (primario) */
  --bermellon-suave: #f0ddd4;
  --musgo: #1f5c4d;            /* jade (exito / aprobado) */
  --musgo-suave: #d8e6df;

  /* oro / laton: el marco gilt de todo el sistema */
  --oro: #b08d3a;
  --oro-claro: #d8b864;
  --oro-suave: #efe1bd;

  /* azul noche art deco: reemplaza el negro lacado en los fondos oscuros */
  --azul: #16223c;          /* azul noche (headers de tabla, log, avisos) */
  --azul-claro: #233456;    /* azul medio (degrade cabecera) */
  --azul-oscuro: #0e1626;   /* azul casi negro (sello) */

  --linea: #c7b485;        /* filete dorado fino */
  --sombra: 0 3px 14px rgba(27, 22, 16, .14);
  --serif: "Bodoni MT", Didot, "Playfair Display", Georgia, "Times New Roman", serif;
  --sans: "Century Gothic", "Segoe UI", system-ui, sans-serif;
}

* { box-sizing: border-box; }
body {
  margin: 0; background: var(--washi); color: var(--sumi);
  font-family: var(--sans); font-size: 15px; line-height: 1.45;
  /* celosia de rombos dorados (motivo art deco) */
  background-image:
    repeating-linear-gradient(45deg, transparent 0 28px, rgba(176,141,58,.06) 28px 29px),
    repeating-linear-gradient(-45deg, transparent 0 28px, rgba(176,141,58,.06) 28px 29px);
}

.cabecera {
  display: flex; align-items: center; gap: 18px;
  padding: 26px 36px 18px;
  background: linear-gradient(180deg, #101a30, #1b2944);
  color: var(--washi-claro);
  border-top: 3px solid var(--oro);
  border-bottom: 3px solid var(--oro);
  box-shadow: inset 0 0 0 1px rgba(216,184,100,.25), var(--sombra);
}
.sello {
  width: 54px; height: 54px; border-radius: 3px;
  background: #0d1526; color: var(--oro-claro);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-family: var(--serif);
  border: 2px solid var(--oro); box-shadow: inset 0 0 0 3px #0d1526, 0 0 0 1px var(--oro-claro);
}
.sello svg { width: 30px; height: 30px; display: block; }
.cabecera h1 {
  margin: 0; font-family: var(--serif); font-size: 27px;
  letter-spacing: 4px; text-transform: uppercase; color: var(--oro-claro);
}
.cabecera .sub { margin: 4px 0 0; color: #c9bfa6; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; }

.barra-acciones {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 16px 36px 0;
}
.barra-acciones .boton { padding: 8px 18px; font-size: 14px; }
.barra-acciones .boton.peligro { margin-left: auto; }
.estado-robot { color: var(--sumi-suave); font-size: 13px; font-style: italic; }
.estado-robot.activo { color: var(--bermellon); font-style: normal; }
.log-robot {
  margin: 12px 36px 0; padding: 12px 16px; max-height: 200px; overflow: auto;
  background: var(--azul); color: var(--oro-suave); border-radius: 3px;
  font-size: 12px; line-height: 1.5; box-shadow: var(--sombra);
  border: 1px solid var(--oro); border-left: 4px solid var(--oro-claro); white-space: pre-wrap;
}

.tarjetas { display: flex; gap: 16px; padding: 22px 36px 6px; flex-wrap: wrap; }
.tarjeta {
  flex: 1 1 220px; max-width: 320px; text-align: left; cursor: pointer;
  background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px;
  padding: 14px 18px; box-shadow: inset 0 0 0 1px rgba(176,141,58,.3), var(--sombra);
  display: grid; grid-template-columns: 44px 1fr; grid-template-rows: auto auto;
  column-gap: 12px; align-items: center; transition: transform .12s, box-shadow .12s;
  font-family: var(--sans); color: var(--sumi);
}
.tarjeta:hover { transform: translateY(-2px); box-shadow: inset 0 0 0 1px var(--oro-claro), 0 6px 18px rgba(27,22,16,.2); }
.tarjeta.activa { border-color: var(--bermellon); box-shadow: inset 0 0 0 2px var(--bermellon), var(--sombra); }
.tarjeta .kanji {
  grid-row: span 2; color: var(--bermellon);
  display: flex; align-items: center; justify-content: center;
}
.tarjeta .kanji svg { width: 34px; height: 34px; display: block; }
.tarjeta.activa .kanji { color: var(--bermellon); }
.tarjeta strong { font-size: 16px; font-family: var(--serif); letter-spacing: .5px; }
.tarjeta small { color: var(--sumi-suave); }

main { padding: 18px 36px 40px; }
.vista.oculta, .oculta { display: none !important; }
.leyenda { color: var(--sumi-suave); font-size: 13px; margin: 4px 0 14px; }

#vista-tablas { display: flex; gap: 18px; align-items: flex-start; }
.lista-tablas { flex: 0 0 230px; display: flex; flex-direction: column; gap: 6px; }
.lista-tablas button {
  text-align: left; padding: 9px 12px; border-radius: 3px; cursor: pointer;
  background: transparent; border: 1px solid transparent; color: var(--sumi);
  font-family: var(--sans); font-size: 14px;
}
.lista-tablas button:hover { background: var(--washi-claro); }
.lista-tablas button.activa {
  background: var(--washi-claro); border-color: var(--oro);
  font-weight: 600; box-shadow: inset 3px 0 0 var(--bermellon);
}
.lista-tablas .conteo { color: var(--sumi-suave); font-size: 12px; float: right; }

.panel-grilla { flex: 1; min-width: 0; }
.encabezado-grilla { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.encabezado-grilla h2 { margin: 0; font-family: var(--serif); font-size: 21px; letter-spacing: 1.5px; text-transform: uppercase; }
.grilla-acciones { display: flex; gap: 8px; align-items: center; }

/* fila de filtros por columna (vistas de tabla) */
table.grilla tr.fila-filtro td {
  position: sticky; top: 33px; z-index: 2;
  background: var(--washi); padding: 4px 6px; border-bottom: 1px solid var(--oro);
}
.filtro-col {
  width: 100%; min-width: 70px; border: 1px solid var(--linea); border-radius: 3px;
  padding: 3px 6px; font: inherit; font-size: 12px; background: #fff; color: var(--sumi);
}
.filtro-col:focus { outline: none; border-color: var(--bermellon); }

.envoltorio-grilla {
  overflow: auto; background: var(--washi-claro); border: 1px solid var(--oro);
  border-radius: 4px; box-shadow: inset 0 0 0 1px rgba(176,141,58,.25), var(--sombra); max-height: 62vh;
}
table.grilla { border-collapse: collapse; width: 100%; font-size: 13px; }
table.grilla th {
  position: sticky; top: 0; background: var(--azul); color: var(--oro-claro);
  padding: 8px 10px; text-align: left; font-weight: 600; white-space: nowrap;
  text-transform: uppercase; letter-spacing: .8px; font-size: 12px;
  border-bottom: 2px solid var(--oro);
}
table.grilla td { border-bottom: 1px solid var(--linea); padding: 5px 8px; vertical-align: top; }
table.grilla tr:hover td { background: rgba(176,141,58,.08); }
table.grilla input {
  width: 100%; min-width: 90px; border: 1px solid transparent; border-radius: 3px;
  background: transparent; font: inherit; color: inherit; padding: 3px 5px;
}
table.grilla input:focus { background: #fff; border-color: var(--bermellon); outline: none; }

.boton {
  border: 1px solid var(--oro); background: var(--washi-claro); color: var(--sumi);
  border-radius: 3px; padding: 6px 14px; cursor: pointer; font: inherit; font-size: 13px;
  transition: border-color .12s, box-shadow .12s, background .12s;
}
.boton:hover { border-color: var(--oro-claro); box-shadow: inset 0 0 0 1px var(--oro-claro); }
.boton.primario {
  background: var(--bermellon); border-color: var(--oro); color: var(--washi-claro);
  text-transform: uppercase; letter-spacing: 1px; font-size: 12px;
  box-shadow: inset 0 0 0 1px rgba(216,184,100,.4);
}
.boton.primario:hover { filter: brightness(1.08); box-shadow: inset 0 0 0 1px var(--oro-claro); }
.boton.sutil { font-size: 12px; padding: 4px 10px; }
.boton.peligro:hover { border-color: var(--bermellon); color: var(--bermellon); }
.boton:disabled { opacity: .42; cursor: default; box-shadow: none; }

/* consulta: tarjeta por afiliado */
.orden-card {
  background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px;
  box-shadow: inset 0 0 0 1px rgba(176,141,58,.28), var(--sombra); margin-bottom: 18px; overflow: hidden;
}
.orden-cabecera {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  padding: 12px 18px;
  background: linear-gradient(180deg, #16223c, #233456);
  color: var(--washi-claro);
  border-bottom: 2px solid var(--oro);
}
.orden-cabecera h3 { margin: 0; font-family: var(--serif); font-size: 19px; color: var(--oro-claro); letter-spacing: 1px; text-transform: uppercase; }
.orden-cabecera .espacio { flex: 1; }
.sub-orden { color: #c9bfa6; font-size: 13px; }

.chip {
  font-size: 11px; padding: 3px 10px; border-radius: 2px; white-space: nowrap;
  border: 1px solid var(--linea); color: var(--sumi-suave); background: var(--washi);
  text-transform: uppercase; letter-spacing: .5px;
}
.chip.pendiente { background: var(--oro-suave); border-color: var(--oro); color: #7a5b14; }
.chip.aprobada { background: var(--musgo-suave); border-color: var(--musgo); color: var(--musgo); }
.chip.no-vigente { background: var(--bermellon-suave); border-color: var(--bermellon); color: var(--bermellon); }
.chip.rechazada { background: #efe4e2; border-color: var(--bermellon); color: var(--bermellon); text-decoration: line-through; }
.chip.solo-excel { background: #e8e4f0; border-color: #8d7fb0; color: #574a78; }
.chip.anulada { background: #e6e2da; border-color: #9a9486; color: #6a6458; text-decoration: line-through; }
.chip.auth { background: #e3edf2; border-color: #6b93a8; color: #37606f; }

/* dos columnas IZEN (izq) / OSDE (der) */
.afiliado-cols { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; padding: 14px 16px; }
@media (max-width: 880px) { .afiliado-cols { grid-template-columns: 1fr; } }
.col-lado { min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.col-lado-titulo {
  margin: 0 0 2px; font-family: var(--serif); font-size: 14px;
  text-transform: uppercase; letter-spacing: 1.5px;
  border-bottom: 3px double var(--oro); padding-bottom: 4px;
}
.col-izen .col-lado-titulo { color: var(--musgo); border-color: var(--musgo); }
.col-osde .col-lado-titulo { color: var(--bermellon); border-color: var(--bermellon); }

.izen-card, .osde-card {
  background: var(--washi); border: 1px solid var(--linea); border-radius: 3px;
  padding: 8px 12px; box-shadow: var(--sombra);
}
.izen-card { border-left: 4px solid var(--musgo); position: relative; z-index: 2; }
.osde-card { border-left: 4px solid var(--bermellon); position: relative; z-index: 2; }
.osde-card.asociada { box-shadow: 0 0 0 2px var(--musgo) inset, var(--sombra); }
.osde-card.armada { box-shadow: 0 0 0 2px var(--bermellon) inset, var(--sombra); background: var(--bermellon-suave); }
.afiliado-cols.conectando .izen-card { cursor: pointer; border-style: dashed; }
.afiliado-cols.conectando .izen-card:hover { border-color: var(--bermellon); background: var(--bermellon-suave); }

.mini-titulo { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
.mini-titulo strong { font-family: var(--serif); font-size: 14px; letter-spacing: .5px; }
/* datos en flujo horizontal: cada par "etiqueta: valor" se acomoda al lado del
   otro y envuelve, asi cada orden/tratamiento ocupa pocas lineas y entran todas
   las ordenes del afiliado de un pantallazo (PND-016) */
.mini-datos { display: flex; flex-wrap: wrap; gap: 2px 14px; }
.mini-fila { display: inline-flex; align-items: baseline; gap: 5px; font-size: 12px; }
.mini-k { color: var(--oro); flex: 0 0 auto; font-size: 10.5px; text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.mini-k::after { content: ":"; }
.mini-v { color: var(--sumi); font-weight: 500; min-width: 0; word-break: break-word; }
/* campo seleccionado pero sin valor (PND-022): se muestra para que se note el vacio */
.mini-v.sin-valor, .prestacion-linea.sin-valor { color: var(--bermellon); font-style: italic; font-weight: 500; }
.chip.chip-sin { background: var(--bermellon-suave); border-color: var(--bermellon); color: var(--bermellon); font-style: italic; }
.mini-subtitulo { margin-top: 6px; font-size: 11px; font-weight: 600; color: var(--sumi-suave); text-transform: uppercase; letter-spacing: .5px; }
.prestaciones { margin-top: 4px; border-top: 1px dashed var(--oro); padding-top: 5px; }
.prestacion-linea { font-size: 12px; padding: 1px 0; }
.prestacion-fechahasta { display: flex; align-items: baseline; gap: 6px; margin-top: 3px; font-size: 12px; }
.prestacion-fechahasta .fh-k { color: var(--oro); font-size: 10.5px; text-transform: uppercase; letter-spacing: .5px; font-weight: 700; }
.prestacion-fechahasta .fh-v { font-weight: 700; color: var(--sumi); }
.prestacion-fechahasta .fh-sin { color: var(--bermellon); font-style: italic; }
.osde-pie { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.asociada-chip { background: var(--musgo-suave); border-color: var(--musgo); color: var(--musgo); }

td.vacio { color: #b3a98f; font-style: italic; }

.pie {
  text-align: center; color: var(--sumi-suave); font-family: var(--serif);
  font-style: italic; font-size: 13px; padding: 10px 0 26px;
}

.aviso {
  position: fixed; right: 24px; bottom: 24px; max-width: 380px;
  background: var(--azul); color: var(--washi-claro);
  padding: 12px 18px; border-radius: 3px; box-shadow: var(--sombra); font-size: 14px;
  border: 1px solid var(--oro); border-left: 4px solid var(--oro-claro);
}

/* vault de credenciales (card Configuracion) */
.vault-grupos { display: flex; flex-direction: column; gap: 26px; max-width: 700px; }
.vault-grupo {
  background: var(--washi-claro); border: 1px solid var(--oro);
  border-radius: 4px; padding: 22px 26px; box-shadow: inset 0 0 0 1px rgba(176,141,58,.25), var(--sombra);
}
.vault-grupo-titulo { margin: 0 0 18px; font-family: var(--serif); font-size: 19px; text-transform: uppercase; letter-spacing: 1.5px; }
.vault-campo { margin-bottom: 18px; }
.vault-campo label {
  display: block; font-size: 13px; font-weight: 600;
  color: var(--sumi-suave); margin-bottom: 5px;
}
.vault-campo input[type=text],
.vault-campo input[type=password],
.vault-campo input[type=url],
.vault-campo textarea {
  width: 100%; border: 1px solid var(--linea); border-radius: 3px;
  padding: 8px 12px; font: inherit; background: var(--washi);
  color: var(--sumi); resize: vertical;
}
.vault-campo input:focus, .vault-campo textarea:focus {
  outline: none; border-color: var(--bermellon); background: #fff;
}
.vault-chip { display: inline-block; margin-bottom: 5px; }
.vault-configurado { background: var(--musgo-suave); border-color: var(--musgo); color: var(--musgo); }
.vault-vacio { background: var(--bermellon-suave); border-color: var(--bermellon); color: var(--bermellon); }
.vault-fecha { display: block; font-size: 11px; color: var(--sumi-suave); margin-bottom: 5px; }
.vault-btn-guardar { margin-top: 4px; }

/* checkbox de seleccion por orden OSDE y por fila IZEN (aprobacion por tildado) */
.orden-check, .izen-check { width: 17px; height: 17px; margin: 0 2px 0 0; accent-color: var(--bermellon); cursor: pointer; flex: 0 0 auto; }

/* PND-079: el aviso de afiliados sin telefono se movio al buzon de Alertas
   (tipo 'afiliado_sin_telefono'); ya no se pinta como banner en Consulta. */

/* auditoria (solo lectura con buscador) */
.auditoria-busqueda { margin: 0 0 16px; }
.auditoria-busqueda input {
  width: 100%; max-width: 480px; padding: 9px 13px; font-size: 14px;
  border: 1px solid var(--oro); border-radius: 4px; background: var(--washi-claro);
}
.auditoria-bloque { margin: 0 0 26px; }
.auditoria-titulo {
  font-family: var(--serif); font-size: 16px; text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--sumi); border-bottom: 2px solid var(--oro); padding-bottom: 5px; margin: 0 0 10px;
}

/* configuracion de la consulta (campos visibles + filtros) en pestana Config */
.config-seccion-titulo {
  font-family: var(--serif); font-size: 18px; text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--sumi); border-bottom: 2px solid var(--oro); padding-bottom: 6px;
  margin: 28px 0 4px;
}
.config-seccion-titulo:first-child { margin-top: 4px; }
/* sub-secciones dentro de un formulario de configuracion (WhatsApp) */
.config-subseccion {
  font-family: var(--serif); font-size: 14px; text-transform: uppercase; letter-spacing: 1px;
  color: var(--musgo); margin: 20px 0 8px; padding-bottom: 4px;
  border-bottom: 1px solid var(--oro);
}
.form-config { max-width: 760px; }
.config-consulta {
  background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px;
  box-shadow: inset 0 0 0 1px rgba(176,141,58,.3), var(--sombra);
  padding: 18px 22px; margin: 0 0 8px; max-width: 760px;
  display: flex; flex-direction: column; gap: 18px;
}
.config-bloque-titulo { margin: 0; font-family: var(--serif); font-size: 15px; text-transform: uppercase; letter-spacing: 1px; }
.config-cols { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 22px; }
@media (max-width: 720px) { .config-cols { grid-template-columns: 1fr; } }
.config-grupo { display: flex; flex-direction: column; gap: 7px; }
.config-grupo strong { font-size: 12.5px; color: var(--sumi-suave); border-bottom: 2px solid var(--oro); padding-bottom: 5px; text-transform: uppercase; letter-spacing: .5px; }
.config-item { display: flex; align-items: center; gap: 8px; font-size: 13px; cursor: pointer; }
.config-item input { accent-color: var(--bermellon); }
.config-filtros { gap: 6px; }
.config-item-filtro { display: block; font-size: 12.5px; color: var(--sumi-suave); cursor: default; margin-top: 4px; }
.filtro-logico {
  width: 100%; max-width: 420px;
  border: 1px solid var(--linea); border-radius: 3px; padding: 6px 10px;
  font: inherit; font-size: 12.5px; background: #fff; color: var(--sumi);
}
.filtro-logico::placeholder { color: #a99f86; font-style: italic; }
.filtro-logico:focus { outline: none; border-color: var(--bermellon); }

/* ---- acceso (login dummy, PND-041) ---------------------------------------- */
body.sin-acceso { overflow: hidden; }

.login-overlay {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center; padding: 24px;
  background-color: #0e1626;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 28px, rgba(176,141,58,.10) 28px 29px),
    repeating-linear-gradient(-45deg, transparent 0 28px, rgba(176,141,58,.10) 28px 29px),
    radial-gradient(120% 120% at 50% 0%, rgba(35,52,86,.92), rgba(14,22,38,.97));
}
.login-tarjeta {
  width: 100%; max-width: 380px; text-align: center;
  background: var(--washi-claro); color: var(--sumi);
  border: 1px solid var(--oro); border-top: 3px solid var(--oro); border-bottom: 3px solid var(--oro);
  border-radius: 5px; padding: 30px 32px 24px;
  box-shadow: inset 0 0 0 1px rgba(176,141,58,.3), 0 18px 50px rgba(8,12,22,.5);
}
.login-sello {
  width: 56px; height: 56px; margin: 0 auto 14px; border-radius: 3px;
  background: #0d1526; color: var(--oro-claro);
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--oro); box-shadow: inset 0 0 0 3px #0d1526, 0 0 0 1px var(--oro-claro);
}
.login-sello svg { width: 30px; height: 30px; display: block; }
.login-tarjeta h2 {
  margin: 0; font-family: var(--serif); font-size: 22px;
  letter-spacing: 3px; text-transform: uppercase; color: var(--sumi);
}
.login-sub {
  margin: 4px 0 22px; font-size: 11.5px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--sumi-suave);
}
.login-campo { display: block; text-align: left; margin-bottom: 14px; }
.login-campo span {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--sumi-suave); margin-bottom: 5px;
  text-transform: uppercase; letter-spacing: .5px;
}
.login-campo input {
  width: 100%; border: 1px solid var(--linea); border-radius: 3px;
  padding: 9px 12px; font: inherit; background: var(--washi); color: var(--sumi);
}
.login-campo input:focus { outline: none; border-color: var(--bermellon); background: #fff; }
.login-boton { width: 100%; padding: 11px; margin-top: 4px; font-size: 13px; }
.login-nota { margin: 16px 0 0; font-size: 11.5px; line-height: 1.5; color: var(--sumi-suave); font-style: italic; }
.login-error {
  margin: 14px 0 0; padding: 9px 12px; font-size: 12.5px; line-height: 1.45; text-align: left;
  background: rgba(178,58,42,.08); border: 1px solid var(--bermellon);
  border-left: 4px solid var(--bermellon); border-radius: 3px; color: #7a2018;
}
.login-volver { width: 100%; margin-top: 8px; background: transparent; }

/* gateo por rol: solo el admin ve lo marcado solo-admin; el auditor (solo lectura)
   no ve lo marcado solo-operador. El backend igual lo refuerza con @requiere. */
body:not(.rol-admin) .solo-admin { display: none !important; }
body.rol-auditor .solo-operador { display: none !important; }

/* chip de usuario conectado (cabecera) */
.usuario-actual {
  margin-left: auto; display: flex; align-items: center; gap: 9px;
  background: rgba(13,21,38,.55); border: 1px solid var(--oro);
  border-radius: 3px; padding: 6px 8px 6px 12px;
}
.usuario-actual .usuario-icono { width: 20px; height: 20px; color: var(--oro-claro); flex: 0 0 auto; }
.usuario-actual .usuario-email {
  font-size: 13px; color: var(--washi-claro); letter-spacing: .3px;
  max-width: 240px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.usuario-actual .boton.sutil { background: transparent; color: var(--oro-claro); border-color: var(--oro); }
.usuario-actual .boton.sutil:hover { background: var(--oro); color: #0d1526; }
.usuario-actual .usuario-rol {
  font-size: 10px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  color: #0d1526; background: var(--oro-claro); border: 1px solid var(--oro);
  border-radius: 9px; padding: 2px 8px; flex: 0 0 auto;
}
.usuario-actual .usuario-rol.oculta { display: none; }
@media (max-width: 620px) { .usuario-actual .usuario-email { max-width: 120px; } }

/* ---- vista Usuarios (administracion, solo admin) -------------------------- */
.usuarios-alta {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 12px;
  background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px;
  padding: 14px 16px; margin-bottom: 16px;
}
.usuarios-alta .ua-campo { display: flex; flex-direction: column; gap: 4px; }
.usuarios-alta .ua-campo span {
  font-size: 11px; font-weight: 600; color: var(--sumi-suave);
  text-transform: uppercase; letter-spacing: .5px;
}
.usuarios-alta input, .usuarios-alta select {
  border: 1px solid var(--linea); border-radius: 3px; padding: 7px 10px;
  font: inherit; background: var(--washi); color: var(--sumi); min-width: 160px;
}
.usuarios-alta input:focus, .usuarios-alta select:focus { outline: none; border-color: var(--bermellon); background: #fff; }
#grilla-usuarios select { border: 1px solid var(--linea); border-radius: 3px; padding: 4px 6px; font: inherit; background: var(--washi); }
.usuario-estado { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
.usuario-estado.activo { color: #2c6e3f; }
.usuario-estado.inactivo { color: var(--bermellon); }
.usuario-acciones { display: flex; flex-wrap: wrap; gap: 6px; }
.usuario-yo { font-size: 10px; color: var(--oro); font-weight: 700; letter-spacing: .4px; }

/* ---- vista Alertas (buzon de avisos) -------------------------------------- */
.alertas-badge {
  display: inline-block; min-width: 18px; padding: 0 5px; margin-left: 6px;
  font-family: var(--serif); font-size: 11px; line-height: 17px; text-align: center;
  background: var(--bermellon); color: var(--washi-claro);
  border: 1px solid var(--oro); border-radius: 9px; vertical-align: middle;
}
.alertas-badge.oculta { display: none; }
.alertas-controles { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.alertas-filtro {
  padding: 6px 8px; background: var(--washi-claro); color: var(--sumi);
  border: 1px solid var(--oro); border-radius: 4px; font-size: 13px;
}
.alerta-card {
  background: var(--washi-claro); border: 1px solid var(--oro); border-left: 4px solid var(--oro);
  border-radius: 4px; padding: 12px 14px; margin-bottom: 10px;
}
.alerta-card.nueva { border-left-color: var(--bermellon); box-shadow: inset 0 0 0 1px var(--oro-suave); }
.alerta-cabecera { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.alerta-cabecera strong { font-family: var(--serif); color: var(--oro-claro); letter-spacing: .5px; }
.alerta-mensaje { margin: 4px 0; color: var(--sumi); }
.alerta-detalle { margin: 2px 0 6px; font-size: 13px; color: #5a5346; }
.alerta-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.alerta-acciones { margin-top: 10px; }
.chip.chip-alerta { background: var(--bermellon-suave); border-color: var(--bermellon); color: var(--bermellon); }
.chip.chip-tenue { background: var(--washi); border-color: var(--oro); color: #6a6458; }

/* contactos responsables en la card Consulta (PND-083) */
.responsables {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 8px 18px; border-bottom: 1px dashed var(--oro); background: var(--washi);
}
.responsables-titulo {
  font-size: 11px; font-weight: 600; color: var(--sumi-suave);
  text-transform: uppercase; letter-spacing: .5px;
}
.chip.chip-contacto {
  text-transform: none; letter-spacing: 0; white-space: normal;
  background: var(--washi-claro); border-color: var(--oro); color: var(--sumi);
}

/* ---- configuracion de email del sistema (PND-078) ------------------------- */
.email-config { max-width: 640px; }
.email-cabecera { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.email-campo { display: flex; flex-direction: column; gap: 4px; margin-bottom: 10px; }
.email-campo > label { font-size: 13px; color: var(--oro-claro); font-family: var(--serif); letter-spacing: .3px; }
.email-campo input[type="text"], .email-campo input[type="email"],
.email-campo input[type="password"], .email-campo input[type="number"] {
  padding: 7px 9px; background: var(--washi-claro); color: var(--sumi);
  border: 1px solid var(--oro); border-radius: 4px; font-size: 13px;
}
.email-campo-check { flex-direction: row; }
.email-campo-check .config-item { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--sumi); }
.email-autoconfig { margin: 2px 0 10px; }
.email-acciones { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.email-nota, .email-resultado { margin: 6px 0; }
.email-nota.oculta, .email-resultado.oculta { display: none; }
.email-ok { color: #2f7d4f; font-weight: 600; }
.email-error { color: var(--bermellon); font-weight: 600; }

/* ===== Navegacion de dos niveles (PND-089) ================================
   Barra de secciones (Sistemas/Datos/Consultas) + modales lanzadores +
   miga de pan. Reutiliza el look de .tarjeta del Design System. */

.grupos { display: flex; gap: 16px; padding: 22px 36px 6px; flex-wrap: wrap; }
.grupo {
  flex: 1 1 240px; max-width: 360px; text-align: left; cursor: pointer;
  background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px;
  padding: 16px 20px; box-shadow: inset 0 0 0 1px rgba(176,141,58,.3), var(--sombra);
  display: grid; grid-template-columns: 48px 1fr; grid-template-rows: auto auto;
  column-gap: 14px; align-items: center; transition: transform .12s, box-shadow .12s;
  font-family: var(--sans); color: var(--sumi);
}
.grupo:hover { transform: translateY(-2px); box-shadow: inset 0 0 0 1px var(--oro-claro), 0 6px 18px rgba(27,22,16,.2); }
.grupo.activo { border-color: var(--bermellon); box-shadow: inset 0 0 0 2px var(--bermellon), var(--sombra); }
.grupo-kanji { grid-row: span 2; color: var(--bermellon); display: flex; align-items: center; justify-content: center; }
.grupo-kanji svg { width: 38px; height: 38px; display: block; }
.grupo strong { font-size: 18px; font-family: var(--serif); letter-spacing: 1px; text-transform: uppercase; }
.grupo small { color: var(--sumi-suave); }

.miga { display: flex; align-items: center; gap: 12px; padding: 14px 36px 0; }
.miga-rotulo { font-family: var(--serif); letter-spacing: 1px; text-transform: uppercase; color: var(--sumi-suave); font-size: 14px; }

/* modales lanzadores (Sistemas / Datos) */
.modal-grupo { position: fixed; inset: 0; z-index: 60; display: flex; align-items: flex-start; justify-content: center; padding: 60px 20px; overflow: auto; }
.modal-grupo .modal-fondo { position: absolute; inset: 0; background: rgba(14,22,38,.55); backdrop-filter: blur(2px); }
.modal-grupo-tarjeta {
  position: relative; z-index: 1; width: min(960px, 100%);
  background: var(--washi); border: 3px solid var(--oro); border-radius: 6px;
  box-shadow: inset 0 0 0 1px var(--oro-claro), 0 18px 50px rgba(14,22,38,.45);
  padding: 22px 26px 28px;
}
.modal-grupo-cab { display: flex; align-items: center; justify-content: space-between; border-bottom: 2px solid var(--linea); padding-bottom: 12px; margin-bottom: 18px; }
.modal-grupo-cab h2 { margin: 0; font-family: var(--serif); letter-spacing: 2px; text-transform: uppercase; color: var(--sumi); font-size: 22px; }
.lanzador-cards { display: flex; gap: 16px; flex-wrap: wrap; }
.lanzador-cards .tarjeta { flex: 1 1 240px; max-width: 300px; }
body.modal-abierto { overflow: hidden; }

/* tarjetas reservadas para el componente de Forge 2 (deshabilitadas) */
.tarjeta-forge2 { opacity: .6; cursor: not-allowed; border-style: dashed; }
.tarjeta-forge2:hover { transform: none; box-shadow: inset 0 0 0 1px rgba(176,141,58,.3), var(--sombra); }
.tarjeta-forge2 .kanji { color: var(--sumi-suave); }
.forge2-rotulo { color: var(--bermellon); font-style: italic; }

/* ===== Pantalla Orquestador (PND-089) ===================================== */
.orq-cab { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin: 4px 0 18px; }
.orq-estado { font-family: var(--serif); letter-spacing: .5px; font-size: 15px; padding: 6px 12px; border-radius: 4px; border: 1px solid var(--oro); }
.orq-estado.on { color: var(--musgo); background: var(--musgo-suave); }
.orq-estado.off { color: var(--bermellon); background: var(--bermellon-suave); }

.orq-prog {
  background: var(--washi-claro); border: 1px solid var(--oro); border-left: 4px solid var(--oro-claro);
  border-radius: 4px; padding: 12px 16px; margin-bottom: 12px; box-shadow: var(--sombra);
}
.orq-prog.inactiva { opacity: .62; border-left-color: var(--sumi-suave); }
.orq-prog-cab { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.orq-prog-cab strong { font-family: var(--serif); font-size: 16px; letter-spacing: .5px; }
.orq-cron { background: var(--azul); color: var(--oro-suave); padding: 2px 8px; border-radius: 3px; font-size: 12px; letter-spacing: .5px; }
.orq-cron-humano { margin: 6px 0 2px; color: var(--sumi); font-size: 13px; }
.orq-prog-edit, .orq-form-fila { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 10px; }
.orq-prog-edit input[type="text"], .orq-form input[type="text"], .orq-form input[type="number"], .orq-form select {
  padding: 7px 9px; background: var(--washi-claro); color: var(--sumi);
  border: 1px solid var(--oro); border-radius: 4px; font-size: 13px; font-family: var(--sans);
}
.orq-cron-input { font-family: "Consolas", "Courier New", monospace; min-width: 180px; }
.orq-check { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--sumi); }
.orq-form { background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px; padding: 14px 16px; box-shadow: var(--sombra); }
.orq-form .boton { margin-top: 10px; }

.orq-badge { padding: 2px 8px; border-radius: 3px; font-size: 12px; letter-spacing: .3px; border: 1px solid var(--oro); }
.orq-badge.orq-corriendo { color: var(--bermellon); background: var(--bermellon-suave); }
.orq-badge.orq-ok { color: var(--musgo); background: var(--musgo-suave); }
.orq-badge.orq-error { color: #fff; background: var(--bermellon); border-color: var(--bermellon); }
.orq-badge.orq-interrumpida, .orq-badge.orq-cancelada { color: var(--sumi-suave); background: var(--oro-suave); }

/* Task Manager (PND-139) */
#procesos-tabla { margin-top: 12px; }
.usuario-acciones { display: flex; flex-wrap: wrap; gap: 6px; }
.usuario-acciones .boton { padding: 4px 10px; font-size: 12px; }

/* Paginacion de pantalla (PND-130) */
.paginacion {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin: 12px 0 4px; padding: 8px 12px;
  background: var(--washi-claro); border: 1px solid var(--oro); border-radius: 4px;
}
.paginacion .pag-info { font-size: 13px; color: var(--sumi); font-family: var(--sans); }
.paginacion .pag-sep { flex: 1 1 auto; }
.paginacion .pag-tam {
  padding: 6px 8px; background: var(--washi-claro); color: var(--sumi);
  border: 1px solid var(--oro); border-radius: 4px; font-size: 13px; font-family: var(--sans);
}
.paginacion .boton[disabled] { opacity: .4; cursor: default; }
