/* ============================================================================
   COGO — lo ÚNICO propio sobre el canónico: el acento (grafito) y las vistas.
   El semáforo es la identidad, así que el chrome es neutro y el color lo cargan
   los tokens --ok / --warn / --err del sistema.
   ============================================================================ */
:root { --accent:#3f4654; --accent-2:#2c313c; --on-accent:#fff; --ring:0 0 0 3px rgba(63,70,84,.20); }
:root[data-theme="dark"] { --accent:#9aa4b2; --accent-2:#6b7280; --ring:0 0 0 3px rgba(154,164,178,.26); }

/* ---- wordmark: sub-título de marca (patrón Selega/familia) ---- */
.app-header h1 { display: flex; flex-direction: column; justify-content: center; }
.app-header h1 small { font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .14em;
  color: var(--muted); margin-top: 2px; line-height: 1; }

/* ---- hero de vista: eyebrow + título (le da "diseño" a cada pantalla) ---- */
.viewhead { margin: 26px 0 20px; }
.viewhead .vh-eyebrow { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: var(--accent); }
:root[data-theme="dark"] .viewhead .vh-eyebrow { color: var(--muted-2); }
.viewhead .vh-title { font-size: clamp(21px, 3vw, 27px); font-weight: 600; letter-spacing: -.025em; margin: 4px 0 6px; color: var(--text); }
.viewhead .vh-sub { color: var(--muted); font-size: 14px; line-height: 1.5; max-width: 640px; }

/* color por confianza, vía una custom prop local que cada elemento usa */
/* El amarillo del semáforo debe leerse AMARILLO/ámbar, no marrón: el --warn
   canónico en claro (#9a6700) tira a marrón, así que la confianza usa un ámbar
   vivo propio (el mismo del grafo). */
.c-green   { --c: var(--ok); }
.c-yellow  { --c: #d6a01a; }
.c-red     { --c: var(--err); }
.c-ungraded{ --c: var(--muted); }

main { max-width: 1060px; margin: 0 auto; padding: 14px 24px 72px; }

/* ---- tabs ---- */
.tabs { display: flex; gap: 2px; padding: 8px 22px 0; border-bottom: 1px solid var(--border);
  position: sticky; top: 55px; background: var(--bg); z-index: 9; }
.tabs .tab { background: none; color: var(--muted-2); border: 0; border-bottom: 2px solid transparent;
  border-radius: 0; padding: 9px 13px; font-weight: 600; }
.tabs .tab:hover { background: none; color: var(--text); border-color: transparent; }
.tabs .tab.active { color: var(--text); border-bottom-color: var(--accent); }

/* ---- view bar / legend ---- */
.viewbar { display: flex; align-items: center; gap: 14px; margin: 16px 0 14px; flex-wrap: wrap; }
.legend { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.legend .lg { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--muted-2);
  border: 1px solid var(--border); border-radius: 999px; padding: 4px 11px; background: var(--panel); }
.dot { width: 10px; height: 10px; border-radius: 50%; background: var(--c, var(--muted)); flex: 0 0 auto; }
.hg { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--muted-2); cursor: pointer; margin-left: auto; }

/* ---- note cards (vault) ---- */
.note-list { display: flex; flex-direction: column; gap: 10px; }
.note-card { display: flex; gap: 13px; align-items: flex-start; padding: 15px 18px;
  border: 1px solid var(--border); border-left: 3px solid var(--c, var(--border));
  border-radius: var(--radius-lg); background: var(--panel); box-shadow: var(--shadow);
  transition: transform .14s, box-shadow .14s, border-color .14s; }
.note-card .dot { margin-top: 4px; }
.nc-body { min-width: 0; flex: 1; }
.nc-head { display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap; }
.nc-id { font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--text); }
.nc-type { font-size: 11.5px; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
.nc-claim { font-size: 13.5px; color: var(--muted-2); margin: 3px 0 0; line-height: 1.45; }
.nc-reason { font-size: 11.5px; color: var(--muted); margin: 5px 0 0; font-style: italic; }
.nc-stale { margin-left: auto; font-family: var(--mono); font-size: 11.5px; color: var(--muted); cursor: help; }
.nc-stale.warn { color: var(--warn); }
.nc-stale.bad { color: var(--err); }
.menu-meta { font-size: 11.5px; color: var(--muted); padding: 7px 13px 3px; font-variant-numeric: tabular-nums; cursor: help; }

/* ---- pantalla de acceso (OIDC / token) ---- */
.login-overlay { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; padding: 24px; background: var(--bg); }
.login-card { width: min(360px, 92vw); text-align: center; background: var(--panel); border: 1px solid var(--border);
  border-radius: 18px; box-shadow: var(--shadow); padding: 32px 28px; }
.login-card .logo { width: 56px; height: 56px; margin: 0 auto 14px; display: block; border-radius: 13px; }
.login-card h2 { margin: 0 0 6px; font-size: 22px; }
.login-sub { color: var(--muted); font-size: 13.5px; margin: 0; line-height: 1.5; }
.login-sso { display: inline-block; margin-top: 18px; padding: 11px 22px; border-radius: 999px;
  background: var(--accent); color: var(--on-accent); font-weight: 600; font-size: 14px; text-decoration: none; cursor: pointer; border: 0; }
.login-sso:hover { background: var(--accent-2); }
/* gate por token */
.token-form { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }
.token-form input { width: 100%; text-align: center; }
.token-form .login-sso { margin-top: 2px; }
.token-err { color: var(--err); font-size: 12.5px; min-height: 16px; margin-top: 10px; }
.login-alt { display: inline-block; margin-top: 16px; font-size: 12.5px; color: var(--muted); cursor: pointer; text-decoration: none; border-bottom: 1px dashed var(--border); }
.login-alt:hover { color: var(--accent); border-color: var(--accent); }

/* ---- Conexiones MCP (tokens de acceso) ---- */
.tokens-modal { width: min(560px, 94vw); max-height: 86vh; overflow-y: auto; }
.tk-intro { color: var(--muted); font-size: 13px; line-height: 1.5; margin: 0 0 14px; }
.tk-list { display: flex; flex-direction: column; gap: 8px; }
.tk-empty { font-size: 13px; color: var(--muted); font-style: italic; padding: 6px 0; }
.tk-row { display: flex; align-items: center; gap: 10px; padding: 11px 13px; background: var(--panel); border: 1px solid var(--border); border-radius: 10px; }
.tk-info { flex: 1; min-width: 0; }
.tk-name { display: flex; align-items: center; gap: 8px; }
.tk-label { font-weight: 600; font-size: 13.5px; color: var(--text); }
.tk-ro { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--warn); background: var(--card); border: 1px solid var(--border); border-radius: 999px; padding: 1px 7px; }
.tk-meta { font-size: 11.5px; color: var(--muted); margin-top: 3px; font-variant-numeric: tabular-nums; }
/* Auditoría MCP */
.au-list { max-height: 62vh; overflow-y: auto; }
.au-row { display: flex; align-items: flex-start; gap: 11px; padding: 9px 12px; background: var(--panel); border: 1px solid var(--border); border-radius: 10px; }
.au-who { flex: 0 0 auto; font-size: 10.5px; font-weight: 700; letter-spacing: .02em; border-radius: 999px; padding: 3px 9px; max-width: 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.au-token { color: var(--accent); background: color-mix(in srgb, var(--accent) 12%, var(--panel)); border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border)); }
.au-user { color: var(--ok); background: color-mix(in srgb, var(--ok) 12%, var(--panel)); border: 1px solid color-mix(in srgb, var(--ok) 30%, var(--border)); }
.au-root { color: var(--warn); background: color-mix(in srgb, var(--warn) 12%, var(--panel)); border: 1px solid color-mix(in srgb, var(--warn) 32%, var(--border)); }
.au-anon { color: var(--err); background: color-mix(in srgb, var(--err) 10%, var(--panel)); border: 1px solid color-mix(in srgb, var(--err) 28%, var(--border)); }
.au-mid { flex: 1; min-width: 0; }
.au-act { font-size: 13px; font-weight: 600; color: var(--text); font-family: var(--mono); }
.au-when { display: flex; gap: 10px; align-items: center; font-size: 11px; color: var(--muted); margin-top: 3px; font-variant-numeric: tabular-nums; }
.au-ip { color: var(--muted-2); }

/* Raíces de evidencia */
.ev-row { gap: 12px; }
.ev-proj { flex: 0 0 auto; min-width: 96px; max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: var(--mono); }
.ev-row input { flex: 1; min-width: 0; }
.ev-msg { font-size: 12.5px; margin-left: 10px; }
.ev-msg.ok { color: var(--ok); }
.ev-msg.bad { color: var(--err); }

/* Instrucciones para agentes */
.agents-modal { max-width: 720px; }
.ag-ctrls { justify-content: space-between; margin-bottom: 12px; }
.ag-pre { max-height: 46vh; overflow: auto; background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; font-size: 12px; line-height: 1.55; white-space: pre-wrap; word-break: break-word; color: var(--text); }
.ag-actions { display: flex; gap: 8px; margin-top: 12px; justify-content: flex-end; }

.tk-form-lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); margin: 20px 0 8px; }
.tk-form { display: flex; flex-direction: column; gap: 9px; }
.tk-form input[type=text], .tk-form > input { width: 100%; }
.tk-form-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.tk-form-row select { flex: 0 0 auto; }
.tk-check { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--muted-2); cursor: pointer; }
.tk-check input { width: auto; }
.tk-form-row .mini { margin-left: auto; }
.tk-reveal { margin-top: 6px; padding: 12px 14px; border-radius: 10px; background: var(--ok-soft, color-mix(in srgb, var(--ok) 10%, var(--panel))); border: 1px solid color-mix(in srgb, var(--ok) 32%, var(--border)); }
.tk-reveal.bad { background: color-mix(in srgb, var(--err) 8%, var(--panel)); border-color: color-mix(in srgb, var(--err) 30%, var(--border)); color: var(--err); font-size: 13px; }
.tk-reveal-lbl { font-size: 12px; color: var(--ok); font-weight: 600; margin-bottom: 7px; }
.tk-secret-row { display: flex; align-items: center; gap: 8px; }
.tk-secret { flex: 1; min-width: 0; overflow-x: auto; white-space: nowrap; font-family: var(--mono); font-size: 12.5px; background: var(--card); border: 1px solid var(--border); border-radius: 7px; padding: 7px 10px; }
.tk-cfg-lbl { font-size: 12px; color: var(--muted-2); margin: 12px 0 6px; }
.tk-cfg { margin: 0 0 10px; background: var(--code-bg, #1c2029); color: var(--code-ink, #d7dce6); border-radius: 9px; padding: 12px 14px; overflow-x: auto; font-family: var(--mono); font-size: 12px; line-height: 1.55; }

/* ---- contradicciones persistidas (pestaña Revisión) ---- */
.contra-box { display: flex; flex-direction: column; gap: 10px; margin: 14px 0; }
.contra-title { font-size: 12.5px; font-weight: 600; color: var(--err); }
.contra-card { border: 1px solid color-mix(in srgb, var(--err) 28%, var(--border)); border-left: 3px solid var(--err); border-radius: var(--radius-lg); background: var(--panel); box-shadow: var(--shadow); padding: 13px 16px; }
.contra-head { display: flex; align-items: baseline; gap: 10px; }
.contra-tag { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--err); }
.contra-when { font-size: 11px; color: var(--muted); font-variant-numeric: tabular-nums; }
.contra-reason { font-size: 12.5px; color: var(--muted-2); font-style: italic; margin: 5px 0 10px; }
.contra-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.contra-side { background: var(--card); border: 1px solid var(--border); border-radius: 9px; padding: 9px 11px; min-width: 0; }
.contra-id { display: block; font-family: var(--mono); font-size: 12.5px; font-weight: 600; color: var(--accent); cursor: pointer; text-decoration: none; word-break: break-all; }
.contra-id:hover { text-decoration: underline; }
.contra-claim { font-size: 12.5px; color: var(--muted-2); margin-top: 4px; line-height: 1.45; }
.contra-acts { display: flex; gap: 8px; margin-top: 11px; }
@media (max-width: 560px) { .contra-pair { grid-template-columns: 1fr; } }

/* ---- Veracidad (xray) ---- */
.xr-overall { display: inline-flex; align-items: center; gap: 8px; font-size: 13.5px; }
.xr-overall strong { font-weight: 650; }
.xr-summary { color: var(--muted); font-size: 12.5px; }
.xr-out { display: flex; flex-direction: column; gap: 9px; margin-top: 14px; }
.xr-claim { display: flex; gap: 11px; padding: 12px 15px; border: 1px solid var(--border);
  border-left: 3px solid var(--c, var(--border)); border-radius: var(--radius-lg); background: var(--panel); box-shadow: var(--shadow); }
.xr-claim .dot { margin-top: 4px; flex: 0 0 auto; }
.xr-claim-body { min-width: 0; }
.xr-claim-text { font-size: 13.5px; color: var(--text); line-height: 1.45; }
.xr-claim-reason { font-size: 12.5px; color: var(--muted-2); margin-top: 4px; font-style: italic; }
.xr-claim-meta { font-size: 11px; color: var(--muted); margin-top: 5px; text-transform: uppercase; letter-spacing: .03em; }

/* ---- etiquetado humano del Guard (corpus) ---- */
.guard-label { margin-top: 14px; padding: 13px 15px; border: 1px dashed var(--border); border-radius: var(--radius-lg); background: var(--card); }
.guard-label-btns { display: flex; gap: 8px; margin-top: 8px; }
.guard-label-done { display: block; margin-top: 9px; font-size: 12px; color: var(--ok); min-height: 15px; }

/* ---- render de Markdown (modal de nota + preview del editor) ---- */
.md-render { font-size: 13.5px; line-height: 1.6; color: var(--text); word-wrap: break-word; }
.md-render h1, .md-render h2, .md-render h3, .md-render h4 { margin: 14px 0 6px; line-height: 1.3; }
.md-render h1 { font-size: 19px; } .md-render h2 { font-size: 16px; } .md-render h3 { font-size: 14.5px; }
.md-render p { margin: 8px 0; }
.md-render ul, .md-render ol { margin: 8px 0; padding-left: 22px; }
.md-render li { margin: 3px 0; }
.md-render code { font-family: var(--mono); font-size: .92em; background: var(--card); border: 1px solid var(--border); border-radius: 5px; padding: 1px 5px; }
.md-render pre { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; overflow-x: auto; margin: 10px 0; }
.md-render pre code { background: none; border: 0; padding: 0; }
.md-render blockquote { margin: 10px 0; padding: 4px 14px; border-left: 3px solid var(--border); color: var(--muted-2); }
.md-render a { color: var(--accent); }
.md-render a.wikilink { cursor: pointer; text-decoration: none; border-bottom: 1px dashed var(--accent); }
.md-render hr { border: 0; border-top: 1px solid var(--hairline); margin: 14px 0; }
.md-render > :first-child { margin-top: 0; }

/* ---- editor markdown (toolbar + preview split) ---- */
.md-editor { border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.md-tb-row { display: flex; align-items: center; gap: 2px; padding: 5px 6px; border-bottom: 1px solid var(--border); background: var(--card); }
.md-tb { min-width: 30px; height: 28px; padding: 0 8px; font-size: 13px; font-weight: 600; border-radius: 7px; border: 0; background: transparent; color: var(--muted-2); cursor: pointer; }
.md-tb:hover { background: var(--panel); color: var(--text); }
.md-tb-sp { flex: 1; }
.md-prev.on { background: var(--accent); color: var(--on-accent); }
.md-body-row { display: flex; }
.md-body-row textarea.md { width: 100%; border: 0; border-radius: 0; }
.md-body-row textarea.md:focus { box-shadow: none; border: 0; background: var(--bg); }
.md-preview { display: none; }
.md-editor.split textarea.md { flex: 1; border-right: 1px solid var(--border); }
.md-editor.split .md-preview { display: block; flex: 1; padding: 11px 15px; overflow-y: auto; max-height: 360px; }

/* ---- modal de nota (clic en un nodo del grafo) ---- */
.note-modal { width: min(560px, 94vw); max-height: 86vh; overflow-y: auto; }
.nm-meta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin: 2px 0 6px; }
.nm-type { font-size: 11.5px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.nm-color { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; }
.nm-reason { font-size: 12px; color: var(--muted); font-style: italic; margin-bottom: 10px; }
.nm-contra { margin: 0 0 12px; padding: 10px 12px; border-radius: 10px; background: color-mix(in srgb, var(--err) 8%, var(--panel)); border: 1px solid color-mix(in srgb, var(--err) 30%, var(--border)); }
.nm-contra-tit { font-size: 12px; font-weight: 700; color: var(--err); margin-bottom: 6px; }
.nm-contra-row { font-size: 13px; }
.nm-contra-row + .nm-contra-row { margin-top: 7px; padding-top: 7px; border-top: 1px solid color-mix(in srgb, var(--err) 18%, var(--border)); }
.nm-contra-head { color: var(--muted-2); }
.nm-contra-id { font-family: var(--mono); font-size: 12.5px; color: var(--err); background: none; border: 0; padding: 0; cursor: pointer; text-decoration: underline; }
.nm-contra-reason { font-size: 12px; color: var(--muted); margin-top: 2px; }
.nm-body { border-top: 1px solid var(--hairline); padding-top: 12px; }
.nm-block { margin-top: 14px; border-top: 1px solid var(--hairline); padding-top: 10px; }
.nm-label { font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin-bottom: 6px; }
.nm-ev-row { display: flex; gap: 8px; align-items: baseline; font-size: 12px; margin: 3px 0; }
.nm-ev-kind { font-family: var(--mono); color: var(--muted-2); flex: 0 0 auto; }
.nm-ev-ref { color: var(--text); word-break: break-all; flex: 1; }
.nm-rel-row { display: flex; gap: 8px; font-size: 12.5px; margin: 3px 0; }
.nm-rel-k { color: var(--muted); flex: 0 0 96px; }
.nm-rel-v { font-family: var(--mono); color: var(--text); word-break: break-all; }
.nm-hist { display: flex; flex-direction: column; gap: 8px; }
.nm-hist-row { display: flex; gap: 9px; align-items: baseline; }
.nm-hist-row .dot { margin-top: 5px; flex: 0 0 auto; }
.nm-hist-info { min-width: 0; }
.nm-hist-time { display: block; font-size: 11.5px; color: var(--muted); font-variant-numeric: tabular-nums; }
.nm-hist-reason { font-size: 12px; color: var(--muted-2); }

/* ---- grafo a pantalla completa ---- */
.graph-view:fullscreen { background: var(--bg); padding: 16px 22px; display: flex; flex-direction: column; }
.graph-view:fullscreen .graph-wrap { flex: 1; height: auto; margin-top: 12px; }
.graph-view:fullscreen .edge-legend { flex: 0 0 auto; }

/* ---- modal de confirmación (estilo Escriba, reemplaza al confirm() nativo) ---- */
.confirm-back { opacity: 0; transition: opacity .16s ease; }
.confirm-back.show { opacity: 1; }
.confirm-card { width: min(420px, 94vw); }
.confirm-note { display: inline-block; font-family: var(--mono); font-size: 12.5px; font-weight: 600;
  color: var(--text); background: var(--card); border: 1px solid var(--border);
  border-radius: 8px; padding: 4px 10px; margin-bottom: 10px; word-break: break-all; }
.confirm-msg { margin: 0 0 10px; }
.prompt-input { width: 100%; font-family: var(--mono); font-size: 13px; margin-top: 2px; }
.confirm-hint { font-size: 12.5px; color: var(--muted); background: var(--card);
  border-left: 3px solid var(--warn); border-radius: 0 8px 8px 0; padding: 8px 12px; }
button.danger-btn { background: var(--err); border-color: var(--err); color: #fff; }
button.danger-btn:hover { background: color-mix(in srgb, var(--err) 84%, #000); border-color: color-mix(in srgb, var(--err) 84%, #000); }

/* ---- lifecycle: estado (archivar/reemplazar) + acciones por nota ---- */
.nc-badge { font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em;
  color: var(--muted); background: var(--card); border: 1px solid var(--border);
  border-radius: 999px; padding: 1px 8px; }
.note-card.archived { opacity: .62; background: var(--card); }
.note-card.archived:hover { opacity: 1; }
.nc-actions { display: flex; gap: 6px; margin-top: 9px; opacity: 0; transition: opacity .14s; }
.note-card:hover .nc-actions, .note-card.archived .nc-actions { opacity: 1; }
.nc-act { font-size: 11.5px; padding: 3px 10px; border-radius: 8px; border: 1px solid var(--border);
  background: var(--panel); color: var(--muted); cursor: pointer; transition: color .12s, border-color .12s, background .12s; }
.nc-act:hover { color: var(--text); border-color: var(--hairline); background: var(--card); }
.nc-act.danger:hover { color: var(--err); border-color: var(--err); }

/* ---- freshness table ---- */
.fresh-row { display: flex; align-items: center; gap: 12px; padding: 10px 14px; border: 1px solid var(--border);
  border-radius: var(--radius); background: var(--card-2); margin-bottom: 7px; }
.fresh-row .status { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  padding: 2px 8px; border-radius: 999px; border: 1px solid var(--c, var(--border)); color: var(--c, var(--muted)); }
.fresh-row .fid { font-family: var(--mono); font-size: 13px; }
.fresh-row .fwhen { margin-left: auto; font-family: var(--mono); font-size: 12px; color: var(--muted); }

/* ---- pack preview ---- */
.pack-form { display: flex; gap: 8px; align-items: center; margin: 16px 0 12px; flex-wrap: wrap; }
.pack-form input.q { flex: 1; min-width: 200px; }
.pack-form input.b { width: 120px; }
.pack-summary { display: flex; gap: 12px; align-items: center; margin: 4px 0 12px; font-size: 12.5px; color: var(--muted-2); flex-wrap: wrap; }
.pack-summary .tok { font-family: var(--mono); margin-left: auto; }
.pack-md { font-family: var(--mono); font-size: 12.5px; line-height: 1.5; white-space: pre-wrap; word-break: break-word;
  background: var(--card-2); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px 18px; margin: 0; color: var(--text); }
.copy-row { display: flex; justify-content: flex-end; margin-top: 8px; }

/* ---- graph ---- */
.graph-bar { align-items: center; }
.graph-bar .gb-sp { flex: 1; }
.seg { display: inline-flex; background: var(--card); border: 1px solid var(--border); border-radius: 999px; padding: 2px; gap: 2px; }
.seg-btn { background: none; color: var(--muted-2); border: 0; border-radius: 999px; padding: 5px 15px; font-size: 12.5px; font-weight: 600; transition: background .15s, color .15s; }
.seg-btn:hover { background: var(--card-2); }
.seg-btn.on { background: var(--accent); color: var(--on-accent); }
/* leyenda de aristas del grafo */
.edge-legend { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; margin-top: 10px; padding: 0 2px; }
.el-item { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--muted-2); }
.el-swatch { flex: 0 0 auto; }
/* El grafo es siempre una "constelación" sobre grafito profundo, en cualquier
   tema — es el momento espectacular del visor (así luce el glow y el 3D). */
.graph-wrap { position: relative; height: clamp(360px, 66vh, 620px); border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.08); box-shadow: var(--shadow);
  background: radial-gradient(130% 135% at 50% 34%, #10131c 0%, #0a0d14 55%, #07090f 100%);
  margin-top: 12px; overflow: hidden; }
canvas.graph-canvas { display: block; width: 100%; height: 100%; cursor: grab; }
canvas.graph-canvas:active { cursor: grabbing; }
.graph-tip { position: absolute; z-index: 5; pointer-events: none; max-width: 260px; background: var(--panel);
  border: 1px solid var(--hairline); border-radius: 11px; box-shadow: var(--shadow); padding: 9px 12px;
  display: flex; flex-direction: column; gap: 3px; }
.graph-tip .gt-id { font-family: var(--mono); font-size: 12.5px; font-weight: 600; color: var(--text); }
.graph-tip .gt-type { font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.graph-tip .gt-claim { font-size: 12px; color: var(--muted-2); line-height: 1.42; margin-top: 2px; }
.edge-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 12px; font-size: 12px; color: var(--muted); }
.edge-legend span { display: inline-flex; align-items: center; gap: 7px; }
.edge-legend i { width: 22px; height: 0; border-top: 2px solid var(--muted-2); display: inline-block; }
.edge-legend i.wiki { border-top-style: dashed; border-color: var(--hairline); }

.empty { color: var(--muted); font-size: 13.5px; padding: 30px 0; text-align: center; }

/* ---- welcome / empty vault (primer contacto) ---- */
.welcome { max-width: 480px; margin: 54px auto 0; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 13px; }
.welcome-logo { width: 56px; height: 56px; border-radius: 14px; }
.welcome-h { margin: 4px 0 0; font-size: 22px; font-weight: 600; letter-spacing: -.02em; }
.welcome-sub { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.55; }
.welcome-legend { display: flex; gap: 16px; margin: 4px 0; flex-wrap: wrap; justify-content: center; }
.welcome-legend .lg { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--muted-2); }
.welcome-btn { margin-top: 6px; padding: 11px 22px; font-size: 14px; border-radius: 999px; }

/* ---- editor / capture ---- */
.note-card { cursor: pointer; }
.note-card:hover { border-color: var(--hairline); transform: translateY(-2px);
  box-shadow: 0 2px 4px rgba(15,15,20,.05), 0 20px 44px -22px rgba(15,15,20,.28); }
.editor-head { display: flex; align-items: center; gap: 12px; margin: 16px 0 14px; }
.editor-title { margin: 0; font-size: 17px; font-weight: 600; }
.editor { display: flex; flex-direction: column; gap: 14px; max-width: 680px; }
.form-row { display: flex; gap: 12px; }
.form-row .field { flex: 1; }
.field { display: flex; flex-direction: column; gap: 5px; }
.field-lbl { font-size: 11.5px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); font-weight: 600; }
.editor textarea.md { width: 100%; font-family: var(--mono); font-size: 13px; line-height: 1.5; resize: vertical; }
.ev-wrap { display: flex; flex-direction: column; gap: 7px; }
.ev-row { display: flex; gap: 7px; align-items: center; }
.ev-row select { flex: 0 0 168px; }
.ev-row input { flex: 1; min-width: 0; }
.ev-x { width: 32px; height: 32px; flex: 0 0 auto; font-size: 17px; }
.ev-empty { font-size: 12.5px; color: var(--muted); font-style: italic; }
.ev-status { flex: 0 0 auto; font-size: 11px; font-weight: 600; white-space: nowrap; cursor: help;
  min-width: 92px; text-align: right; }
.ev-status.ok { color: var(--ok); }
.ev-status.warn { color: var(--warn); }
.ev-status.bad { color: var(--err); }
.ev-status.muted { color: var(--muted); font-weight: 500; }

/* ---- relaciones manuales en el editor ---- */
.rel-wrap { display: flex; flex-direction: column; gap: 11px; }
.rel-field { display: flex; flex-direction: column; gap: 5px; }
.rel-lbl { font-size: 11.5px; color: var(--muted); }
.rel-deps { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.rel-chip { display: inline-flex; align-items: center; gap: 4px; font-family: var(--mono); font-size: 12px;
  color: var(--text); background: var(--card); border: 1px solid var(--border); border-radius: 999px; padding: 3px 5px 3px 11px; }
.rel-chip-x { width: 18px; height: 18px; padding: 0; font-size: 13px; line-height: 1; border-radius: 50%;
  border: 0; background: transparent; color: var(--muted); cursor: pointer; }
.rel-chip-x:hover { color: var(--err); background: var(--panel); }
.rel-add, .rel-field > select { max-width: 260px; }
.color-preview { display: flex; align-items: center; gap: 10px; padding: 11px 14px; border: 1px solid var(--border);
  border-left: 3px solid var(--c, var(--border)); border-radius: var(--radius); background: var(--card-2); }
.color-preview strong { font-size: 13.5px; }
.cp-reason { font-size: 12px; color: var(--muted); }
.editor-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 4px; }
.scrub-note { font-size: 12px; color: var(--muted); background: var(--card-2); border: 1px solid var(--border); border-radius: 9px; padding: 8px 11px; }

/* ---- revisión (lint) ---- */
.lint-intro { color: var(--muted-2); font-size: 13.5px; margin: 16px 0 0; max-width: 640px; line-height: 1.5; }
.lint-status { font-size: 12px; color: var(--muted); }
.lint-hint { font-size: 12.5px; color: var(--muted); margin: 4px 0 10px; }
.lint-out { display: flex; flex-direction: column; gap: 7px; }
.lint-row { display: flex; gap: 11px; align-items: center; padding: 10px 13px; border: 1px solid var(--border);
  border-left: 3px solid var(--border); border-radius: var(--radius); background: var(--card-2); }
.lint-row.lint-contradiction { border-left-color: var(--err); }
.lint-row.lint-broken_dep, .lint-row.lint-stale { border-left-color: var(--warn); }
.lint-tag { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted-2); flex: 0 0 auto; }
.lint-msg { font-size: 13px; color: var(--text); font-family: var(--mono); }
.lint-redmsg { font-size: 12.5px; color: var(--err); margin-top: 8px; }

/* ---- guard (anti-manipulación) ---- */
.guard-mandate { display: flex; flex-direction: column; gap: 8px; margin: 14px 0 16px; padding: 13px 15px;
  border: 1px solid var(--border); border-radius: var(--radius); background: var(--card-2); }
.guard-mrow { display: flex; align-items: center; gap: 10px; }
.guard-steel-row { margin: 10px 0 0; }
.guard-out { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.guard-card { cursor: default; }
.guard-card:hover { border-color: var(--border); }
.guard-ev { font-family: var(--mono); font-size: 12.5px; color: var(--muted-2); margin-top: 6px;
  padding: 7px 11px; border-left: 2px solid var(--hairline); background: var(--card); border-radius: 0 8px 8px 0; }
.guard-receipt { font-size: 12.5px; margin-top: 7px; padding: 8px 11px; border-radius: 8px;
  border: 1px solid var(--err); color: var(--text); background: color-mix(in srgb, var(--err) 7%, transparent); }
.guard-quest { margin: 8px 0 0; padding-left: 18px; font-size: 12.5px; color: var(--muted-2); }
.guard-quest li { margin: 2px 0; }
.guard-move { font-size: 12.5px; margin-top: 7px; color: var(--text); }
.guard-inoc { font-size: 12.5px; font-style: italic; color: var(--muted); margin-top: 5px; }
.guard-redline { font-size: 13px; color: var(--err); padding: 8px 12px; border: 1px solid var(--err);
  border-radius: var(--radius); background: color-mix(in srgb, var(--err) 6%, transparent); }
.guard-streak { font-size: 12.5px; color: var(--muted-2); }
.guard-steel { display: flex; flex-direction: column; gap: 7px; padding: 13px 15px; margin-top: 4px;
  border: 1px dashed var(--hairline); border-radius: var(--radius); background: var(--card-2); }
.guard-steel-pos { font-size: 13px; font-weight: 600; }
.guard-steel-body { font-size: 13px; line-height: 1.5; color: var(--muted-2); white-space: pre-wrap; }
.guard-steel-test { font-size: 12.5px; color: var(--muted-2); }
.guard-cover { font-size: 11.5px; color: var(--muted); margin-top: 6px; }

/* ---- ajustes modal ---- */
#settingsModal .field { margin-top: 11px; }
.set-status { font-size: 12.5px; color: var(--muted); margin-top: 12px; min-height: 16px; }
.set-status.ok { color: var(--ok); }
.set-status.bad { color: var(--err); }

/* ---- ojito de password: ícono dentro del input, no botón lleno ---- */
.pass-wrap { position: relative; }
.pass-wrap input { width: 100%; padding-right: 40px; }
.pass-toggle { position: absolute; right: 5px; top: 50%; transform: translateY(-50%);
  width: 30px; height: 30px; padding: 0; border: 0; border-radius: 8px; background: transparent;
  color: var(--muted); display: grid; place-items: center; cursor: pointer; }
.pass-toggle:hover { color: var(--text); background: var(--card); }
.pass-toggle svg { width: 18px; height: 18px; }

/* ---- selector dinámico de modelos ---- */
.model-row { display: flex; gap: 8px; }
.model-row input { flex: 1; min-width: 0; }
.model-row .mini { flex: 0 0 auto; white-space: nowrap; }
#setModelSelect { width: 100%; margin-top: 8px; }
.model-hint { font-size: 12px; color: var(--muted); margin-top: 6px; min-height: 15px; line-height: 1.4; }
.model-hint.ok { color: var(--ok); }
.model-hint.bad { color: var(--err); }

/* ============ rediseño de vistas (2026-07-04) ============ */

/* Filtro por color: chips clickeables (Vault y Grafo) */
.cfilter { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.cf { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--muted-2);
  border: 1px solid var(--border); border-radius: 999px; padding: 5px 12px; cursor: pointer;
  background: color-mix(in srgb, var(--c) 9%, var(--panel)); transition: border-color .12s, background .12s, box-shadow .12s; }
.cf:hover { background: color-mix(in srgb, var(--c) 15%, var(--panel)); }
.cf.on { color: var(--text); font-weight: 600; border-color: var(--c);
  background: color-mix(in srgb, var(--c) 18%, var(--panel)); box-shadow: inset 0 0 0 1px var(--c); }
.cf .dot { width: 9px; height: 9px; }

/* Botón toggle tipo pill (archivadas) */
.pilltog { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--muted-2);
  border: 1px solid var(--border); border-radius: 999px; padding: 5px 13px; background: var(--panel); cursor: pointer; transition: all .12s; }
.pilltog:hover { border-color: var(--muted); color: var(--text); }
.pilltog.on { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.vb-spacer { flex: 1 1 auto; }

/* Frescura — estado "todo fresco" */
.fresh-zen { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 40px 20px 30px; }
.fresh-art { margin-bottom: 6px; }
.fresh-zen-h { font-size: 19px; font-weight: 650; color: var(--text); }
.fresh-zen-sub { font-size: 13.5px; color: var(--muted); margin-top: 6px; max-width: 380px; line-height: 1.5; }

/* Guard/Veracidad — caja BLANCA (superficie) con el CAMPO tintado por su color.
   Cada variante define --fieldbg (el tinte del input) y el color del borde izq. */
.gbox { display: flex; flex-direction: column; gap: 8px; margin: 0 0 14px; padding: 14px 16px;
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); border-left-width: 3px; box-shadow: var(--shadow); }
.gbox-lbl { font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--muted-2); }
.gbox textarea, .gbox input { width: 100%; max-width: 100%; box-sizing: border-box; background: var(--fieldbg, var(--card-2)); border-color: var(--border); }
.gbox textarea { resize: vertical; } /* se estira para abajo, nunca a los costados (rompía la caja) */
.gbox textarea:focus, .gbox input:focus { background: var(--fieldbg, var(--bg-2)); }
.gbox-mandate { --fieldbg: color-mix(in srgb, var(--accent) 8%, var(--panel)); border-left-color: var(--accent); }
.gbox-context { --fieldbg: color-mix(in srgb, #5b8def 11%, var(--panel)); border-left-color: color-mix(in srgb, #5b8def 60%, var(--border)); }
.gbox-turn { --fieldbg: color-mix(in srgb, var(--warn) 12%, var(--panel)); border-left-color: color-mix(in srgb, var(--warn) 65%, var(--border)); }
.gbox-xray { --fieldbg: color-mix(in srgb, var(--accent) 8%, var(--panel)); border-left-color: var(--accent); }

/* Veracidad — pills por eje + tarjetas */
.xr-rail { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 0 0 auto; }
.xr-num { font-family: var(--mono); font-size: 10.5px; color: var(--muted); }
.xr-pills { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.xr-pill { font-size: 10.5px; font-weight: 600; letter-spacing: .01em; border-radius: 999px; padding: 3px 9px;
  background: color-mix(in srgb, var(--pc) 13%, var(--panel)); color: var(--pc); border: 1px solid color-mix(in srgb, var(--pc) 32%, var(--border)); }
.xr-ok { --pc: var(--ok); }
.xr-warn { --pc: var(--warn); }
.xr-err { --pc: var(--err); }
.xr-neutral { --pc: var(--muted); }
.xr-overall { padding: 8px 14px; border-radius: 999px; background: color-mix(in srgb, var(--c) 12%, var(--panel));
  border: 1px solid color-mix(in srgb, var(--c) 30%, var(--border)); }

/* Agentes — gestor de instrucciones */
.agt-tabs { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 16px 0 12px; }
.agt-tab { position: relative; font-family: var(--mono); font-size: 12.5px; color: var(--muted-2); cursor: pointer;
  background: var(--panel); border: 1px solid var(--border); border-radius: 8px; padding: 6px 12px; transition: all .12s; }
.agt-tab:hover { border-color: var(--muted); color: var(--text); }
.agt-tab.on { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.agt-tab.saved:not(.on)::after { content: "●"; color: var(--ok); font-size: 8px; margin-left: 7px; vertical-align: middle; }
.agt-new { font-family: inherit; border-style: dashed; color: var(--muted); }
.agt-editor { width: 100%; font-size: 12.5px; line-height: 1.55; resize: vertical; min-height: 340px; }
.agt-bar { display: flex; gap: 8px; align-items: center; margin: 10px 0; flex-wrap: wrap; }
.agt-ins { display: flex; gap: 8px; align-items: center; margin: 0 0 12px; }
.agt-ins.hidden { display: none; }
.agt-ins input { flex: 1; min-width: 200px; }
.agt-hist { margin-top: 8px; border-top: 1px solid var(--hairline); padding-top: 12px; }
.agt-hist-lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin-bottom: 8px; }
.agt-hist-row { display: flex; align-items: center; gap: 12px; padding: 7px 0; font-size: 12.5px; color: var(--muted-2); }
.agt-hist-t { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.agt-hist-row .nc-act { margin-left: auto; }
