/* Piloto P0 — estilos. Paleta de la app principal (teal #006c84) para sentirlo familiar. */

:root {
  color-scheme: light;
  --bg: #edf1f4;
  --surface: #ffffff;
  --soft: #f6f9fa;
  --text: #17212b;
  --muted: #5c6874;
  --border: #d6dde2;
  --accent: #006c84;
  --accent-soft: #e1f0f4;
  --accent-contrast: #ffffff;
  --warn-bg: #fdf3d6;
  --warn-fg: #8a6d10;
  --warn-border: #e0c25a;
  --mark: #ffe9a8;
  --flash: #d2ecf3;
  --danger: #a3271c;
  --danger-bg: #fdecea;
  --danger-border: #e3b4ae;
}

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
    --bg: #10181d;
    --surface: #1a242c;
    --soft: #202c35;
    --text: #e2e9ee;
    --muted: #93a5b1;
    --border: #2e3d48;
    --accent: #2da7c4;
    --accent-soft: #15333d;
    --accent-contrast: #06222b;
    --warn-bg: #4a3c12;
    --warn-fg: #e6c96b;
    --warn-border: #6b5614;
    --mark: #6b5614;
    --flash: #1d4350;
    --danger: #f3b0a6;
    --danger-bg: #3a1d19;
    --danger-border: #643a32;
  }
}

/* El atributo `hidden` SIEMPRE oculta, aunque otra regla fije display (p.ej. .form-back{display:flex}
   o #ia-cuerpo{display:grid} ganarían al [hidden] del navegador). Evita modales/paneles fantasma. */
[hidden] { display: none !important; }

* { box-sizing: border-box; }

/* tamaño de letra GLOBAL ajustable (accesibilidad): escala todo lo medido en rem */
html { font-size: calc(16px * var(--font-scale, 1)); }

body {
  margin: 0;
  font-family: Inter, "Segoe UI", system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
}

kbd {
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--soft);
  padding: 0 5px;
  font-size: 0.78em;
}

.top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}

.top h1 { margin: 0; font-size: 1.15rem; }
.top .sub { margin: 3px 0 0; font-size: 0.8rem; color: var(--muted); }

.cron {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--accent);
  white-space: nowrap;
}

.cols {
  display: grid;
  grid-template-columns: minmax(330px, 420px) minmax(0, 1fr);
  gap: 18px;
  padding: 18px 22px;
  align-items: start;
}

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

/* ------------------------------------------------ panel izquierdo (captura) */

.lbl {
  margin: 0 0 8px;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.picker-lista { display: grid; gap: 10px; }
.picker-mod { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); margin-top: 6px; }
.picker-mod:first-child { margin-top: 0; }
/* modalidad-bar de la captura (resetea el padding de la .modbar del catálogo) */
#cap-modbar.modbar { padding: 0 0 10px; }
/* galería de hallazgos del estudio (captura), tipo tarjetas como el catálogo */
#cap-galeria { margin-top: 14px; }
.cap-galeria-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(165px, 1fr)); gap: 8px; margin: 4px 0 6px; }
.cap-gcard { text-align: left; display: grid; gap: 3px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface); color: var(--text); cursor: pointer; font: inherit; }
.cap-gcard:hover { border-color: var(--accent); background: var(--accent-soft); }
.cap-gcard small { color: var(--muted); font-size: 0.78rem; }
.cap-gcard .badge.tag { justify-self: start; }
.cap-gcard.aplicado { opacity: 0.45; cursor: default; }

.picker-btn {
  display: grid;
  gap: 3px;
  text-align: left;
  padding: 14px 16px;
  font: inherit;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
}

.picker-btn:hover { border-color: var(--accent); background: var(--accent-soft); }
.picker-btn small { color: var(--muted); }

.est-actual {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  font-weight: 700;
}

#buscar {
  width: 100%;
  font: inherit;
  font-size: 1.02rem;
  padding: 11px 14px;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  outline: none;
}

#buscar:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

#resultados {
  margin-top: 6px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  overflow: hidden;
}

.res {
  display: grid;
  gap: 1px;
  padding: 9px 13px;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
}

.res:last-child { border-bottom: none; }
.res:hover, .res.sel { background: var(--accent-soft); }
.res small { color: var(--muted); }
.res.crear strong { color: var(--accent); }

/* datos generales del estudio (taxonomía obligatoria) */
.generales-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 11px 13px;
  margin: 12px 0 14px;
}
.generales-box .lbl { margin: 0 0 4px; }
.det.oblig > label::after { content: " *"; color: var(--accent); font-weight: 700; }
.grp.dim3 input[type="number"] { width: 56px; }
.grp.dim3 .x { color: var(--muted); font-size: 0.85rem; }

#aplicados { display: grid; gap: 10px; margin-top: 14px; }

.dx-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 11px 13px;
}

.dx-card.nuevo { border-left: 3px solid var(--accent); }
/* sub-hallazgos (refinamiento aditivo) */
.dx-refinar { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 8px; }
.dx-refinar-lbl { font-size: 0.78rem; color: var(--muted); }
.dx-card .dx-hijo { margin-top: 10px; border-left: 2px solid var(--accent); background: var(--soft); }

.dx-head {
  display: flex;
  align-items: center;
  gap: 8px;
}

.dx-head strong { flex: 1; }

.badge {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: 99px;
  padding: 2px 8px;
}

.quitar {
  border: none;
  background: none;
  color: var(--muted);
  font-size: 1rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 6px;
}

.quitar:hover { color: #c0392b; background: var(--soft); }

.det {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 9px;
}

.det > label {
  min-width: 110px;
  font-size: 0.8rem;
  color: var(--muted);
}

.grp { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.chip {
  font: inherit;
  font-size: 0.86rem;
  padding: 5px 12px;
  border: 1px solid var(--border);
  border-radius: 99px;
  background: var(--soft);
  color: var(--text);
  cursor: pointer;
}

.chip:hover { border-color: var(--accent); }
.chip:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.chip.on { background: var(--accent); border-color: var(--accent); color: var(--accent-contrast); font-weight: 700; }

.det input[type="number"], .det input[type="text"] {
  font: inherit;
  width: 90px;
  padding: 5px 9px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
}

.det input[type="text"] { width: 100%; }
.det input:focus { border-color: var(--accent); outline: none; }
.unidad { color: var(--muted); font-size: 0.85rem; }

/* formulario de crear (flujo C) */
#crear {
  margin-top: 14px;
  padding: 13px 14px;
  background: var(--surface);
  border: 1px dashed var(--accent);
  border-radius: 10px;
  display: grid;
  gap: 10px;
}

#crear label { display: grid; gap: 4px; font-size: 0.8rem; color: var(--muted); }

#crear input, #crear select, #crear textarea {
  font: inherit;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  width: 100%;
}

#crear .dos { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
#crear .acciones { display: flex; justify-content: flex-end; gap: 8px; }

/* botones */
.primario, .ghost {
  font: inherit;
  font-weight: 700;
  padding: 9px 16px;
  border-radius: 8px;
  cursor: pointer;
}

.primario { background: var(--accent); border: 1px solid var(--accent); color: var(--accent-contrast); }
.primario:hover { filter: brightness(1.08); }
.ghost { background: none; border: 1px solid transparent; color: var(--accent); }
.ghost:hover { background: var(--accent-soft); border-color: var(--border); }

/* ------------------------------------------------ panel derecho (la hoja) */

.hoja {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 30px 36px;
  min-height: 420px;
  box-shadow: 0 2px 10px rgba(10, 30, 40, 0.06);
  line-height: 1.55;
}

.hoja h2 { margin: 0 0 14px; font-size: 1.05rem; letter-spacing: 0.04em; }

.hoja h3 {
  margin: 16px 0 5px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
}

.hoja p { margin: 0 0 7px; }
.hoja ul { margin: 0; padding-left: 20px; }
.hoja li { margin-bottom: 3px; }

/* párrafo distinto del normal (lo tocó un diagnóstico) */
.hoja p.mod { border-left: 3px solid var(--accent); padding-left: 10px; }

.hoja mark { background: var(--mark); border-radius: 3px; padding: 0 3px; font-weight: 700; }

.hoja p.flash { animation: flashbg 0.8s ease-out; }
@keyframes flashbg { 0% { background: var(--flash); } 100% { background: transparent; } }

.vacio { color: var(--muted); text-align: center; margin-top: 150px; }

.pie {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 12px;
}

/* ------------------------------------------------ tour guiado */

#tour-fab {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 60;
  font: inherit;
  font-weight: 700;
  padding: 11px 16px;
  border: none;
  border-radius: 99px;
  background: var(--accent);
  color: var(--accent-contrast);
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 60, 75, 0.3);
}

#tour-fab:hover { filter: brightness(1.08); }

/* "Spotlight": una caja con sombra gigante que oscurece todo lo demás. */
#tour-dim {
  position: fixed;
  z-index: 70;
  border-radius: 10px;
  box-shadow: 0 0 0 9999px rgba(10, 22, 30, 0.62);
  pointer-events: none;
  transition: all 0.25s ease;
}

#tour-cap {
  position: fixed;
  z-index: 71;
  width: min(360px, 92vw);
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 15px 17px;
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.3);
  transition: top 0.25s ease, left 0.25s ease;
}

#tour-cap h4 { margin: 0 0 6px; font-size: 1rem; color: var(--accent); }
#tour-cap p { margin: 0 0 12px; font-size: 0.9rem; line-height: 1.5; }
#tour-cap code { background: var(--soft); border-radius: 4px; padding: 0 4px; font-size: 0.85em; }

.tour-nav { display: flex; align-items: center; gap: 8px; }
.tour-nav #tour-n { margin-right: auto; font-size: 0.78rem; color: var(--muted); }

.tour-b {
  font: inherit;
  font-size: 0.84rem;
  font-weight: 700;
  padding: 7px 13px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
}

.tour-b.prim { background: var(--accent); border-color: var(--accent); color: var(--accent-contrast); }
.tour-b:disabled { opacity: 0.5; cursor: default; }

/* ------------------------------------------------ catálogo y editor */

.top-acc { display: flex; align-items: center; gap: 14px; }
/* barra de modalidad (nivel 1) sobre los chips de estudio (nivel 2) */
.modbar { display: flex; flex-wrap: wrap; gap: 8px; padding: 14px 22px 12px; border-bottom: 1px solid var(--border); }
.modbar .chip.mod { font-weight: 700; }
.cat-chips { display: flex; flex-wrap: wrap; gap: 8px; padding: 12px 22px 0; }

.cat-cols {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 18px;
  padding: 16px 22px;
  align-items: start;
}
@media (max-width: 900px) { .cat-cols { grid-template-columns: 1fr; } }

.cat-izq #buscar { width: 100%; margin-bottom: 8px; }
.cat-lista { display: grid; gap: 10px; }
.cat-grupo { margin: 8px 0 0; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.cat-grupo:first-child { margin-top: 0; }
.badge.clase { background: var(--accent-soft); color: var(--accent); }
.badge.sub { background: var(--soft); color: var(--muted); }

/* selector de archivos del estudio (formato carpeta) en la pestaña Estructura */
.yaml-archivos { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.yaml-archivos:empty { display: none; }

/* simulador del informe (pestaña del catálogo): toma TODO el ancho (se oculta la lista) y
   se parte en 2 columnas como la captura: izquierda hallazgos, derecha el reporte (sticky). */
.cat-cols.sim-full { grid-template-columns: 1fr; }
.cat-cols.sim-full .cat-izq { display: none; }
.sim-cols { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr); gap: 16px; align-items: start; }
@media (max-width: 900px) { .sim-cols { grid-template-columns: 1fr; } }
#sim-detalles { display: grid; gap: 10px; margin: 10px 0; }
#sim-hoja { position: sticky; top: 12px; max-height: calc(100vh - 40px); overflow: auto; }

/* ---- vista por ÓRGANO (captura + simulador): barra de incluir/excluir + acordeón por órgano ---- */
.organos-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-bottom: 10px; }
.organos-lbl { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin-right: 2px; }
.chip.org { opacity: .55; }                              /* órgano excluido: atenuado */
.chip.org.on { opacity: 1; }                            /* incluido */
.chip.org.opc { border-style: dashed; }                 /* opcional (aorta, retroperitoneo…) */
.org-acc { border: 1px solid var(--border); border-radius: 10px; margin-bottom: 8px; background: var(--soft); overflow: hidden; }
.org-acc > summary { cursor: pointer; padding: 8px 12px; display: flex; justify-content: space-between; align-items: baseline; gap: 8px; list-style: none; }
.org-acc > summary::-webkit-details-marker { display: none; }
.org-acc > summary::before { content: "▸"; color: var(--muted); margin-right: 6px; transition: transform .15s; display: inline-block; }
.org-acc[open] > summary::before { transform: rotate(90deg); }
.org-acc > summary strong { flex: 1; }
.org-meta { font-size: 0.78rem; color: var(--muted); }
.org-meta b { color: var(--accent); }
.org-body { padding: 4px 12px 12px; border-top: 1px solid var(--border); }
.org-clase { margin-top: 8px; }
.org-clase-lbl { display: block; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin-bottom: 4px; }
.org-clase .chip { margin: 0 4px 4px 0; }

/* ---- catálogo: lista agrupada por órgano (acordeón) ---- */
.cat-organo-acc { border-top: 2px solid var(--border); margin-top: 12px; padding-top: 4px; }
.cat-organo-acc > summary { cursor: pointer; padding: 6px 2px; list-style: none; font-size: 1.02rem; color: var(--accent); }
.cat-organo-acc > summary::-webkit-details-marker { display: none; }
.cat-organo-acc > summary::before { content: "▸"; margin-right: 6px; display: inline-block; transition: transform .15s; }
.cat-organo-acc[open] > summary::before { transform: rotate(90deg); }
.cat-organo-n { color: var(--muted); font-size: 0.82rem; font-weight: 600; margin-left: 4px; }

/* valores capturados resaltados en la hoja (los pone el motor; la copia sale limpia) */
.hoja .val { background: var(--accent-soft); color: var(--accent); border-radius: 4px; padding: 0 3px; }

/* ESTADO de una dimensión (rango de referencia): selector ajustable + pista del rango + color por nivel */
.med-estado { font-size: .76rem; padding: 2px 4px; border-radius: 6px; border: 1px solid var(--border); background: var(--soft); color: var(--text); }
.med-estado.nivel-alto { border-color: var(--warn-border); background: var(--warn-bg); color: var(--warn-fg); font-weight: 600; }
.med-estado.nivel-bajo { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); font-weight: 600; }
.med-rango { font-size: .72rem; color: var(--muted); white-space: nowrap; }
.det.fuera-rango input { border-color: var(--warn-border); }
.det.fuera-rango .unidad { color: var(--warn-fg); }

/* sección de MEDICIONES (modal de región): etiqueta arriba + fila de controles, con separador discreto */
.med-controls { display: flex; align-items: center; flex-wrap: wrap; gap: 7px 12px; }
.med-ent { display: inline-flex; align-items: center; gap: 6px; flex: none; }
.region-cap .det.medida { display: block; padding: 9px 0; margin-top: 0; }
.region-cap .det.medida + .det.medida { border-top: 1px solid var(--border); }
.region-cap .det.medida > label { display: block; min-width: 0; margin-bottom: 6px; font-size: 0.82rem; font-weight: 600; color: var(--text); }
.region-cap .det.medida .med-estado { max-width: 200px; }

/* ===== captura rediseñada: búsqueda rápida + TABLERO de órganos + MODAL de región ===== */
.cap-busca { position: relative; margin-bottom: 14px; }
.cap-busca #buscar { width: 100%; }

.tablero { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.org-card { position: relative; text-align: left; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; cursor: pointer; display: flex; flex-direction: column; gap: 4px; transition: border-color .12s, background .12s; }
.org-card:hover, .org-card:focus-visible { border-color: var(--accent); outline: none; }
.org-card.activo { border-color: var(--accent); background: var(--accent-soft); }
.org-card.alerta { border-color: var(--warn-border); background: var(--warn-bg); }
.org-card.incompleto { border-color: var(--danger-border); background: var(--danger-bg); }
.org-card.incompleto .org-card-meta { color: var(--danger); font-weight: 600; }
.org-card.pendiente { opacity: .55; border-style: dashed; }
.org-card.pendiente .org-card-meta { color: var(--muted); }
.org-card.ok .org-card-meta { color: var(--accent); font-weight: 600; }
.org-card.opc { border-style: dashed; }
/* barra: hay órganos sin examinar (no salen en el informe) + atajo «marcar todo normal» */
.tablero-acc { grid-column: 1 / -1; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 10px; padding: 8px 12px; background: var(--warn-bg); border: 1px solid var(--warn-border); border-radius: 10px; margin-bottom: 2px; }
.tablero-acc-info { font-size: 0.82rem; color: var(--warn-fg); }
#modal-examinar.ok { color: var(--accent); border-color: var(--accent); font-weight: 600; }
.org-card-tit { font-weight: 700; font-size: 0.95rem; color: var(--text); }
.org-card-meta { font-size: 0.78rem; color: var(--muted); }
.org-card.alerta .org-card-meta { color: var(--warn-fg); font-weight: 600; }
.org-card.activo .org-card-meta { color: var(--accent); }
.org-card-x { position: absolute; top: 6px; right: 6px; width: 22px; height: 22px; border: none; background: transparent; color: var(--muted); cursor: pointer; border-radius: 6px; font-size: 0.8rem; line-height: 1; }
.org-card-x:hover { background: var(--soft); color: var(--danger); }
.tablero-add { grid-column: 1 / -1; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 6px; }
.tablero-add-lbl { font-size: 0.78rem; color: var(--muted); }

.modal-back { position: fixed; inset: 0; z-index: 80; background: rgba(10, 22, 30, 0.5); display: flex; align-items: flex-start; justify-content: center; padding: 28px 16px; overflow-y: auto; }
/* TAMAÑO FIJO (no salta al cambiar contenido): región 4:3 (960×720) con scroll interno por panel */
.modal-box { width: min(1488px, 96vw); height: min(864px, 92vh); background: var(--surface); border: 1px solid var(--border); border-radius: 12px; box-shadow: 0 18px 50px rgba(0,0,0,0.35); display: flex; flex-direction: column; }
.modal-box-det { width: min(728px, 94vw); height: min(720px, 92vh); }   /* detalle: +30% de ancho; misma altura que el de región (redimensionable) */
.modal-back.nivel-2 { z-index: 90; background: rgba(10, 22, 30, 0.45); }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); flex: none; }
.modal-head strong { font-size: 1.05rem; }
.icon-x { border: none; background: transparent; color: var(--muted); cursor: pointer; font-size: 1rem; padding: 4px 8px; border-radius: 6px; }
.icon-x:hover { background: var(--soft); color: var(--text); }

/* barra de herramientas del modal (accesibilidad): letra · pantalla completa · redimensionar */
.modal-box { position: relative; }
.modal-tools { display: flex; align-items: center; gap: 4px; }
.tool-btn { border: 1px solid var(--border); background: var(--soft); color: var(--text); cursor: pointer; border-radius: 8px; padding: 4px 9px; font: inherit; font-size: 0.82rem; font-weight: 600; line-height: 1; }
.tool-btn:hover { border-color: var(--accent); color: var(--accent); }
.tool-btn[aria-pressed="true"] { background: var(--accent); color: var(--accent-contrast); border-color: var(--accent); }
.modal-box.fullscreen, .form-modal.fullscreen { width: 100vw; height: 100dvh; max-width: none; max-height: none; border-radius: 0; border: none; }
.modal-back:has(.modal-box.fullscreen), .form-back:has(.form-modal.fullscreen) { padding: 0; align-items: stretch; }
.modal-resize { position: absolute; right: 3px; bottom: 3px; width: 16px; height: 16px; cursor: nwse-resize; touch-action: none; z-index: 2;
  background: linear-gradient(135deg, transparent 45%, var(--muted) 45%, var(--muted) 55%, transparent 55%, transparent 70%, var(--muted) 70%, var(--muted) 80%, transparent 80%); opacity: .6; }
.modal-resize:hover { opacity: 1; }
.modal-box.fullscreen .modal-resize, .form-modal.fullscreen .modal-resize { display: none; }
/* control de tamaño de letra en el top bar de la página */
.font-ctl { display: inline-flex; align-items: center; gap: 2px; border: 1px solid var(--border); border-radius: 8px; padding: 2px 3px; background: var(--surface); }
.font-ctl button { border: none; background: transparent; color: var(--text); cursor: pointer; font: inherit; font-weight: 700; font-size: 0.82rem; padding: 2px 7px; border-radius: 6px; line-height: 1; }
.font-ctl button:hover { background: var(--soft); color: var(--accent); }
.font-ctl .font-val { font-size: 0.7rem; color: var(--muted); min-width: 32px; text-align: center; }
.modal-body { padding: 16px 18px; overflow-y: auto; flex: 1; min-height: 0; }
#modal-body { padding: 0; overflow: hidden; }   /* región: el scroll lo llevan las 2 columnas */
.modal-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 18px; border-top: 1px solid var(--border); background: var(--soft); flex: none; }
.modal-hint, .modal-msg { font-size: 0.76rem; color: var(--muted); }
.modal-msg.error { color: var(--danger); font-weight: 600; }
/* info clínica del hallazgo (descripción + impresión + etiquetas) en el modal de detalle */
.det-info { background: var(--accent-soft); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; margin-bottom: 12px; }
.det-desc { margin: 0; font-size: 0.88rem; line-height: 1.5; color: var(--text); }
.det-imp { margin: 8px 0 0; font-size: 0.82rem; line-height: 1.45; color: var(--muted); }
.det-imp-lbl { font-weight: 700; color: var(--text); }
.det-tags { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 6px; }
.det-tags .etq { font-size: 0.72rem; color: var(--accent); background: var(--surface); border: 1px solid var(--border); border-radius: 99px; padding: 2px 8px; }
.det-preview { background: var(--soft); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; margin-bottom: 14px; font-size: 0.9rem; line-height: 1.5; }
.det-preview::before { content: "Quedará en el informe:"; display: block; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin-bottom: 4px; }
/* comentario adicional sobre el diagnóstico (texto libre que se suma al informe) */
.det-coment { margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--border); }
.det-coment .det-coment-lbl, .det-coment .det-coment-txt { display: none; }
.det-coment.abierto .det-coment-btn { display: none; }
.det-coment.abierto .det-coment-lbl { display: block; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin-bottom: 6px; }
.det-coment.abierto .det-coment-txt { display: block; }
.det-coment-txt { width: 100%; font: inherit; font-size: 0.88rem; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface); color: var(--text); resize: vertical; }
.det-coment-txt:focus { border-color: var(--accent); outline: none; }
.det-preview .val { background: var(--accent-soft); color: var(--accent); border-radius: 4px; padding: 0 3px; }
.det-preview mark { background: var(--mark); border-radius: 3px; padding: 0 3px; }
.det.invalido input, .det.invalido .grp { outline: 2px solid var(--danger); outline-offset: 2px; border-radius: 6px; }
.det.invalido > label { color: var(--danger); font-weight: 600; }

/* modal de detalle: separar CLARAMENTE cada característica/medición (separador discreto + aire) */
#det-body .det { align-items: start; padding: 13px 0; margin-top: 0; }
#det-body .det + .det { border-top: 1px solid var(--border); }
#det-body .det > label { min-width: 120px; padding-top: 6px; font-weight: 600; color: var(--text); }
#det-body .det.invalido { border-radius: 8px; }

/* widget de región: 3 columnas — Capturar · Capturado (solo lectura) · Impacto en lo normal. Cada una scrollea. */
.region-3col { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 0.95fr); gap: 0; height: 100%; }
.region-cap { padding: 16px 18px; border-right: 1px solid var(--border); overflow-y: auto; height: 100%; }
.region-res { padding: 16px 18px; display: flex; flex-direction: column; min-width: 0; overflow-y: auto; height: 100%; border-right: 1px solid var(--border); }
.region-imp { padding: 16px 18px; min-width: 0; overflow-y: auto; height: 100%; }
.region-lbl { margin: 0 0 8px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.region-cap .region-lbl { margin-top: 14px; }
.region-cap .region-lbl:first-child { margin-top: 0; }
.region-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); margin-bottom: 12px; flex-wrap: wrap; }
.region-tab { border: none; background: transparent; cursor: pointer; padding: 7px 12px; font: inherit; font-size: 0.85rem; color: var(--muted); border-bottom: 2px solid transparent; margin-bottom: -1px; }
.region-tab:hover { color: var(--text); }
.region-tab.on { color: var(--accent); border-bottom-color: var(--accent); font-weight: 600; }
.region-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.region-vacio { margin: 4px 0; font-size: 0.82rem; color: var(--muted); }

/* características normales del órgano: lista de enunciados activables/desactivables */
.region-normales { display: flex; flex-direction: column; gap: 3px; margin-bottom: 6px; }
.norm-item { display: flex; align-items: flex-start; gap: 8px; text-align: left; background: transparent; border: none; border-radius: 8px; padding: 5px 8px; cursor: pointer; font: inherit; color: var(--text); }
.norm-item:hover { background: var(--soft); }
.norm-check { color: var(--accent); font-weight: 700; flex: none; line-height: 1.4; }
.norm-txt { font-size: 0.85rem; line-height: 1.4; }
.norm-item.off { color: var(--muted); }
.norm-item.off .norm-check { color: var(--muted); }
.norm-item.off .norm-txt { text-decoration: line-through; }
.norm-item.quitado { opacity: .65; cursor: default; }
.norm-item.quitado .norm-check { color: var(--danger); }
.norm-item.quitado .norm-txt { text-decoration: line-through; }
.norm-tag { margin-left: auto; font-size: 0.7rem; color: var(--muted); white-space: nowrap; }
.norm-item.advisorio { background: var(--warn-bg); border-radius: 8px; }
.norm-warn { margin-left: auto; color: var(--warn-fg); flex: none; }

/* ALERTA de impacto de un hallazgo sobre lo normal (transparencia + advisorio) */
.region-alerta { background: var(--warn-bg); border: 1px solid var(--warn-border); border-radius: 10px; padding: 9px 12px; margin-bottom: 14px; }
.al-hallazgo + .al-hallazgo { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--warn-border); }
.al-tit { margin: 0 0 4px; font-size: 0.84rem; font-weight: 700; color: var(--warn-fg); }
.region-alerta ul { margin: 0; padding-left: 18px; }
.region-alerta li { font-size: 0.82rem; line-height: 1.4; margin: 2px 0; color: var(--text); }
.region-alerta li.al-auto { color: var(--muted); }
.al-sub { color: var(--muted); font-size: 0.92em; }
.al-btn { margin-top: 7px; background: var(--accent); color: var(--accent-contrast); border: none; border-radius: 8px; padding: 5px 12px; font: inherit; font-size: 0.8rem; cursor: pointer; }
.al-btn:hover { filter: brightness(1.05); }

/* listado de capturados (solo lectura, editable con doble clic) */
.res-lista { display: flex; flex-direction: column; gap: 8px; }
.res-item { background: var(--soft); border: 1px solid var(--border); border-radius: 10px; padding: 9px 11px; }
.res-item.editando { border-color: var(--accent); }
.res-item.res-hijo { margin-left: 16px; border-left: 3px solid var(--accent); }
.res-item-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.res-item-txt { font-size: 0.9rem; line-height: 1.45; color: var(--text); }
.res-item-txt .val { background: var(--accent-soft); color: var(--accent); border-radius: 4px; padding: 0 3px; }
.res-item-txt mark { background: var(--mark); border-radius: 3px; padding: 0 3px; }
.res-item-acc { display: flex; gap: 2px; flex: none; }
.icon-mini { border: none; background: transparent; color: var(--muted); cursor: pointer; width: 22px; height: 22px; border-radius: 6px; font-size: 0.8rem; line-height: 1; }
.icon-mini:hover { background: var(--surface); color: var(--text); }
.res-item.incompleto { border-color: var(--warn-border); background: var(--warn-bg); }
.res-falta { display: inline-block; margin-top: 6px; font-size: 0.72rem; font-weight: 600; color: var(--warn-fg); }
.res-refinar { margin-top: 8px; display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.res-refinar-lbl { font-size: 0.74rem; color: var(--muted); }
.res-dims { display: flex; flex-direction: column; gap: 8px; }
.res-dims:empty { display: none; }
.res-dim { border-radius: 8px; padding: 7px 10px; font-size: 0.85rem; background: var(--warn-bg); border: 1px solid var(--warn-border); }
.res-dim.nivel-bajo { background: var(--accent-soft); border-color: var(--accent); }
.res-dim-txt { color: var(--text); }
.res-vacio[hidden] { display: none; }
.res-pie { margin-top: auto; padding-top: 12px; font-size: 0.78rem; color: var(--muted); }

@media (max-width: 920px) {
  .region-3col { grid-template-columns: 1fr; height: auto; }
  .region-cap, .region-res, .region-imp { padding: 14px 16px; border-right: none; border-bottom: 1px solid var(--border); overflow: visible; height: auto; }
  #modal-body { overflow-y: auto; }
}
/* MÓVIL: los modales ocupan la PÁGINA ENTERA (full-screen) */
@media (max-width: 640px) {
  .modal-back { padding: 0; align-items: stretch; }
  .modal-box, .modal-box-det { width: 100vw; height: 100dvh; max-width: none; border: none; border-radius: 0; }
}

/* pestaña Agentes (prompts del sistema, SOLO LECTURA; se editan por MCP) */
.agentes-cols { display: grid; grid-template-columns: minmax(0, 240px) minmax(0, 1fr); gap: 16px; align-items: start; }
.agentes-lista { display: flex; flex-direction: column; gap: 8px; }
.agentes-grupo { margin: 8px 0 0; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: var(--accent); }
.agentes-grupo:first-child { margin-top: 0; }
.agentes-grupo small { font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--muted); }
/* modo microfrontend embebido (iframe en la app principal): el host aporta el chrome; ocultamos la navegación externa */
body.embed .top-acc a.ghost { display: none; }
body.embed .top .sub { display: none; }
#enviar-host { margin-left: 8px; }

.agentes-nuevo { align-self: stretch; justify-content: center; margin-bottom: 2px; }
.agentes-vacio { margin: 0 0 2px; font-size: 0.78rem; color: var(--muted); font-style: italic; }
/* acciones del visor (copiar/editar/eliminar) + editor de prompt */
.agente-doc-acc { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.prompt-form { display: grid; gap: 12px; }
.prompt-form label { display: grid; gap: 4px; font-size: 0.82rem; color: var(--muted); font-weight: 700; }
.prompt-form input, .prompt-form textarea { font: inherit; font-weight: 400; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface); color: var(--text); width: 100%; }
.prompt-form textarea.ia-mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 0.82rem; line-height: 1.45; resize: vertical; }
.prompt-form input:focus, .prompt-form textarea:focus { outline: none; border-color: var(--accent); }
.prompt-form-acc { display: flex; justify-content: flex-end; gap: 10px; }
.prompt-form .err { color: var(--danger); background: var(--danger-bg); border: 1px solid var(--danger-border); border-radius: 7px; padding: 8px 10px; font-size: 0.84rem; }
.agente-item { text-align: left; background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; cursor: pointer; display: flex; flex-direction: column; gap: 3px; }
.agente-item:hover { border-color: var(--accent); }
.agente-item.on { border-color: var(--accent); background: var(--accent-soft); }
.agente-item strong { font-size: 0.9rem; }
.agente-item small { font-size: 0.74rem; color: var(--muted); line-height: 1.3; }
.agente-doc { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 16px 20px; max-height: calc(100vh - 170px); overflow: auto; }
.agente-doc-head { border-bottom: 1px solid var(--border); margin-bottom: 12px; padding-bottom: 10px; }
.agente-doc-head h3 { margin: 0 0 4px; }
.agente-doc h1, .agente-doc h2, .agente-doc h3, .agente-doc h4 { margin: 16px 0 6px; color: var(--accent); font-size: 0.98rem; }
.agente-doc-head h3 { color: var(--text); }
.agente-doc p { margin: 6px 0; line-height: 1.5; font-size: 0.88rem; }
.agente-doc ul { margin: 6px 0 6px 18px; }
.agente-doc li { font-size: 0.88rem; line-height: 1.45; margin: 2px 0; }
.agente-doc code { background: var(--soft); border: 1px solid var(--border); border-radius: 4px; padding: 0 4px; font-size: 0.85em; }
.agente-doc pre { background: var(--soft); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; overflow-x: auto; font-size: 0.82rem; }
.agente-doc pre code { background: none; border: none; padding: 0; }
@media (max-width: 760px) { .agentes-cols { grid-template-columns: 1fr; } }

/* panel "Mediciones del estudio" (las dimensiones que se reportan siempre) */
.mediciones-box { background: var(--soft); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; margin-bottom: 12px; }
.med-titulo { margin: 0 0 4px; }
.med-org { margin: 8px 0 4px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.mediciones-box .med-org:first-of-type { margin-top: 2px; }
.med-vacio { margin: 0; font-size: 0.82rem; color: var(--muted); }
/* base normal del estudio (enunciados ubicables, etiquetados medición/normal) */
.base-normal .med-org { margin-top: 10px; }
.base-enun { display: flex; align-items: baseline; gap: 8px; padding: 3px 0; font-size: 0.85rem; }
.base-enun .badge { flex: none; }
.base-txt { color: var(--text); }

/* botón «+» (agregar otra instancia del mismo hallazgo) en la cabecera de la tarjeta */
.dx-head .mas { border: 1px solid var(--border); background: var(--surface); color: var(--accent); border-radius: 7px; width: 24px; height: 24px; line-height: 1; cursor: pointer; font-size: 0.95rem; padding: 0; }
.dx-head .mas:hover { border-color: var(--accent); background: var(--accent-soft); }

.cat-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
}
.cat-card.mio { border-left: 3px solid var(--accent); }

.cat-card-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.cat-card-head strong { font-size: 1rem; }
.badges { display: flex; gap: 5px; flex-wrap: wrap; }

.badge {
  font-size: 0.7rem; font-weight: 700; border-radius: 99px; padding: 2px 8px;
  background: var(--soft); color: var(--muted); white-space: nowrap;
}
.badge.tag { background: var(--accent-soft); color: var(--accent); }
.badge.mio { background: var(--accent); color: var(--accent-contrast); }
.badge.fab { background: var(--soft); color: var(--muted); }

.cat-desc { margin: 7px 0 4px; font-size: 0.88rem; color: var(--text); }
.cat-frase { margin: 4px 0; font-size: 0.84rem; font-style: italic; color: var(--muted); }
.cat-meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin-top: 6px; font-size: 0.76rem; }
.etq { color: var(--accent); }
.cat-autor { margin-left: auto; color: var(--muted); }
.cat-del {
  margin-top: 8px; font: inherit; font-size: 0.78rem; color: #c0392b;
  background: none; border: 1px solid var(--border); border-radius: 7px; padding: 4px 10px; cursor: pointer;
}
.cat-del:hover { background: var(--soft); }

.cat-der {
  background: var(--surface); border: 1px solid var(--border); border-radius: 12px; overflow: hidden;
}
.cat-tabs { display: flex; border-bottom: 1px solid var(--border); }
.cat-tab {
  font: inherit; font-weight: 700; font-size: 0.86rem; padding: 11px 16px;
  background: none; border: none; color: var(--muted); cursor: pointer; border-bottom: 2px solid transparent;
}
.cat-tab.activo { color: var(--accent); border-bottom-color: var(--accent); }
.cat-panel { padding: 14px 16px; }

.cat-yaml-acciones { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.cat-yaml {
  width: 100%; min-height: 460px; resize: vertical;
  font-family: ui-monospace, "Cascadia Code", Consolas, monospace; font-size: 0.82rem; line-height: 1.5;
  padding: 11px 13px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--soft); color: var(--text); white-space: pre; tab-size: 2;
}
.cat-yaml:focus { outline: none; border-color: var(--accent); }
#yaml-msg .ok { color: var(--accent); font-weight: 700; font-size: 0.86rem; margin-bottom: 8px; }
#yaml-msg .err {
  color: var(--danger); background: var(--danger-bg); border: 1px solid var(--danger-border); border-radius: 7px;
  padding: 8px 10px; font-size: 0.84rem; margin-bottom: 8px;
}
.aviso { background: var(--warn-bg); border: 1px solid var(--border); border-radius: 7px; padding: 8px 10px; font-size: 0.82rem; margin-top: 6px; color: var(--text); }

.guia { font-size: 0.9rem; line-height: 1.55; }
.guia h3 { color: var(--accent); font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.05em; margin: 16px 0 5px; }
.guia h3:first-child { margin-top: 0; }
.guia code { background: var(--soft); border-radius: 4px; padding: 0 4px; font-size: 0.85em; }
.guia pre {
  background: var(--soft); border: 1px solid var(--border); border-radius: 8px; padding: 11px 13px;
  font-size: 0.8rem; line-height: 1.5; overflow-x: auto;
}
.guia-tabla { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.guia-tabla td { padding: 4px 8px 4px 0; vertical-align: top; border-bottom: 1px solid var(--border); }
.guia-tabla td:first-child { white-space: nowrap; }

.cat-lista-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin: 8px 0 6px; }
.cat-lista-head #lista-lbl { margin: 0; }
.cat-card.bib { border-left: 3px solid var(--accent); }
.badge.ref { background: var(--accent-soft); color: var(--accent); }
.badge.bib { background: var(--accent); color: var(--accent-contrast); }
.cat-card-acc { display: flex; gap: 8px; margin-top: 8px; }
.cat-ed, .cat-del {
  font: inherit; font-size: 0.78rem; background: none; border: 1px solid var(--border);
  border-radius: 7px; padding: 4px 10px; cursor: pointer;
}
.cat-ed { color: var(--accent); } .cat-ed:hover { background: var(--accent-soft); }
.cat-del { color: #c0392b; } .cat-del:hover { background: var(--soft); }

/* ---- editor por formulario (modal) ---- */
.form-back {
  position: fixed; inset: 0; z-index: 80; background: rgba(10, 22, 30, 0.5);
  display: flex; align-items: flex-start; justify-content: center; padding: 30px 16px; overflow-y: auto;
}
.form-modal {
  width: min(900px, 100%); background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 18px 50px rgba(0, 0, 0, 0.35);
  --det-cols: minmax(0, 1.15fr) 96px minmax(0, 2fr) 28px;
  position: relative; display: flex; flex-direction: column; max-height: calc(100vh - 60px);
}
.form-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); flex: none; }
.form-head h3 { margin: 0; font-size: 1.05rem; }
#form-desc { margin: 10px 18px 0; font-size: 0.8rem; color: var(--muted); flex: none; }
/* el cuerpo scrollea; head/desc/msg/acciones quedan fijos → el modal puede ir a pantalla completa o redimensionarse */
.form-body { padding: 16px 18px; display: grid; gap: 14px; overflow-y: auto; flex: 1 1 auto; min-height: 0; }
.form-body label, .form-body .campo { display: grid; gap: 4px; font-size: 0.82rem; color: var(--muted); font-weight: 700; }
.form-body .campo-lbl { font-size: 0.82rem; color: var(--muted); font-weight: 700; }
.form-body .campo-lbl .hint, .ia-head .hint { font-weight: 400; }
.form-body input, .form-body select, .form-body textarea {
  font: inherit; font-weight: 400; padding: 8px 10px; border: 1px solid var(--border);
  border-radius: 8px; background: var(--surface); color: var(--text); width: 100%;
}
.form-body input:focus, .form-body select:focus, .form-body textarea:focus { outline: none; border-color: var(--accent); }

/* dos columnas: Clasificacion (izq) + Redaccion (der) */
.form-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 16px 18px; align-items: start; }
.col-clasif, .col-redaccion { display: grid; gap: 12px; align-content: start; min-width: 0; }
.col-titulo { margin: 0 0 2px; padding-bottom: 6px; border-bottom: 1px solid var(--border);
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); }
.col-redaccion textarea { min-height: 96px; resize: vertical; }
#f-frase { min-height: 150px; }

.form-body .dos { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-body #f-estudios { display: grid; gap: 8px; }
.f-estudios-grp { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.f-estudios-mod { width: 100%; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.f-det-head { display: flex; align-items: center; justify-content: space-between; }
.f-det-head .lbl { margin: 0; }
.f-detalles { display: grid; gap: 8px; }
.f-det-row { display: grid; grid-template-columns: var(--det-cols); align-items: center; gap: 6px; }
.f-det-row .f-d-extra { display: block; min-width: 0; }
.f-det-row .f-d-extra input, .f-det-row .f-d-extra select { width: 100%; }
.form-acc { display: flex; justify-content: flex-end; gap: 10px; padding: 12px 18px; border-top: 1px solid var(--border); flex: none; }
#form-msg { flex: none; }
#form-msg:not(:empty) { padding: 0 18px 4px; }
#form-msg .err { color: var(--danger); background: var(--danger-bg); border: 1px solid var(--danger-border); border-radius: 7px; padding: 8px 10px; font-size: 0.84rem; }

/* asistente IA dentro del formulario (banda superior a todo el ancho) */
.ia-box { border: 1px dashed var(--accent); border-radius: 10px; padding: 10px 12px; background: var(--soft); }
.ia-head { display: flex; align-items: center; justify-content: space-between; }
.ia-head strong { font-weight: 700; font-size: 0.9rem; color: var(--accent); }
#ia-cuerpo:not([hidden]) { display: grid; gap: 8px; margin-top: 10px; }
.ia-acc { display: flex; gap: 8px; }
.ia-mono { width: 100%; font-family: ui-monospace, "Cascadia Code", Consolas, monospace; font-size: 0.78rem; line-height: 1.45; }
#ia-msg .ok { color: var(--accent); font-weight: 700; font-size: 0.82rem; }
/* asistente IA: selector de modo + mediciones recomendadas (1 clic) */
.ia-modo { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
#ia-meds:not(:empty) { margin-top: 8px; border-top: 1px solid var(--border); padding-top: 6px; }
.med-rec { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 6px 0; }
.med-rec + .med-rec { border-top: 1px solid var(--border); }
.med-rec-txt { font-size: 0.84rem; }
.med-rec-txt small { color: var(--muted); }
/* fila de checkbox en el formulario (anula el grid label-sobre-control) */
.form-body label.check-row { display: flex; flex-direction: row; align-items: center; gap: 8px; }
.form-body label.check-row input { width: auto; }
#ia-msg .err { color: var(--danger); background: var(--danger-bg); border: 1px solid var(--danger-border); border-radius: 7px; padding: 6px 9px; font-size: 0.82rem; }

/* movil: una sola columna, filas de detalle que envuelven */
@media (max-width: 760px) {
  .form-grid { grid-template-columns: 1fr; }
  .form-body .dos { grid-template-columns: 1fr; }
  .f-det-row { display: flex; flex-wrap: wrap; gap: 6px; }
  .f-det-row .f-d-clave, .f-det-row .f-d-tipo { flex: 1 1 auto; }
  .f-det-row .f-d-extra { flex: 1 1 100%; }
  .form-acc { flex-wrap: wrap; }
}
