/* ─────────────────────────────────────────────────────────────
   ClaudioBot v2 — estilos para Paquetes D · E · F
   ───────────────────────────────────────────────────────────── */

/* ════════════════════════════════════════════════════════════
   D-1 · Chat IA
   ════════════════════════════════════════════════════════════ */
.cb-chatia__layout { display: grid; grid-template-columns: 1fr 360px; gap: var(--cb-space-4); height: calc(100vh - 240px); min-height: 540px; }
@media (max-width: 1180px) { .cb-chatia__layout { grid-template-columns: 1fr; height: auto; } }
.cb-chatia__main { display: flex; flex-direction: column; min-height: 0; }
.cb-chatia__msgs { flex: 1; overflow-y: auto; padding: 18px 22px; display: flex; flex-direction: column; gap: 14px; }
.cb-chatia__inputbar { border-top: 1px solid var(--cb-line); padding: 12px 14px; display: flex; flex-direction: column; gap: 10px; background: color-mix(in oklch, var(--cb-bg-2) 50%, transparent); }
.cb-chatia__input { display: flex; align-items: center; gap: 10px; padding: 8px 12px; background: var(--cb-bg-2); border: 1px solid var(--cb-line-strong); border-radius: 10px; }
.cb-chatia__input svg { color: var(--cb-accent); flex-shrink: 0; }
.cb-chatia__input input { flex: 1; background: transparent; border: none; outline: none; color: var(--cb-text); font-size: 13.5px; min-width: 0; }
.cb-chatia__quicks { display: flex; gap: 6px; flex-wrap: wrap; }
.cb-chatia__side { display: flex; flex-direction: column; gap: var(--cb-space-4); overflow-y: auto; }

.cb-chatmsg { display: flex; gap: 10px; }
.cb-chatmsg--user { justify-content: flex-end; }
.cb-chatmsg--user .cb-chatmsg__bubble { max-width: 72%; padding: 10px 14px; background: var(--cb-accent); color: var(--cb-accent-ink); border-radius: 14px 14px 4px 14px; font-size: 13px; }
.cb-chatmsg--bot { align-items: flex-start; }
.cb-chatmsg__avi { width: 32px; height: 32px; display: grid; place-items: center; background: var(--cb-bg-2); border: 1px solid color-mix(in oklch, var(--cb-accent) 30%, transparent); border-radius: 10px; color: var(--cb-accent); flex-shrink: 0; }
.cb-chatmsg__body { flex: 1; min-width: 0; max-width: 80%; }
.cb-chatmsg__head { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--cb-text-3); margin-bottom: 4px; }
.cb-chatmsg__head strong { color: var(--cb-text); font-size: 12.5px; }
.cb-chatmsg__time { font-family: var(--cb-font-mono); font-size: 10.5px; color: var(--cb-text-3); }
.cb-chatmsg__bubble--bot { padding: 12px 14px; background: var(--cb-bg-2); border: 1px solid var(--cb-line); border-radius: 4px 14px 14px 14px; font-size: 13px; line-height: 1.6; }
.cb-chatmsg__bubble--bot div { margin-bottom: 4px; }
.cb-chatmsg__bubble--bot div:last-child { margin-bottom: 0; }
.cb-chatmsg__cites { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.cb-chatmsg__feedback { display: flex; gap: 4px; margin-top: 6px; }
.cb-chatmsg__fb { display: inline-flex; align-items: center; gap: 4px; padding: 3px 8px; background: transparent; border: 1px solid var(--cb-line); border-radius: 6px; font-size: 10.5px; color: var(--cb-text-3); }
.cb-chatmsg__fb:hover { background: var(--cb-bg-2); color: var(--cb-text); }
.cb-chatmsg--tools { padding-left: 42px; }
.cb-chatmsg__tools { display: inline-flex; align-items: center; gap: 8px; padding: 5px 10px; background: color-mix(in oklch, var(--cb-accent) 8%, var(--cb-bg-2)); border: 1px solid color-mix(in oklch, var(--cb-accent) 22%, transparent); border-radius: 6px; font-size: 11px; color: var(--cb-text-2); }
.cb-chatmsg__tools svg { color: var(--cb-good); }
.cb-chatmsg__det { color: var(--cb-text-3); font-size: 10.5px; }
.cb-chatmsg__loader { width: 10px; height: 10px; border: 2px solid var(--cb-line); border-top-color: var(--cb-accent); border-radius: 50%; animation: cb-spin 0.7s linear infinite; }

.cb-toolslist { display: flex; flex-direction: column; gap: 2px; max-height: 280px; overflow-y: auto; padding: 2px; }
.cb-toolrow { display: grid; grid-template-columns: 18px 14px 1fr auto; align-items: center; gap: 8px; padding: 6px 8px; border-radius: 6px; }
.cb-toolrow:hover { background: var(--cb-bg-2); }
.cb-toolrow__num { font-size: 10px; color: var(--cb-text-4); }
.cb-toolrow svg { color: var(--cb-accent); }
.cb-toolrow__n { font-size: 11.5px; color: var(--cb-text); font-weight: 500; }
.cb-toolrow__d { font-size: 10.5px; color: var(--cb-text-3); line-height: 1.35; }

.cb-rag { display: flex; flex-direction: column; gap: 8px; }
.cb-rag__row { padding: 8px 10px; background: var(--cb-bg-2); border-radius: 6px; }
.cb-rag__head { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.cb-rag__q { font-size: 12px; }
.cb-rag__meta { font-size: 10.5px; color: var(--cb-text-3); display: flex; align-items: center; gap: 5px; margin-top: 2px; }
.cb-rag__corr { font-size: 11px; color: var(--cb-warn); margin-top: 6px; display: flex; align-items: flex-start; gap: 4px; line-height: 1.4; }
.cb-rag__corr svg { margin-top: 2px; flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════
   D-2 · WhatsApp
   ════════════════════════════════════════════════════════════ */
.cb-wa-layout { display: grid; grid-template-columns: 340px 1fr 300px; gap: var(--cb-space-4); height: calc(100vh - 320px); min-height: 480px; }
@media (max-width: 1280px) { .cb-wa-layout { grid-template-columns: 320px 1fr; } .cb-wa-layout__side { display: none; } }
@media (max-width: 900px)  { .cb-wa-layout { grid-template-columns: 1fr; height: auto; } }
.cb-wa-layout__list { overflow: hidden; }
.cb-wa-layout__chat { overflow: hidden; display: flex; flex-direction: column; }
.cb-wa-layout__chat .cb-card__body { display: none; }
.cb-wa-layout__chat .cb-wa { padding: 14px 16px; flex: 1; overflow-y: auto; background: var(--cb-bg-2); }
.cb-wa-input { display: flex; gap: 8px; padding: 10px 12px; border-top: 1px solid var(--cb-line); background: var(--cb-bg-2); }
.cb-wa-input__txt { flex: 1; height: 34px; }
.cb-wa-layout__side { overflow-y: auto; }

.cb-wachats { display: flex; flex-direction: column; max-height: 100%; overflow-y: auto; }
.cb-wachat { display: flex; gap: 10px; padding: 12px 14px; background: transparent; border: none; border-bottom: 1px solid var(--cb-line); border-left: 3px solid transparent; text-align: left; color: var(--cb-text); }
.cb-wachat:hover { background: var(--cb-bg-2); }
.cb-wachat.is-active { background: var(--cb-bg-2); border-left-color: var(--cb-accent); }
.cb-wachat__avi { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; flex-shrink: 0; color: white; }
.cb-wachat__avi--obra { background: linear-gradient(135deg, oklch(0.5 0.12 140), oklch(0.32 0.1 140)); }
.cb-wachat__avi--interno { background: linear-gradient(135deg, oklch(0.5 0.1 220), oklch(0.32 0.08 220)); }
.cb-wachat__avi--cliente { background: linear-gradient(135deg, oklch(0.5 0.12 60), oklch(0.32 0.1 60)); }
.cb-wachat__avi--jefeobra { background: linear-gradient(135deg, oklch(0.5 0.14 320), oklch(0.32 0.1 320)); }
.cb-wachat__body { flex: 1; min-width: 0; }
.cb-wachat__head { display: flex; justify-content: space-between; align-items: center; }
.cb-wachat__n { font-size: 12.5px; font-weight: 600; }
.cb-wachat__un { min-width: 18px; height: 18px; padding: 0 5px; background: var(--cb-accent); color: var(--cb-accent-ink); border-radius: 9px; font-size: 10px; font-weight: 700; display: grid; place-items: center; }
.cb-wachat__last { font-size: 11px; color: var(--cb-text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin: 3px 0; }
.cb-wachat__meta { display: flex; align-items: center; gap: 6px; font-size: 10.5px; color: var(--cb-text-3); }
.cb-wa__author { font-size: 10.5px; font-weight: 600; color: var(--cb-accent); margin-bottom: 2px; }
.cb-wa__time { font-size: 9.5px; color: var(--cb-text-3); margin-top: 4px; font-family: var(--cb-font-mono); }
.cb-wa__photo { background: linear-gradient(135deg, #2a3140, #14181f); border-radius: 8px; display: grid; place-items: center; height: 80px; }
.cb-wa__cap { font-size: 10.5px; color: var(--cb-text-3); margin-top: 4px; font-family: var(--cb-font-mono); }

.cb-cmdlist { display: flex; flex-direction: column; gap: 4px; }
.cb-cmdrow { display: flex; gap: 8px; align-items: flex-start; padding: 6px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-cmdrow:last-child { border-bottom: none; }
.cb-cmdrow__cmd { font-family: var(--cb-font-mono); font-size: 10.5px; padding: 1px 6px; background: color-mix(in oklch, var(--cb-accent) 12%, var(--cb-bg-2)); color: var(--cb-accent); border-radius: 4px; white-space: nowrap; flex-shrink: 0; }
.cb-cmdrow__d { font-size: 11px; color: var(--cb-text-2); }

/* ════════════════════════════════════════════════════════════
   D-3 · System status
   ════════════════════════════════════════════════════════════ */
.cb-conex { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-conex:last-child { border-bottom: none; }
.cb-conex__ico { width: 32px; height: 32px; display: grid; place-items: center; background: var(--cb-bg-2); border: 1px solid var(--cb-line); border-radius: 8px; }
.cb-conex__ico.is-ok { color: var(--cb-good); border-color: color-mix(in oklch, var(--cb-good) 30%, transparent); }
.cb-conex__ico.is-warn { color: var(--cb-warn); border-color: color-mix(in oklch, var(--cb-warn) 30%, transparent); }
.cb-conex__ico.is-idle { color: var(--cb-text-4); }
.cb-conex__ico.is-error { color: var(--cb-danger); border-color: color-mix(in oklch, var(--cb-danger) 30%, transparent); }
.cb-conex__body { flex: 1; min-width: 0; }
.cb-conex__n { font-size: 12.5px; font-weight: 500; }
.cb-conex__d { font-size: 11px; color: var(--cb-text-3); }

/* ════════════════════════════════════════════════════════════
   D-4 · Insights IA
   ════════════════════════════════════════════════════════════ */
.cb-pred { display: flex; flex-direction: column; gap: 6px; }
.cb-pred__head { display: flex; align-items: center; justify-content: space-between; }
.cb-pred__obra { font-size: 11px; color: var(--cb-text-3); }
.cb-pred__tipo { font-size: 13px; font-weight: 600; }
.cb-pred__cuando { font-family: var(--cb-font-mono); font-size: 12px; color: var(--cb-accent); }
.cb-pred__txt { font-size: 12px; color: var(--cb-text-2); line-height: 1.5; }
.cb-pred__bar { height: 4px; background: var(--cb-line); border-radius: 3px; overflow: hidden; margin-top: 6px; }
.cb-pred__bar > div { height: 100%; background: linear-gradient(90deg, var(--cb-info), var(--cb-accent)); border-radius: 3px; }

.cb-graphwrap { background: var(--cb-bg-2); border-radius: 8px; padding: 20px; }
.cb-graph { width: 100%; height: 400px; max-height: 50vh; }
.cb-graph__legend { display: flex; gap: 16px; justify-content: center; margin-top: 10px; font-size: 11px; color: var(--cb-text-3); flex-wrap: wrap; }
.cb-graph__legend span { display: flex; align-items: center; gap: 5px; }
.cb-graph__dot { width: 10px; height: 10px; border-radius: 50%; }

/* ════════════════════════════════════════════════════════════
   D-5/6/7/8 · Tools
   ════════════════════════════════════════════════════════════ */
.cb-comp__heads { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: center; }
.cb-comp__vs { font-family: var(--cb-font-mono); font-size: 14px; font-weight: 700; color: var(--cb-text-3); text-align: center; }
.cb-comp__hd { display: flex; align-items: center; gap: 10px; }
.cb-comp__hd svg { color: var(--cb-accent); }
.cb-comp__t { font-size: 13px; font-weight: 600; }
.cb-comp__sub { font-size: 11px; color: var(--cb-text-3); }

.cb-grid--ocr { grid-template-columns: 360px 1fr; }
@media (max-width: 980px) { .cb-grid--ocr { grid-template-columns: 1fr; } }
.cb-ocrimg { position: relative; min-height: 280px; background: var(--cb-bg-2); border: 1px dashed var(--cb-line-strong); border-radius: 10px; overflow: hidden; }
.cb-ocrimg__inner { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; min-height: 280px; gap: 10px; color: var(--cb-text-3); }
.cb-ocrimg__name { font-size: 11px; }
.cb-ocrimg__overlay { position: absolute; inset: 0; pointer-events: none; }
.cb-ocrimg__box { position: absolute; height: 12%; border: 1.5px solid color-mix(in oklch, var(--cb-accent) 55%, transparent); border-radius: 3px; background: color-mix(in oklch, var(--cb-accent) 5%, transparent); animation: cb-ocrpulse 2.4s ease-in-out infinite; }
.cb-ocrimg__box:nth-child(odd) { animation-delay: -0.6s; }
@keyframes cb-ocrpulse { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
.cb-ocrimg__meta { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; }

.cb-grid--maps { grid-template-columns: 1.2fr 1fr; }
@media (max-width: 980px) { .cb-grid--maps { grid-template-columns: 1fr; } }
.cb-mapbox { padding: 14px; }
.cb-mapbox__svg { width: 100%; max-height: 380px; }

.cb-tip { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: color-mix(in oklch, var(--cb-info) 8%, var(--cb-surf)); border: 1px solid color-mix(in oklch, var(--cb-info) 22%, transparent); border-radius: 8px; font-size: 12px; }
.cb-tip svg { color: var(--cb-info); flex-shrink: 0; }
.cb-tip code { font-family: var(--cb-font-mono); font-size: 11px; padding: 1px 6px; background: var(--cb-bg-2); border: 1px solid var(--cb-line); border-radius: 4px; }

/* ════════════════════════════════════════════════════════════
   E-1 · Vista madre de obra
   ════════════════════════════════════════════════════════════ */
.cb-obra-hero { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; padding: 18px; background: linear-gradient(135deg, color-mix(in oklch, var(--cb-accent) 10%, var(--cb-surf)) 0%, var(--cb-surf) 100%); border: 1px solid color-mix(in oklch, var(--cb-accent) 22%, var(--cb-line)); border-radius: 14px; }
@media (max-width: 900px) { .cb-obra-hero { grid-template-columns: repeat(2, 1fr); } }
.cb-obra-hero__cell { display: flex; flex-direction: column; gap: 6px; }
.cb-obra-hero__lbl { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cb-text-3); }
.cb-obra-hero__bar { height: 8px; background: var(--cb-bg-2); border-radius: 4px; overflow: hidden; }
.cb-obra-hero__bar > div { height: 100%; background: linear-gradient(90deg, var(--cb-accent), var(--cb-accent-2)); border-radius: 4px; }
.cb-obra-hero__bar--info > div { background: linear-gradient(90deg, var(--cb-info), var(--cb-accent)); }
.cb-obra-hero__val { font-family: var(--cb-font-mono); font-size: 22px; font-weight: 600; color: var(--cb-accent); }
.cb-obra-hero__big { font-size: 19px; font-weight: 600; color: var(--cb-text); }

.cb-kv { display: flex; flex-direction: column; }
.cb-kv > div { display: flex; justify-content: space-between; padding: 7px 0; font-size: 12px; border-bottom: 1px dashed var(--cb-line); }
.cb-kv > div:last-child { border-bottom: none; }
.cb-kv > div > span { color: var(--cb-text-3); }
.cb-kv strong { color: var(--cb-text); font-weight: 500; }

.cb-obra-loc { font-size: 12.5px; color: var(--cb-text); margin-bottom: 10px; }
.cb-obra-loc__mini { background: var(--cb-bg-2); border-radius: 8px; overflow: hidden; height: 130px; }
.cb-obra-loc__mini svg { width: 100%; height: 100%; }
.cb-obra-loc__coords { font-size: 11px; margin-top: 6px; text-align: right; }

.cb-obra-eq { display: flex; gap: 12px; align-items: center; padding: 8px 0; }
.cb-obra-eq__n { font-size: 13px; font-weight: 600; }
.cb-obra-eq__r { font-size: 11px; color: var(--cb-text-3); }
.cb-obra-eq__m { font-size: 11px; color: var(--cb-text-2); margin-top: 2px; }
.cb-obra-eq__m.cb-warn { color: var(--cb-warn); }
.cb-obra-eq__list { display: flex; flex-direction: column; gap: 8px; }
.cb-obra-eq__row { display: flex; align-items: center; gap: 8px; font-size: 12.5px; }
.cb-obra-eq__row > span { flex: 1; }

.cb-obra-photos { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
@media (max-width: 880px) { .cb-obra-photos { grid-template-columns: repeat(2, 1fr); } }
.cb-obra-photo { aspect-ratio: 1; padding: 10px; border-radius: 8px; display: flex; flex-direction: column; justify-content: space-between; color: var(--cb-text); position: relative; overflow: hidden; }
.cb-obra-photo.tone-0 { background: linear-gradient(135deg, #6E4A2E, #1a1410); }
.cb-obra-photo.tone-1 { background: linear-gradient(135deg, #2D5F4A, #0e1814); }
.cb-obra-photo.tone-2 { background: linear-gradient(135deg, #4A4E6E, #14161f); }
.cb-obra-photo.tone-3 { background: linear-gradient(135deg, #6E2E5F, #1a0e17); }
.cb-obra-photo__cap { font-size: 10.5px; opacity: 0.85; }

/* ════════════════════════════════════════════════════════════
   E-2 · Dashboard Jefe de Obra
   ════════════════════════════════════════════════════════════ */
.cb-jo-banner { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; margin-bottom: var(--cb-space-4); background: linear-gradient(90deg, color-mix(in oklch, var(--cb-good) 14%, var(--cb-surf)) 0%, var(--cb-surf) 100%); border: 1px solid color-mix(in oklch, var(--cb-good) 25%, var(--cb-line)); border-radius: 12px; }
.cb-jo-banner__k { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cb-good); font-weight: 600; }
.cb-jo-banner__t { font-size: 17px; font-weight: 600; margin: 4px 0 0; letter-spacing: -0.02em; }
.cb-jo-tasks { display: flex; flex-direction: column; gap: 6px; }
.cb-jo-task { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--cb-bg-2); border: 1px solid var(--cb-line); border-radius: 8px; }
.cb-jo-task.is-alta { border-color: color-mix(in oklch, var(--cb-danger) 25%, var(--cb-line)); background: color-mix(in oklch, var(--cb-danger) 4%, var(--cb-bg-2)); }
.cb-jo-task.is-media { background: color-mix(in oklch, var(--cb-warn) 3%, var(--cb-bg-2)); }
.cb-jo-task > div:nth-child(2) { flex: 1; }
.cb-jo-task__t { font-size: 13px; font-weight: 500; }
.cb-jo-task__m { font-size: 11px; color: var(--cb-text-3); margin-top: 2px; }
.cb-jo-task > svg { color: var(--cb-accent); flex-shrink: 0; }
.cb-jo-team { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
@media (max-width: 760px) { .cb-jo-team { grid-template-columns: 1fr; } }
.cb-jo-tm { display: flex; gap: 10px; align-items: center; padding: 8px; background: var(--cb-bg-2); border-radius: 8px; }
.cb-jo-tm__b { flex: 1; }
.cb-jo-tm__n { font-size: 12.5px; font-weight: 500; }
.cb-jo-tm__r { font-size: 11px; color: var(--cb-text-3); }
.cb-jo-mat { display: flex; flex-direction: column; }
.cb-jo-mat__row { display: grid; grid-template-columns: 100px 1fr auto; gap: 12px; align-items: center; padding: 8px 0; font-size: 12.5px; border-bottom: 1px dashed var(--cb-line); }
.cb-jo-mat__row:last-child { border-bottom: none; }
.cb-jo-mat__row span:first-child { color: var(--cb-text-3); }
.cb-jo-acts { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.cb-jo-act { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 18px; background: var(--cb-bg-2); border: 1px solid var(--cb-line); border-radius: 12px; color: var(--cb-text); font-size: 12px; font-weight: 500; }
.cb-jo-act:hover { background: color-mix(in oklch, var(--cb-accent) 8%, var(--cb-bg-2)); border-color: var(--cb-accent); }
.cb-jo-act svg { color: var(--cb-accent); }

/* ════════════════════════════════════════════════════════════
   E-3 · Bandeja de firmas
   ════════════════════════════════════════════════════════════ */
.cb-firmas__cta { display: flex; gap: 6px; }

/* ════════════════════════════════════════════════════════════
   E-4 · Versiones de cómputo
   ════════════════════════════════════════════════════════════ */
.cb-cv { display: flex; flex-direction: column; }
.cb-cv__row { display: grid; grid-template-columns: 80px 30px 1fr auto; align-items: flex-start; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--cb-line); }
.cb-cv__row:last-child { border-bottom: none; }
.cb-cv__row.is-current { background: color-mix(in oklch, var(--cb-accent) 4%, transparent); }
.cb-cv__v { display: flex; flex-direction: column; gap: 4px; align-items: flex-start; }
.cb-cv__vno { font-size: 13px; font-weight: 600; color: var(--cb-accent); }
.cb-cv__line { position: relative; display: flex; flex-direction: column; align-items: center; height: 100%; }
.cb-cv__dot { width: 10px; height: 10px; border-radius: 50%; background: var(--cb-accent); border: 2px solid var(--cb-surf); margin-top: 6px; flex-shrink: 0; z-index: 2; }
.cb-cv__row:not(.is-current) .cb-cv__dot { background: var(--cb-line-strong); }
.cb-cv__rail { position: absolute; top: 18px; bottom: -14px; left: 50%; width: 1.5px; background: var(--cb-line); transform: translateX(-50%); }
.cb-cv__body { flex: 1; min-width: 0; }
.cb-cv__head { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--cb-text-3); margin-bottom: 4px; }
.cb-cv__delta { font-family: var(--cb-font-mono); margin-left: auto; padding: 1px 6px; border-radius: 4px; font-weight: 600; font-size: 11px; }
.cb-cv__delta.is-up { background: color-mix(in oklch, var(--cb-good) 14%, transparent); color: var(--cb-good); }
.cb-cv__delta.is-down { background: color-mix(in oklch, var(--cb-danger) 14%, transparent); color: var(--cb-danger); }
.cb-cv__delta.is-neutral { background: var(--cb-line); color: var(--cb-text-3); }
.cb-cv__cambios { font-size: 12.5px; color: var(--cb-text); }
.cb-cv__monto { font-size: 11px; color: var(--cb-text-3); margin-top: 2px; }
.cb-cv__cta { display: flex; gap: 6px; }

/* ════════════════════════════════════════════════════════════
   F-1 · Portal cliente
   ════════════════════════════════════════════════════════════ */
.cb-port-acc { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px dashed var(--cb-line); }
.cb-port-acc:last-child { border-bottom: none; }
.cb-port-acc__b { flex: 1; }
.cb-port-acc__n { font-size: 12.5px; font-weight: 500; }
.cb-port-acc__r { font-size: 11px; color: var(--cb-text-3); }
.cb-port-acc__ult { font-size: 10.5px; color: var(--cb-text-3); }
.cb-port-items { display: flex; flex-direction: column; gap: 6px; }
.cb-port-it { display: flex; align-items: center; gap: 8px; padding: 6px 0; font-size: 12px; border-bottom: 1px dashed var(--cb-line); }
.cb-port-it:last-child { border-bottom: none; }
.cb-port-it__t { flex: 1; }
.cb-port-it__f { font-size: 10.5px; color: var(--cb-text-3); }
.cb-port-no { display: flex; flex-direction: column; gap: 6px; }
.cb-port-no > div { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--cb-text-2); padding: 4px 0; }
.cb-port-no svg { color: var(--cb-danger); }
.cb-cliview { background: var(--cb-bg); border: 1px solid var(--cb-line); border-radius: 12px; padding: 16px; }
.cb-cliview__bar { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--cb-text-2); padding-bottom: 14px; border-bottom: 1px solid var(--cb-line); margin-bottom: 14px; }
.cb-cliview__bar svg { color: var(--cb-info); }
.cb-cliview__cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 760px) { .cb-cliview__cards { grid-template-columns: repeat(2, 1fr); } }
.cb-cliview__card { padding: 14px 16px; background: var(--cb-surf); border: 1px solid var(--cb-line); border-radius: 10px; }
.cb-cliview__lbl { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cb-text-3); font-weight: 600; }
.cb-cliview__big { font-size: 26px; font-weight: 700; font-family: var(--cb-font-mono); margin: 4px 0 2px; color: var(--cb-accent); }
.cb-cliview__sub { font-size: 11px; color: var(--cb-text-3); }

/* ════════════════════════════════════════════════════════════
   F-2 · Marketplace
   ════════════════════════════════════════════════════════════ */
.cb-mkt-rubros { display: flex; gap: 4px; flex-wrap: wrap; }
.cb-mkt-rate { display: flex; align-items: center; gap: 6px; }
.cb-mkt-stars { color: var(--cb-warn); font-size: 11px; letter-spacing: 1px; }

/* ════════════════════════════════════════════════════════════
   F-3 · ERP
   ════════════════════════════════════════════════════════════ */
.cb-erp-flow { display: flex; align-items: center; justify-content: center; gap: 14px; padding: 20px; flex-wrap: wrap; }
.cb-erp-flow__box { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 16px 20px; min-width: 140px; background: var(--cb-bg-2); border: 1px solid var(--cb-line-strong); border-radius: 12px; text-align: center; }
.cb-erp-flow__box svg { color: var(--cb-accent); margin-bottom: 4px; }
.cb-erp-flow__box > div:nth-child(2) { font-size: 13px; font-weight: 600; }
.cb-erp-flow__sub { font-size: 10.5px; color: var(--cb-text-3); }
.cb-erp-flow__arrow { display: flex; flex-direction: column; align-items: center; gap: 4px; color: var(--cb-text-3); font-size: 10.5px; font-family: var(--cb-font-mono); min-width: 100px; text-align: center; }
.cb-erp-flow__arrow svg { color: var(--cb-accent); }

/* ════════════════════════════════════════════════════════════
   F-4 · App móvil
   ════════════════════════════════════════════════════════════ */
.cb-mobapp { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; justify-items: center; }
@media (max-width: 900px) { .cb-mobapp { grid-template-columns: 1fr; } }
.cb-phone { position: relative; width: 260px; height: 540px; background: #0a0c10; border: 8px solid #1a1f2a; border-radius: 36px; box-shadow: 0 30px 60px rgba(0,0,0,0.5); overflow: hidden; display: flex; flex-direction: column; }
.cb-phone__notch { position: absolute; top: 6px; left: 50%; transform: translateX(-50%); width: 90px; height: 22px; background: #0a0c10; border-radius: 0 0 12px 12px; z-index: 5; }
.cb-phone__statusbar { display: flex; justify-content: space-between; align-items: center; padding: 8px 20px 2px; font-size: 10px; color: var(--cb-text-2); font-family: var(--cb-font-mono); }
.cb-phone__screen { flex: 1; padding: 32px 16px 60px; display: flex; flex-direction: column; gap: 12px; position: relative; }
.cb-phone__tab { position: absolute; bottom: -28px; left: 50%; transform: translateX(-50%); font-size: 11.5px; color: var(--cb-text-3); }

.cb-mob-greet { font-size: 20px; font-weight: 600; }
.cb-mob-sub { font-size: 12px; color: var(--cb-text-3); margin-top: -8px; }
.cb-mob-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 8px; }
.cb-mob-card { padding: 14px; background: var(--cb-bg-2); border: 1px solid var(--cb-line); border-radius: 10px; }
.cb-mob-card--accent { background: color-mix(in oklch, var(--cb-accent) 14%, var(--cb-bg-2)); border-color: color-mix(in oklch, var(--cb-accent) 30%, transparent); }
.cb-mob-card__t { font-size: 22px; font-weight: 700; font-family: var(--cb-font-mono); }
.cb-mob-card__l { font-size: 10.5px; color: var(--cb-text-3); margin-top: 2px; }
.cb-mob-list { display: flex; flex-direction: column; gap: 4px; }
.cb-mob-li { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--cb-bg-2); border-radius: 8px; font-size: 11.5px; }
.cb-mob-li svg { color: var(--cb-accent); flex-shrink: 0; }
.cb-mob-tab { position: absolute; bottom: 0; left: 0; right: 0; display: grid; grid-template-columns: repeat(4, 1fr); padding: 10px 0; background: var(--cb-bg-2); border-top: 1px solid var(--cb-line); }
.cb-mob-tab > div { display: grid; place-items: center; color: var(--cb-text-3); }
.cb-mob-tab > div:first-child { color: var(--cb-accent); }
.cb-mob-cam { background: linear-gradient(135deg, #2a3140, #0a0c10); border-radius: 16px; padding: 30px; margin: 14px 0; flex: 1; display: flex; flex-direction: column; justify-content: space-between; }
.cb-mob-cam__view { flex: 1; display: grid; place-items: center; color: var(--cb-text-3); }
.cb-mob-cam__bar { display: grid; grid-template-columns: 40px 1fr 40px; align-items: center; }
.cb-mob-cam__shut { width: 56px; height: 56px; border-radius: 50%; background: white; border: 4px solid var(--cb-line-strong); justify-self: center; }
.cb-mob-btn { padding: 14px; background: var(--cb-accent); color: var(--cb-accent-ink); border-radius: 10px; text-align: center; font-weight: 600; font-size: 13px; margin-top: auto; }

.cb-dim { color: var(--cb-text-3); }
.cb-warn { color: var(--cb-warn); }

/* Mobile collapse */
@media (max-width: 800px) {
  .cb-chatia__layout { grid-template-columns: 1fr; }
  .cb-comp__heads { grid-template-columns: 1fr; }
  .cb-comp__vs { display: none; }
  .cb-cv__row { grid-template-columns: 60px 18px 1fr; }
  .cb-cv__cta { display: none; }
  .cb-jo-mat__row { grid-template-columns: 1fr; gap: 4px; }
  .cb-erp-flow__arrow { min-width: auto; }
  .cb-firmas__cta { flex-direction: column; }
}
