/* ═══════════════════════════════════════════════════════════════════════════
   comcenter-compositor.css · CC-COMPOSER-V6
   ───────────────────────────────────────────────────────────────────────────
   Tab "Composición" (ex-Plantillas) + modal de envío individual ad-hoc.
   Anclado a tokens canónicos LUZOkit (--lk-*). Marca = morado del sistema.
   Hereda los 3 temas automáticamente vía --lk-*. Sin border-left de acento ·
   glow difuso (box-shadow) · sin emojis · radios LUZOkit · borders 0.5px.
   ═══════════════════════════════════════════════════════════════════════════ */

/* tokens locales del compositor → mapean a los CANÓNICOS --lk-* (verificados
   en lk-tokens.css v2.4). Estos --lk-* ya cambian por [data-theme], así que
   light/dark/midnight funcionan sin redefinir nada. Los fallbacks son los
   valores reales de lk-tokens, no inventados. */
#lz-comcenter-root,
#cc-comp-modal-root {
  --cc-brand:         var(--lk-brand, #6d28d9);
  --cc-brand-soft:    var(--lk-brand-muted, rgba(109,40,217,.15));
  --cc-brand-dim:     var(--lk-brand-border, rgba(109,40,217,.30));
  --cc-panel:         var(--lk-bg-card, #ffffff);
  --cc-sunken:        var(--lk-bg-surface, #f8fafc);
  --cc-hover:         var(--lk-bg-hover, rgba(0,0,0,.05));
  --cc-selected:      var(--lk-bg-selected, #ede9fe);
  --cc-tx:            var(--lk-text-primary, #0f172a);
  --cc-tx-strong:     var(--lk-text-primary, #0f172a);
  --cc-muted:         var(--lk-text-muted, #475569);
  --cc-faint:         var(--lk-text-faint, #94a3b8);
  --cc-border:        var(--lk-border, rgba(0,0,0,.12));
  --cc-border-strong: var(--lk-border, rgba(0,0,0,.12));
  --cc-green:         var(--lk-green, #16a34a);
  --cc-amber:         var(--lk-amber, #d97706);
  --cc-red:           var(--lk-red, #dc2626);
  --cc-overlay:       rgba(15,23,42,.62);
  --cc-shadow:        var(--lk-shadow-lg, 0 24px 64px rgba(0,0,0,.42));
  /* color de marca aplicado dentro del PREVIEW del email (texto/CTA) */
  --cc-email-accent:  var(--lk-brand, #6d28d9);
}
[data-theme="dark"] #lz-comcenter-root,
[data-theme="dark"] #cc-comp-modal-root,
[data-theme="midnight"] #lz-comcenter-root,
[data-theme="midnight"] #cc-comp-modal-root {
  --cc-overlay: rgba(0,0,0,.72);
}

/* ── botón de tab Compositor (ya estilado por .st-toggle-btn del shell) ─── */
#lz-comcenter-root .cc-comp-tabbtn svg { width: 12px; height: 12px; }

/* ── pane Compositor ────────────────────────────────────────────────────── */
#lz-comcenter-root .cc-comp { display: flex; flex-direction: column; height: 100%; gap: 14px; overflow-y: auto; }

#lz-comcenter-root .cc-comp-hero {
  display: flex; align-items: center; gap: 16px;
  background: var(--cc-panel); border: 0.5px solid var(--cc-border);
  border-radius: 10px; padding: 16px 18px;
}
#lz-comcenter-root .cc-comp-hero-t { flex: 1; min-width: 0; }
#lz-comcenter-root .cc-comp-hero-title { font-size: 15px; font-weight: 500; color: var(--cc-tx-strong); }
#lz-comcenter-root .cc-comp-hero-sub { font-size: 12.5px; color: var(--cc-muted); margin-top: 3px; line-height: 1.45; }
#lz-comcenter-root .cc-comp-cta {
  display: inline-flex; align-items: center; gap: 8px; flex-shrink: 0;
  font-size: 13px; font-weight: 500; padding: 9px 16px; border-radius: 10px;
  background: var(--cc-brand); color: #fff; border: none; cursor: pointer;
  transition: filter 0.12s;
}
#lz-comcenter-root .cc-comp-cta:hover { filter: brightness(1.07); }
#lz-comcenter-root .cc-comp-cta svg { width: 14px; height: 14px; }

#lz-comcenter-root .cc-comp-subnav { display: flex; gap: 4px; border-bottom: 0.5px solid var(--cc-border); }
#lz-comcenter-root .cc-comp-subtab {
  font-size: 12.5px; font-weight: 500; padding: 8px 14px; border: none; background: none;
  color: var(--cc-muted); cursor: pointer; border-bottom: 2px solid transparent;
  display: inline-flex; align-items: center; gap: 7px; transition: color 0.12s;
}
#lz-comcenter-root .cc-comp-subtab.is-active { color: var(--cc-brand); border-bottom-color: var(--cc-brand); }
#lz-comcenter-root .cc-comp-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 16px; height: 16px; padding: 0 5px; border-radius: 9px;
  background: var(--cc-brand-soft); color: var(--cc-brand); font-size: 9.5px; font-weight: 500;
}
#lz-comcenter-root .cc-comp-body { flex: 1; min-height: 0; }

/* grid de plantillas */
#lz-comcenter-root .cc-comp-tplgrid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px;
}
#lz-comcenter-root .cc-comp-tplcard {
  display: flex; align-items: center; gap: 11px; padding: 12px;
  background: var(--cc-panel); border: 0.5px solid var(--cc-border); border-radius: 10px;
  cursor: pointer; text-align: left; transition: background 0.12s, border-color 0.12s;
}
#lz-comcenter-root .cc-comp-tplcard:hover { background: var(--cc-hover); border-color: var(--cc-brand-dim); }
#lz-comcenter-root .cc-comp-tplav {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: var(--cc-brand-soft); color: var(--cc-brand);
  display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 500;
}
#lz-comcenter-root .cc-comp-tplinfo { flex: 1; min-width: 0; }
#lz-comcenter-root .cc-comp-tplname { font-size: 13px; font-weight: 500; color: var(--cc-tx); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#lz-comcenter-root .cc-comp-tplslug { font-size: 11px; color: var(--cc-muted); }
#lz-comcenter-root .cc-comp-tplcat {
  font-size: 9.5px; padding: 3px 9px; border-radius: 20px; flex-shrink: 0;
  background: var(--cc-sunken); color: var(--cc-muted);
}

/* lista de borradores */
#lz-comcenter-root .cc-comp-draftlist { display: flex; flex-direction: column; gap: 6px; }
#lz-comcenter-root .cc-comp-draftrow {
  display: flex; align-items: center; gap: 10px; padding: 11px 13px;
  background: var(--cc-panel); border: 0.5px solid var(--cc-border); border-radius: 10px; cursor: pointer;
}
#lz-comcenter-root .cc-comp-draftrow:hover { background: var(--cc-hover); }
#lz-comcenter-root .cc-comp-draftmain { flex: 1; min-width: 0; }
#lz-comcenter-root .cc-comp-draftsubj { font-size: 13px; font-weight: 500; color: var(--cc-tx); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#lz-comcenter-root .cc-comp-draftmeta { font-size: 11px; color: var(--cc-muted); margin-top: 2px; }
#lz-comcenter-root .cc-comp-draftbadge { font-size: 9.5px; padding: 3px 9px; border-radius: 20px; background: var(--cc-sunken); color: var(--cc-muted); flex-shrink: 0; }
#lz-comcenter-root .cc-comp-draftdel {
  width: 26px; height: 26px; border-radius: 8px; border: none; background: none; cursor: pointer;
  color: var(--cc-muted); display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
#lz-comcenter-root .cc-comp-draftdel:hover { background: var(--cc-hover); color: var(--cc-red); }

/* empty states */
#lz-comcenter-root .cc-comp-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 48px 20px; color: var(--cc-muted);
}
#lz-comcenter-root .cc-comp-empty-icon { color: var(--cc-faint); margin-bottom: 12px; }
#lz-comcenter-root .cc-comp-empty-icon svg { width: 28px; height: 28px; }
#lz-comcenter-root .cc-comp-empty-title { font-size: 14px; font-weight: 500; color: var(--cc-tx); }
#lz-comcenter-root .cc-comp-empty-sub { font-size: 12px; margin-top: 4px; }

/* ═══ MODAL ══════════════════════════════════════════════════════════════ */
#cc-comp-modal-root .cc-cm-back {
  position: fixed; inset: 0; background: var(--cc-overlay);
  display: none; align-items: center; justify-content: center;
  z-index: 1000; padding: 2.2vh 2vw;
}
#cc-comp-modal-root .cc-cm-back.open { display: flex; }
#cc-comp-modal-root .cc-cm-back.is-min .cc-cm-modal { height: 56px; max-height: 56px; overflow: hidden; }
#cc-comp-modal-root .cc-cm-modal {
  width: 100%; height: 100%; max-width: 1320px; background: var(--cc-panel);
  border-radius: 14px; box-shadow: var(--cc-shadow);
  display: flex; flex-direction: column; overflow: hidden; position: relative;
  color: var(--cc-tx);
}

/* head */
#cc-comp-modal-root .cc-cm-head {
  display: flex; align-items: center; gap: 10px; padding: 12px 18px;
  border-bottom: 0.5px solid var(--cc-border); flex-shrink: 0;
}
#cc-comp-modal-root .cc-cm-title { font-size: 14.5px; font-weight: 500; color: var(--cc-tx-strong); display: inline-flex; align-items: center; gap: 9px; }
#cc-comp-modal-root .cc-cm-title svg { width: 17px; height: 17px; color: var(--cc-brand); }
#cc-comp-modal-root .cc-cm-meta { font-size: 11.5px; font-weight: 400; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-saved { font-size: 11px; color: var(--cc-green); display: inline-flex; align-items: center; gap: 5px; }
#cc-comp-modal-root .cc-cm-saved::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--cc-green); }
#cc-comp-modal-root .cc-cm-flex { flex: 1; }
#cc-comp-modal-root .cc-cm-kbd { font-size: 10px; color: var(--cc-faint); }
#cc-comp-modal-root .cc-cm-kbd b { font-weight: 500; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-icon {
  width: 30px; height: 30px; border-radius: 8px; border: none; background: none; cursor: pointer;
  color: var(--cc-muted); display: flex; align-items: center; justify-content: center;
}
#cc-comp-modal-root .cc-cm-icon:hover { background: var(--cc-hover); color: var(--cc-tx); }
#cc-comp-modal-root .cc-cm-icon svg { width: 16px; height: 16px; }

/* body: form angosta + preview grande */
#cc-comp-modal-root .cc-cm-body { flex: 1; display: flex; min-height: 0; }
#cc-comp-modal-root .cc-cm-form { width: 300px; flex-shrink: 0; border-right: 0.5px solid var(--cc-border); overflow-y: auto; padding: 14px 15px; display: flex; flex-direction: column; gap: 12px; transition: width 0.18s ease, padding 0.18s ease; }
#cc-comp-modal-root .cc-cm-body.is-collapsed .cc-cm-form { width: 0; padding: 0; overflow: hidden; border-right: none; }
#cc-comp-modal-root .cc-cm-body.is-collapsed .cc-cm-form > * { display: none; }
#cc-comp-modal-root .cc-cm-fld { display: flex; flex-direction: column; }
#cc-comp-modal-root .cc-cm-lbl { font-size: 10px; font-weight: 500; color: var(--cc-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 5px; }
#cc-comp-modal-root .cc-cm-input {
  width: 100%; padding: 7px 10px; background: var(--cc-sunken);
  border: 0.5px solid var(--cc-border); border-radius: 6px; color: var(--cc-tx);
  font-size: 12.5px; font-family: inherit; transition: border-color 0.12s, background 0.12s;
}
#cc-comp-modal-root .cc-cm-input:focus { outline: none; border-color: var(--cc-brand-dim); background: var(--cc-panel); }
#cc-comp-modal-root .cc-cm-help { font-size: 10.5px; color: var(--cc-muted); margin-top: 4px; line-height: 1.4; }

#cc-comp-modal-root .cc-cm-tplpick {
  display: flex; align-items: center; gap: 9px; padding: 8px 9px;
  background: var(--cc-sunken); border: 0.5px solid var(--cc-border); border-radius: 6px; cursor: pointer;
}
#cc-comp-modal-root .cc-cm-tplpick:hover { background: var(--cc-hover); border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-tplav {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  background: var(--cc-brand-soft); color: var(--cc-brand);
  display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 500;
}
#cc-comp-modal-root .cc-cm-tplinfo { flex: 1; min-width: 0; }
#cc-comp-modal-root .cc-cm-tplname { font-size: 12.5px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#cc-comp-modal-root .cc-cm-tplslug { font-size: 10.5px; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-mini { font-size: 10.5px; padding: 4px 9px; border-radius: 6px; border: 0.5px solid var(--cc-border-strong); color: var(--cc-tx); flex-shrink: 0; }

/* acordeones */
#cc-comp-modal-root .cc-cm-acc { border: 0.5px solid var(--cc-border); border-radius: 6px; }
#cc-comp-modal-root .cc-cm-acc-h { padding: 9px 11px; display: flex; align-items: center; justify-content: space-between; cursor: pointer; background: var(--cc-sunken); border-radius: 6px; }
#cc-comp-modal-root .cc-cm-acc-h:hover { background: var(--cc-hover); }
#cc-comp-modal-root .cc-cm-acc.is-open .cc-cm-acc-h { border-radius: 6px 6px 0 0; border-bottom: 0.5px solid var(--cc-border); }
#cc-comp-modal-root .cc-cm-acc-l { font-size: 12px; font-weight: 500; color: var(--cc-tx); display: inline-flex; align-items: center; gap: 8px; }
#cc-comp-modal-root .cc-cm-acc-l svg { width: 14px; height: 14px; color: var(--cc-brand); }
#cc-comp-modal-root .cc-cm-accbadge { background: var(--cc-brand-soft); color: var(--cc-brand); border-radius: 20px; padding: 0 6px; font-size: 9px; font-weight: 500; }
#cc-comp-modal-root .cc-cm-accsum { font-size: 10px; color: var(--cc-muted); font-weight: 400; }
#cc-comp-modal-root .cc-cm-caret { color: var(--cc-muted); display: inline-flex; transition: transform 0.15s; }
#cc-comp-modal-root .cc-cm-caret svg { width: 14px; height: 14px; }
#cc-comp-modal-root .cc-cm-acc.is-open .cc-cm-caret { transform: rotate(180deg); }
#cc-comp-modal-root .cc-cm-acc-b { padding: 11px; display: none; }
#cc-comp-modal-root .cc-cm-acc.is-open .cc-cm-acc-b { display: block; }

#cc-comp-modal-root .cc-cm-varpanel { background: var(--cc-sunken); border: 0.5px solid var(--cc-border); border-radius: 6px; padding: 10px; display: flex; flex-direction: column; gap: 8px; }
#cc-comp-modal-root .cc-cm-varrow { display: flex; flex-direction: column; gap: 3px; }
#cc-comp-modal-root .cc-cm-varkey { font-size: 10.5px; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-varreq { color: var(--cc-brand); margin-left: 2px; font-weight: 500; }
#cc-comp-modal-root .cc-cm-varinput { padding: 5px 8px; background: var(--cc-panel); border: 0.5px solid var(--cc-border); border-radius: 4px; color: var(--cc-tx); font-size: 11.5px; font-family: inherit; }
#cc-comp-modal-root .cc-cm-varinput:focus { outline: none; border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-varempty { font-size: 11px; color: var(--cc-muted); padding: 4px; }
#cc-comp-modal-root .cc-cm-varauto {
  font-size: 10.5px; padding: 6px 9px; border-radius: 6px; border: 0.5px dashed var(--cc-border-strong);
  background: none; color: var(--cc-brand); cursor: pointer; display: inline-flex; align-items: center; gap: 6px; justify-content: center;
}
#cc-comp-modal-root .cc-cm-varauto:hover { background: var(--cc-brand-soft); border-style: solid; }
#cc-comp-modal-root .cc-cm-varauto svg { width: 13px; height: 13px; }

#cc-comp-modal-root .cc-cm-textarea {
  width: 100%; min-height: 150px; padding: 8px 10px; background: var(--cc-sunken);
  border: 0.5px solid var(--cc-border); border-radius: 5px; color: var(--cc-tx);
  font-size: 11.5px; line-height: 1.5; resize: vertical;
}
#cc-comp-modal-root .cc-cm-textarea:focus { outline: none; border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-mjml-actions { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
#cc-comp-modal-root .cc-cm-btn-prev { font-size: 11px; padding: 5px 11px; }
#cc-comp-modal-root .cc-cm-mjml-status { font-size: 10.5px; color: var(--cc-muted); }

#cc-comp-modal-root .cc-cm-modes { display: flex; gap: 7px; }
#cc-comp-modal-root .cc-cm-mode { flex: 1; padding: 8px 7px; border: 0.5px solid var(--cc-border); border-radius: 6px; cursor: pointer; text-align: center; background: var(--cc-panel); display: flex; flex-direction: column; gap: 1px; }
#cc-comp-modal-root .cc-cm-mode:hover { border-color: var(--cc-border-strong); }
#cc-comp-modal-root .cc-cm-mode.is-active { background: var(--cc-brand-soft); border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-mode-n { font-size: 11.5px; font-weight: 500; color: var(--cc-tx); }
#cc-comp-modal-root .cc-cm-mode.is-active .cc-cm-mode-n { color: var(--cc-brand); }
#cc-comp-modal-root .cc-cm-mode-h { font-size: 9.5px; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-track { display: flex; flex-direction: column; gap: 7px; margin-top: 10px; font-size: 11.5px; color: var(--cc-tx); }
#cc-comp-modal-root .cc-cm-track label { display: flex; align-items: center; gap: 7px; cursor: pointer; }

/* preview */
/* ── botón colapsar (pie del form) + reabrir ── */
#cc-comp-modal-root .cc-cm-collapse-row { margin-top: auto; padding-top: 10px; }
#cc-comp-modal-root .cc-cm-collapse-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: 7px; padding: 8px; border-radius: 8px; border: 0.5px solid var(--cc-border); background: var(--cc-sunken); color: var(--cc-muted); cursor: pointer; font-family: inherit; font-size: 11.5px; }
#cc-comp-modal-root .cc-cm-collapse-btn:hover { background: var(--cc-hover); color: var(--cc-tx); }
#cc-comp-modal-root .cc-cm-collapse-btn svg { width: 14px; height: 14px; }
#cc-comp-modal-root .cc-cm-reopen { position: absolute; bottom: 64px; left: 0; width: 32px; height: 40px; border-radius: 0 8px 8px 0; border: 0.5px solid var(--cc-border); border-left: none; background: var(--cc-panel); box-shadow: 2px 0 8px rgba(0,0,0,0.10); cursor: pointer; display: none; align-items: center; justify-content: center; color: var(--cc-muted); z-index: 6; }
#cc-comp-modal-root .cc-cm-body.is-collapsed ~ .cc-cm-reopen { display: flex; }
#cc-comp-modal-root .cc-cm-reopen:hover { color: var(--cc-brand); }

/* ── zona derecha (3 vistas) ── */
#cc-comp-modal-root .cc-cm-right { flex: 1; display: flex; flex-direction: column; min-height: 0; min-width: 0; background: var(--cc-sunken); }
#cc-comp-modal-root .cc-cm-rtoolbar { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 0.5px solid var(--cc-border); background: var(--cc-panel); flex-shrink: 0; }
#cc-comp-modal-root .cc-cm-seg { display: inline-flex; background: var(--cc-sunken); border: 0.5px solid var(--cc-border); border-radius: 8px; padding: 2px; gap: 2px; }
#cc-comp-modal-root .cc-cm-segbtn { border: none; background: none; font-family: inherit; font-size: 12px; padding: 5px 12px; border-radius: 6px; cursor: pointer; color: var(--cc-muted); display: inline-flex; align-items: center; gap: 6px; }
#cc-comp-modal-root .cc-cm-segbtn.is-on { background: var(--cc-brand); color: #fff; }
#cc-comp-modal-root .cc-cm-segbtn svg { width: 13px; height: 13px; }
#cc-comp-modal-root .cc-cm-rstatus { margin-left: auto; font-size: 11px; color: var(--cc-muted); display: inline-flex; align-items: center; gap: 5px; }
#cc-comp-modal-root .cc-cm-rstatus::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--cc-faint); }
#cc-comp-modal-root .cc-cm-rstatus.is-ok { color: var(--cc-green); }
#cc-comp-modal-root .cc-cm-rstatus.is-ok::before { background: var(--cc-green); }
#cc-comp-modal-root .cc-cm-rstatus.is-warn { color: var(--cc-amber); }
#cc-comp-modal-root .cc-cm-rstatus.is-warn::before { background: var(--cc-amber); }
#cc-comp-modal-root .cc-cm-rstatus.is-err { color: var(--cc-red); }
#cc-comp-modal-root .cc-cm-rstatus.is-err::before { background: var(--cc-red); }
#cc-comp-modal-root .cc-cm-rstatus.is-loading { color: var(--cc-muted); }

/* toolbar HTML */
#cc-comp-modal-root .cc-cm-htmltools { display: flex; align-items: center; gap: 4px; padding: 7px 12px; border-bottom: 0.5px solid var(--cc-border); background: var(--cc-sunken); flex-shrink: 0; flex-wrap: wrap; }
#cc-comp-modal-root .cc-cm-tbtn { font-size: 11px; padding: 5px 9px; border-radius: 6px; border: 0.5px solid var(--cc-border); background: var(--cc-panel); color: var(--cc-tx); cursor: pointer; display: inline-flex; align-items: center; gap: 5px; font-family: inherit; }
#cc-comp-modal-root .cc-cm-tbtn:hover { background: var(--cc-hover); border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-tbtn svg { width: 12px; height: 12px; }
#cc-comp-modal-root .cc-cm-tsep { width: 1px; height: 18px; background: var(--cc-border); margin: 0 3px; }
#cc-comp-modal-root .cc-cm-tdrop { position: relative; }
#cc-comp-modal-root .cc-cm-tmenu { position: absolute; top: 32px; left: 0; background: var(--cc-panel); border: 0.5px solid var(--cc-border); border-radius: 8px; box-shadow: var(--cc-shadow); padding: 4px; min-width: 170px; display: none; z-index: 8; max-height: 280px; overflow-y: auto; }
#cc-comp-modal-root .cc-cm-tdrop.is-open .cc-cm-tmenu { display: block; }
#cc-comp-modal-root .cc-cm-tmenu button { display: block; width: 100%; text-align: left; font-size: 11.5px; padding: 6px 9px; border: none; background: none; border-radius: 6px; cursor: pointer; font-family: inherit; color: var(--cc-tx); }
#cc-comp-modal-root .cc-cm-tmenu button:hover { background: var(--cc-hover); }
#cc-comp-modal-root .cc-cm-tmenu .mono, #cc-comp-modal-root .cc-cm-varmenu button { font-family: var(--lk-font-mono, monospace); }

/* contenido conmutable */
#cc-comp-modal-root .cc-cm-rcontent { flex: 1; display: flex; min-height: 0; min-width: 0; overflow: hidden; }
#cc-comp-modal-root .cc-cm-pane-code { display: flex; min-height: 0; min-width: 0; }
#cc-comp-modal-root .cc-cm-codearea { flex: 1; width: 100%; border: none; resize: none; padding: 14px 16px; font-family: var(--lk-font-mono, monospace); font-size: 12px; line-height: 1.6; color: var(--cc-tx); background: var(--cc-panel); outline: none; }
#cc-comp-modal-root .cc-cm-pane-prev { display: flex; min-height: 0; min-width: 0; background: var(--cc-sunken); padding: 16px; }
#cc-comp-modal-root .cc-cm-prevframe-wrap { flex: 1; display: flex; min-width: 0; border: 0.5px solid var(--cc-border); border-radius: 8px; background: #fff; overflow: hidden; }
#cc-comp-modal-root .cc-cm-prevframe { flex: 1; width: 100%; height: 100%; min-height: 0; border: none; background: #fff; display: block; }
#cc-comp-modal-root .cc-cm-divider { width: 7px; flex-shrink: 0; cursor: col-resize; background: var(--cc-panel); border-left: 0.5px solid var(--cc-border); border-right: 0.5px solid var(--cc-border); display: none; align-items: center; justify-content: center; }
#cc-comp-modal-root .cc-cm-divider::after { content: ''; width: 3px; height: 34px; border-radius: 3px; background: var(--cc-border); }
#cc-comp-modal-root .cc-cm-divider:hover::after { background: var(--cc-brand); }

/* modos: code / split / prev */
#cc-comp-modal-root .cc-cm-rcontent.code .cc-cm-pane-code { flex: 1; }
#cc-comp-modal-root .cc-cm-rcontent.code .cc-cm-pane-prev,
#cc-comp-modal-root .cc-cm-rcontent.code .cc-cm-divider { display: none; }
#cc-comp-modal-root .cc-cm-rcontent.prev .cc-cm-pane-prev { flex: 1; }
#cc-comp-modal-root .cc-cm-rcontent.prev .cc-cm-pane-code,
#cc-comp-modal-root .cc-cm-rcontent.prev .cc-cm-divider { display: none; }
#cc-comp-modal-root .cc-cm-rcontent.split .cc-cm-pane-prev { flex: 1; min-width: 0; }
#cc-comp-modal-root .cc-cm-rcontent.split .cc-cm-divider { display: flex; }

/* preview placeholder (antes de render real) */
#cc-comp-modal-root .cc-cm-prevframe-wrap h2 { color: var(--cc-email-accent); margin: 0 0 16px; font-size: 21px; font-weight: 600; }
#cc-comp-modal-root .cc-cm-prevframe-wrap > h2,
#cc-comp-modal-root .cc-cm-prevframe-wrap > p { padding: 0 24px; }
#cc-comp-modal-root .cc-cm-prevframe-wrap > h2:first-child { padding-top: 24px; }
#cc-comp-modal-root .cc-cm-prevcta { text-align: center; margin: 28px 0; }
#cc-comp-modal-root .cc-cm-prevcta a { background: var(--cc-email-accent); color: #fff; padding: 11px 26px; border-radius: 4px; display: inline-block; font-weight: 500; text-decoration: none; }
#cc-comp-modal-root .cc-cm-prevfoot { color: #777; font-size: 12.5px; padding: 20px 24px 24px; border-top: 1px solid #eee; margin-top: 26px; }

/* footer */
#cc-comp-modal-root .cc-cm-foot { display: flex; align-items: center; gap: 9px; padding: 11px 18px; border-top: 0.5px solid var(--cc-border); flex-shrink: 0; }
#cc-comp-modal-root .cc-cm-foot-id { font-size: 10.5px; color: var(--cc-faint); }
#cc-comp-modal-root .cc-cm-btn {
  font-size: 12px; padding: 7px 13px; border-radius: 8px; border: 0.5px solid var(--cc-border-strong);
  background: none; color: var(--cc-tx); cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
}
#cc-comp-modal-root .cc-cm-btn:hover { background: var(--cc-hover); }
#cc-comp-modal-root .cc-cm-btn svg { width: 14px; height: 14px; }
#cc-comp-modal-root .cc-cm-btn-primary { background: var(--cc-brand); color: #fff; border-color: var(--cc-brand); }
#cc-comp-modal-root .cc-cm-btn-primary:hover { filter: brightness(1.07); background: var(--cc-brand); }
#cc-comp-modal-root .cc-cm-btn-danger { color: var(--cc-red); }
#cc-comp-modal-root .cc-cm-btn-danger:hover { background: var(--cc-red); color: #fff; border-color: var(--cc-red); }

/* submodal plantillas */
#cc-comp-modal-root .cc-cm-subback { position: absolute; inset: 0; background: var(--cc-overlay); display: none; align-items: center; justify-content: center; z-index: 1010; }
#cc-comp-modal-root .cc-cm-subback.open { display: flex; }
#cc-comp-modal-root .cc-cm-submodal { width: 760px; max-height: 80%; background: var(--cc-panel); border-radius: 12px; box-shadow: var(--cc-shadow); display: flex; flex-direction: column; overflow: hidden; }
#cc-comp-modal-root .cc-cm-subhead { padding: 13px 18px; border-bottom: 0.5px solid var(--cc-border); display: flex; align-items: center; gap: 10px; }
#cc-comp-modal-root .cc-cm-subhead svg { width: 16px; height: 16px; color: var(--cc-brand); }
#cc-comp-modal-root .cc-cm-subt { font-size: 14px; font-weight: 500; color: var(--cc-tx-strong); flex: 1; }
#cc-comp-modal-root .cc-cm-subsearch { display: flex; align-items: center; gap: 7px; padding: 12px 16px; }
#cc-comp-modal-root .cc-cm-subsearch svg { width: 15px; height: 15px; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-subsearch input { flex: 1; padding: 7px 10px; background: var(--cc-sunken); border: 0.5px solid var(--cc-border); border-radius: 6px; font-size: 12.5px; color: var(--cc-tx); font-family: inherit; }
#cc-comp-modal-root .cc-cm-subsearch input:focus { outline: none; border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-subgrid { overflow-y: auto; padding: 4px 16px 16px; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
#cc-comp-modal-root .cc-cm-subcard { display: flex; align-items: center; gap: 10px; padding: 11px; border: 0.5px solid var(--cc-border); border-radius: 8px; cursor: pointer; background: var(--cc-panel); text-align: left; }
#cc-comp-modal-root .cc-cm-subcard:hover { background: var(--cc-hover); border-color: var(--cc-border-strong); }
#cc-comp-modal-root .cc-cm-subcard.is-selected { background: var(--cc-brand-soft); border-color: var(--cc-brand-dim); }
#cc-comp-modal-root .cc-cm-subav { width: 28px; height: 28px; border-radius: 50%; background: var(--cc-brand-soft); color: var(--cc-brand); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 500; flex-shrink: 0; }
#cc-comp-modal-root .cc-cm-subinfo { flex: 1; min-width: 0; }
#cc-comp-modal-root .cc-cm-subname { font-size: 12.5px; font-weight: 500; }
#cc-comp-modal-root .cc-cm-subslug { font-size: 10.5px; color: var(--cc-muted); }
#cc-comp-modal-root .cc-cm-subcat { font-size: 9.5px; padding: 2px 7px; border-radius: 20px; background: var(--cc-sunken); color: var(--cc-muted); }

/* diálogo de salida (no nativo) */
#cc-comp-modal-root .cc-cm-exitback { position: absolute; inset: 0; background: rgba(0,0,0,0.45); display: none; align-items: center; justify-content: center; z-index: 1020; }
#cc-comp-modal-root .cc-cm-exitback.open { display: flex; }
#cc-comp-modal-root .cc-cm-exitdlg { width: 380px; background: var(--cc-panel); border-radius: 12px; box-shadow: var(--cc-shadow); overflow: hidden; }
#cc-comp-modal-root .cc-cm-exitbody { padding: 20px 22px 16px; }
#cc-comp-modal-root .cc-cm-exittitle { font-size: 15px; font-weight: 500; color: var(--cc-tx-strong); display: flex; align-items: center; gap: 10px; margin-bottom: 11px; }
#cc-comp-modal-root .cc-cm-exittitle svg { width: 20px; height: 20px; color: var(--cc-amber); }
#cc-comp-modal-root .cc-cm-exittext { font-size: 13px; color: var(--cc-muted); line-height: 1.5; }
#cc-comp-modal-root .cc-cm-exitfoot { display: flex; gap: 8px; padding: 14px 22px; border-top: 0.5px solid var(--cc-border); background: var(--cc-sunken); }
#cc-comp-modal-root .cc-cm-exitfoot .cc-cm-btn { flex: 1; justify-content: center; }

@media (max-width: 920px) {
  #cc-comp-modal-root .cc-cm-body { flex-direction: column; }
  #cc-comp-modal-root .cc-cm-form { width: 100%; border-right: none; border-bottom: 0.5px solid var(--cc-border); }
  #cc-comp-modal-root .cc-cm-subgrid { grid-template-columns: 1fr; }
}
