/* ════════════════════════════════════════════════════════════════════════
   Vistas adicionales: Banco (biblioteca), Tablero (kanban), Calendario.
   Usa las variables del design system de styles.css.
   ════════════════════════════════════════════════════════════════════════ */

/* ---- utilidades menores ---- */
.mb-3{margin-bottom:12px}

/* ════════ BANCO / BIBLIOTECA ════════ */
.bk-chip{display:inline-block;font-family:var(--mono);font-size:11px;color:var(--ink-2);
  background:var(--bg-subtle);border:1px solid var(--line);border-radius:999px;padding:3px 10px;margin:3px 4px 3px 0}
.bk-firma{font-family:var(--mono);font-size:12px;color:var(--accent-text);background:var(--accent-soft);
  border:1px solid var(--accent);border-radius:var(--radius-sm);padding:8px 12px;display:inline-block}
.bk-ul,.bk-ol{margin:0;padding-left:18px;line-height:1.7;font-size:13.5px;color:var(--ink-2)}
.bk-ul li,.bk-ol li{margin:2px 0}
.bk-b{font-weight:800;color:var(--ink)}
.bk-grid-kv{display:grid;grid-template-columns:1fr 1fr;gap:12px 22px}
.bk-grid-kv > div{font-size:13px;color:var(--ink-2);line-height:1.5}
.bk-k{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.bk-3preg{border-top:1px solid var(--line-soft);padding-top:14px}

.bk-table-wrap{overflow-x:auto}
.bk-table{width:100%;border-collapse:collapse;font-size:13px}
.bk-table th{text-align:left;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);font-weight:700;padding:0 12px 8px 0;border-bottom:1px solid var(--line)}
.bk-table td{padding:9px 12px 9px 0;border-bottom:1px solid var(--line-soft);vertical-align:top;color:var(--ink-2);line-height:1.45}

.bk-obj{background:var(--bg);border:1px solid var(--line);border-left:3px solid var(--accent-text);
  border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:10px}
.bk-obj-q{font-weight:800;color:var(--ink);font-size:14px;margin-bottom:5px}
.bk-obj-a{font-size:13px;color:var(--ink-2);line-height:1.55}
.bk-pal{display:inline-block;margin-top:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  color:var(--accent-deep);background:var(--accent-soft);border-radius:4px;padding:2px 8px}

.bk-guion{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden;background:var(--bg)}
.bk-guion-head{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:12px 14px;
  display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:14px;color:var(--ink);font-family:var(--sans)}
.bk-guion-head:hover{background:var(--bg-soft)}
.bk-guion-caret{color:var(--muted);font-size:12px}
.bk-guion-body{padding:0 16px 16px;font-size:13.5px;line-height:1.65;color:var(--ink-2);white-space:pre-wrap;border-top:1px solid var(--line-soft)}
.bk-arch-mes{margin-bottom:14px}
.bk-arch-list{margin-top:6px}

/* ════════ TABLERO / KANBAN ════════ */
.kb-board{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px;align-items:flex-start}
.kb-col{flex:0 0 250px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-md);padding:10px}
.kb-col-head{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.04em;color:var(--ink-2);text-transform:uppercase;padding:4px 4px 10px}
.kb-dot{width:9px;height:9px;border-radius:50%;flex:none}
.kb-count{margin-left:auto;background:var(--bg-subtle);border:1px solid var(--line);border-radius:999px;
  font-size:10px;padding:1px 8px;color:var(--muted)}
.kb-col-body{display:flex;flex-direction:column;gap:9px;min-height:30px}
.kb-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px;cursor:pointer;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast)}
.kb-card:hover{border-color:var(--accent-text);box-shadow:0 4px 12px rgba(37,99,235,.08);transform:translateY(-1px)}
.kb-fecha{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.kb-tipo{font-weight:800;color:var(--ink);font-size:13px;margin-top:4px;line-height:1.25}
.kb-snip{font-size:12px;color:var(--ink-3);line-height:1.45;margin-top:5px}
.kb-card-foot{margin-top:9px}
.kb-empty{color:var(--muted);text-align:center;font-size:12px;padding:14px 0}

/* ════════ CALENDARIO ════════ */
.cal-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.cal-title{font-size:18px;color:var(--ink);text-transform:capitalize;min-width:160px;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-head-row{margin-bottom:6px}
.cal-dow{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--muted);text-align:center;padding:4px 0;font-weight:700}
.cal-cell{min-height:88px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:7px 8px;background:var(--bg);
  cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);display:flex;flex-direction:column;gap:5px}
.cal-cell:hover{border-color:var(--accent-text);background:var(--accent-soft)}
.cal-empty{background:transparent;border:1px dashed var(--line-soft);cursor:default}
.cal-empty:hover{border-color:var(--line-soft);background:transparent}
.cal-num{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--ink-2)}
.cal-hoy{border-color:var(--accent-text);box-shadow:0 0 0 2px var(--accent)}
.cal-hoy-tag{font-size:8.5px;color:var(--accent-text);letter-spacing:.06em}
.cal-has{background:var(--bg-soft)}
.cal-ev{display:flex;align-items:center;gap:5px;background:color-mix(in srgb,var(--sc) 12%,white);
  border:1px solid color-mix(in srgb,var(--sc) 35%,white);border-radius:5px;padding:3px 6px}
.cal-ev-dot{width:7px;height:7px;border-radius:50%;background:var(--sc);flex:none}
.cal-ev-txt{font-size:10.5px;color:var(--ink-2);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.cal-sug{font-size:10px;opacity:.55}

/* ---- responsive ---- */
@media (max-width:720px){
  .bk-grid-kv{grid-template-columns:1fr}
  .cal-cell{min-height:62px;padding:5px}
  .cal-sug{display:none}
  .cal-ev-txt{font-size:9px}
}

/* ════════ EJEMPLO VISUAL (mockups) — versión más clara ════════ */
.mock-section{margin-top:22px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-md);padding:16px 18px}
.mock-section-title{font-family:var(--sans);font-size:14px;font-weight:800;letter-spacing:-.01em;color:var(--ink);text-transform:none;margin-bottom:2px}
.mock-section-sub{font-size:12px;color:var(--ink-3);line-height:1.45;margin-bottom:14px}
.mock-row{gap:20px}
/* teléfono más grande y legible */
.mock-frame{width:212px !important}
.mock-content{padding:24px 16px 12px !important}
.mock-content>span{font-size:13px !important;line-height:1.4 !important;-webkit-line-clamp:12 !important;white-space:pre-line}
.mock-label{font-size:10px;color:var(--ink-3);margin-top:9px;font-weight:700}
/* CTA de palabra clave, más visible */
.mock-cta{font-size:9.5px !important;font-weight:700 !important;opacity:1 !important;background:rgba(255,255,255,.22);
  margin:0 12px 12px;padding:6px 8px !important;border-radius:999px;border:1px solid rgba(255,255,255,.4)}
/* nota comentada bajo los teléfonos */
.mock-note{margin-top:16px;border-top:1px dashed var(--line);padding-top:14px;display:flex;flex-direction:column;gap:9px}
.mock-note-item{display:flex;gap:10px;align-items:baseline;flex-wrap:wrap}
.mock-note-k{flex:none;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;
  color:var(--accent-deep);background:var(--accent-soft);border:1px solid var(--accent);border-radius:4px;padding:2px 8px}
.mock-note-v{font-size:13px;color:var(--ink-2);line-height:1.5}
@media (max-width:640px){.mock-frame{width:170px !important}.mock-content>span{font-size:12px !important}}

/* frases del magnet (historia maestra) */
.bk-mag-frases{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}
.bk-mag-frase{font-family:var(--mono);font-size:12px;color:var(--accent-deep);background:var(--accent-soft);
  border-left:3px solid var(--accent-text);border-radius:0 5px 5px 0;padding:6px 10px}

/* documento completo dentro del magnet */
.bk-doc-wrap{border-top:1px dashed var(--line);padding-top:14px}
.bk-doc-toggle{width:100%;text-align:left;background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius-sm);
  cursor:pointer;padding:11px 14px;display:flex;justify-content:space-between;align-items:center;gap:10px;
  font-size:14px;color:var(--ink);font-family:var(--sans)}
.bk-doc-toggle:hover{background:var(--accent)}
.bk-doc{margin-top:12px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:6px 16px;background:var(--bg);
  max-height:560px;overflow-y:auto}
.bk-doc-sec{padding:14px 0;border-bottom:1px solid var(--line-soft)}
.bk-doc-sec:last-child{border-bottom:none}
.bk-doc-h{font-weight:800;color:var(--ink);font-size:14px;display:flex;align-items:center;gap:9px;margin-bottom:6px}
.bk-doc-n{flex:none;width:20px;height:20px;border-radius:50%;background:var(--accent-text);color:#fff;
  font-family:var(--mono);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.bk-doc-c{font-size:13.5px;line-height:1.7;color:var(--ink-2)}
