/* ═══════════════════════════════════════════════════════
   KLARO BANK — components.css v4
   Cards glass · Botones lavanda · Modales premium
═══════════════════════════════════════════════════════ */

/* ── CARDS ──────────────────────────────────────── */
.card {
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(124,58,237,.1);
  border-radius:var(--radius); overflow:hidden; margin-bottom:20px;
  box-shadow:var(--shadow-card); transition:all .22s;
}
.card:hover { box-shadow:var(--shadow); border-color:rgba(124,58,237,.2); }
.card-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 22px; border-bottom:1px solid rgba(124,58,237,.08);
  gap:12px; flex-wrap:wrap;
  background:linear-gradient(135deg, rgba(124,58,237,.04), rgba(167,139,250,.03));
}
.card-ttl { font-size:15px; font-weight:700; color:var(--k1); }

/* ── INFO LIST ──────────────────────────────────── */
.info-list .ir {
  display:flex; justify-content:space-between; align-items:center;
  padding:13px 22px; border-bottom:1px solid rgba(124,58,237,.07); font-size:14px;
}
.info-list .ir:last-child { border-bottom:none; }
.ir-l { color:var(--text3); font-size:12.5px; }
.ir-v { font-weight:600; color:var(--text); }

/* ── MOVIMIENTOS ────────────────────────────────── */
.mov-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:15px 22px; border-bottom:1px solid rgba(124,58,237,.07);
  transition:background .12s;
  gap:18px;
}
.mov-row-rich { align-items:flex-start; padding:18px 22px; }
.mov-row:last-child { border-bottom:none; }
.mov-row:hover { background:rgba(124,58,237,.04); }
.mov-left { display:flex; align-items:center; gap:12px; min-width:0; }
.mov-row-rich .mov-left { align-items:flex-start; flex:1; }
.mov-ico {
  width:42px; height:42px; border-radius:var(--radius-xs);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.mov-ico.dep { background:rgba(16,185,129,.1); color:var(--ok); }
.mov-ico.ret { background:rgba(244,63,94,.08); color:var(--err); }
.mov-ico.tx { background:rgba(124,58,237,.12); color:var(--k2); }
.mov-main { min-width:0; width:100%; }
.mov-title-line {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  margin-bottom:10px;
}
.mov-desc { font-size:13.5px; font-weight:600; color:var(--text); }
.mov-type {
  display:inline-flex; align-items:center; height:22px; padding:0 9px;
  border-radius:999px; font-size:10.5px; font-weight:800;
  text-transform:uppercase; letter-spacing:.05em;
}
.mov-type-dep { background:rgba(16,185,129,.12); color:var(--ok); }
.mov-type-ret { background:rgba(244,63,94,.12); color:var(--err); }
.mov-type-tx { background:rgba(124,58,237,.14); color:var(--k2); }
.mov-detail-grid {
  display:grid; grid-template-columns:minmax(160px,1fr) auto minmax(160px,1fr);
  gap:10px; align-items:stretch; max-width:760px;
}
.mov-party {
  padding:10px 12px; border:1px solid rgba(124,58,237,.10);
  border-radius:12px; background:rgba(255,255,255,.54);
  min-width:0;
}
.mov-party-label {
  display:block; margin-bottom:4px; color:var(--text3);
  font-size:10.5px; font-weight:800; text-transform:uppercase;
  letter-spacing:.08em;
}
.mov-party strong {
  display:block; color:var(--text); font-size:12.5px; line-height:1.25;
  overflow:hidden; text-overflow:ellipsis;
}
.mov-route-arrow {
  display:flex; align-items:center; justify-content:center; color:var(--k2);
  font-weight:900; min-width:22px;
}
.mov-meta {
  display:flex; flex-wrap:wrap; gap:7px; margin-top:9px;
}
.mov-chip {
  display:inline-flex; align-items:center; min-height:22px; padding:0 8px;
  border-radius:999px; background:rgba(124,58,237,.08);
  color:var(--text3); font-size:11px; font-weight:700;
}
.mov-chip-ref { font-family:'DM Mono',monospace; }
.mov-date { font-size:12px; color:var(--text3); margin-top:2px; }
.mov-ref  { font-size:11px; color:var(--text3); font-family:'DM Mono',monospace; }
.mov-amt  { font-size:15px; font-weight:700; text-align:right; }
.mov-amt.pos { color:var(--ok); }
.mov-amt.neg { color:var(--err); }
.mov-right { min-width:132px; padding-top:2px; }
.mov-bal { font-size:12px; color:var(--text3); text-align:right; margin-top:2px; }
.empty-state { padding:50px; text-align:center; color:var(--text3); font-size:14px; }
.empty-ico { font-size:28px; margin-bottom:10px; opacity:.4; }

/* ── TABLE ──────────────────────────────────────── */
.tbl { width:100%; border-collapse:collapse; }
.tbl thead th {
  text-align:left; font-size:10.5px; font-weight:700; color:var(--text3);
  text-transform:uppercase; letter-spacing:.09em; padding:10px 18px;
  background:rgba(124,58,237,.04); border-bottom:1px solid rgba(124,58,237,.08);
}
.tbl tbody tr { border-bottom:1px solid rgba(124,58,237,.07); transition:background .12s; cursor:pointer; }
.tbl tbody tr:last-child { border-bottom:none; }
.tbl tbody tr:hover { background:rgba(124,58,237,.04); }
.tbl td { padding:13px 18px; font-size:13.5px; }
.cc { display:flex; align-items:center; gap:10px; }
.cc-av {
  width:34px; height:34px; border-radius:50%;
  background:var(--grad-violet);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800; color:#fff; flex-shrink:0;
}
.cc-av-lg { width:46px; height:46px; font-size:15px; }

/* ── BOTONES ────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 20px; border-radius:var(--radius-pill);
  font-family:'Inter',sans-serif; font-size:13.5px; font-weight:600;
  cursor:pointer; border:none; transition:all .22s; letter-spacing:.01em;
}
/* Botón principal — violeta */
.btn-grad {
  background:var(--grad-violet); color:#fff;
  box-shadow:0 4px 16px rgba(124,58,237,.3);
}
.btn-grad:hover { box-shadow:0 8px 32px rgba(124,58,237,.5); transform:translateY(-2px); }
/* Botón dorado → reemplazado por lavanda */
.btn-gold {
  background:var(--grad-lavanda); color:var(--k1); font-weight:700;
  box-shadow:0 4px 16px rgba(167,139,250,.3);
}
.btn-gold:hover { box-shadow:0 8px 28px rgba(167,139,250,.5); transform:translateY(-2px); }
/* Botón mint */
.btn-mint {
  background:linear-gradient(135deg,#10B981,#34D399); color:#fff;
  box-shadow:0 4px 16px rgba(16,185,129,.25);
}
.btn-mint:hover { box-shadow:0 8px 28px rgba(16,185,129,.4); transform:translateY(-2px); }
/* Botón glass */
.btn-glass {
  background:rgba(255,255,255,.72); color:var(--k1);
  border:1px solid rgba(124,58,237,.18);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  box-shadow:var(--shadow-xs);
}
.btn-glass:hover { box-shadow:var(--shadow); transform:translateY(-2px); border-color:rgba(124,58,237,.35); }
/* Botón outline */
.btn-out {
  background:transparent; border:1.5px solid rgba(124,58,237,.22); color:var(--text2);
}
.btn-out:hover { border-color:var(--k3); color:var(--k2); background:rgba(124,58,237,.04); }
/* Botón rojo */
.btn-red {
  background:rgba(244,63,94,.08); border:1.5px solid rgba(244,63,94,.2); color:var(--err);
}
.btn-red:hover { background:var(--err); color:#fff; border-color:var(--err); }

.btn-sm   { padding:6px 14px; font-size:12px; }
.btn-xs   { padding:5px 10px; font-size:11.5px; }
.btn-full { width:100%; justify-content:center; padding:14px; font-size:14.5px; }
.btn:disabled { opacity:.4; cursor:not-allowed; pointer-events:none; }

/* ── FORMULARIOS ────────────────────────────────── */
.form-group { margin-bottom:18px; }
.form-group label {
  display:block; font-size:11px; font-weight:700; color:var(--text3);
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:7px;
}
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:12px 16px;
  background:rgba(255,255,255,.85); border:1.5px solid rgba(124,58,237,.14);
  border-radius:var(--radius-sm); font-family:'Inter',sans-serif;
  font-size:14px; color:var(--text); outline:none; transition:all .2s;
  backdrop-filter:blur(8px);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--k3); background:#fff;
  box-shadow:0 0 0 4px rgba(124,58,237,.08);
}
.form-group input[readonly] { background:rgba(124,58,237,.04); color:var(--text3); cursor:default; }
.form-group input[type="number"] { appearance:textfield; }
.form-group select {
  appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239C8EC1' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px;
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-hint { font-size:11px; color:var(--text3); margin-top:5px; line-height:1.5; }
.form-err {
  font-size:12px; color:var(--err); margin-top:5px; display:none;
  background:rgba(244,63,94,.06); padding:8px 12px;
  border-radius:var(--radius-xs); border-left:2px solid var(--err);
}
.form-err.show { display:block; }
.inp-pref-wrap { position:relative; }
.inp-pref {
  position:absolute; left:16px; top:50%; transform:translateY(-50%);
  font-size:14px; color:var(--text3); pointer-events:none;
}
.inp-pref-wrap input { padding-left:28px!important; }

/* ── SEARCH ─────────────────────────────────────── */
.search-box {
  display:flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.82); border:1.5px solid rgba(124,58,237,.14);
  border-radius:var(--radius-pill); padding:8px 16px;
  transition:all .2s; box-shadow:var(--shadow-xs);
  backdrop-filter:blur(10px);
}
.search-box:focus-within { border-color:var(--k3); box-shadow:0 0 0 4px rgba(124,58,237,.07); }
.search-box svg { color:var(--text3); flex-shrink:0; }
.search-box input {
  border:none!important; background:none!important; outline:none!important;
  box-shadow:none!important; padding:0!important;
  font-size:13.5px; color:var(--text); width:220px;
}

/* ── FILTER BAR ─────────────────────────────────── */
.filter-bar {
  display:flex; gap:8px; align-items:center; flex-wrap:wrap;
  padding:12px 22px; border-bottom:1px solid rgba(124,58,237,.08);
  background:rgba(124,58,237,.03);
}
.filter-select {
  padding:7px 28px 7px 12px; font-size:12.5px;
  background:rgba(255,255,255,.85); border:1.5px solid rgba(124,58,237,.14);
  border-radius:var(--radius-pill); color:var(--text2);
  cursor:pointer; outline:none; font-family:inherit; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239C8EC1' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center; transition:all .15s;
}
.filter-select:focus { border-color:var(--k3); }
.filter-input-sm {
  padding:7px 12px; font-size:12.5px;
  background:rgba(255,255,255,.85); border:1.5px solid rgba(124,58,237,.14);
  border-radius:var(--radius-pill); color:var(--text); outline:none;
  font-family:inherit; transition:all .15s; width:120px;
}
.filter-input-sm:focus { border-color:var(--k3); }
.filter-lbl { font-size:11.5px; color:var(--text3); font-weight:500; white-space:nowrap; }
.filter-sep { width:1px; height:20px; background:rgba(124,58,237,.12); margin:0 2px; }

/* ── FILTER TABS ────────────────────────────────── */
.ftabs { display:flex; gap:5px; flex-wrap:wrap; }
.ftab {
  padding:6px 16px; border-radius:var(--radius-pill);
  background:transparent; border:1.5px solid rgba(124,58,237,.18);
  color:var(--text3); font-family:inherit; font-size:12.5px; font-weight:500;
  cursor:pointer; transition:all .15s;
}
.ftab:hover { border-color:var(--k3); color:var(--k2); }
.ftab.on {
  background:var(--grad-violet); border-color:transparent; color:#fff;
  box-shadow:0 4px 14px rgba(124,58,237,.28);
}

/* ── PILLS ──────────────────────────────────────── */
.pill {
  display:inline-flex; align-items:center; padding:3px 12px;
  border-radius:var(--radius-pill); font-size:12px; font-weight:600; letter-spacing:.02em;
}
.pill-p { background:rgba(124,58,237,.1); color:var(--k2); }
.pill-g { background:rgba(16,185,129,.1); color:#059669; }
.pill-r { background:rgba(244,63,94,.08); color:var(--err); }
.pill-b { background:rgba(56,189,248,.1); color:#0284C7; }
.pill-y { background:rgba(167,139,250,.15); color:var(--k3); }

/* ── MODALES ────────────────────────────────────── */
.modal-ov {
  display:none; position:fixed; inset:0;
  background:rgba(15,5,32,.65); z-index:300;
  align-items:center; justify-content:center;
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
}
.modal-ov.open { display:flex; }
.modal {
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(32px); -webkit-backdrop-filter:blur(32px);
  border:1px solid rgba(124,58,237,.14);
  border-radius:var(--radius); width:100%;
  box-shadow:0 32px 80px rgba(26,5,51,.3);
  animation:fadeUp .22s ease;
  position:relative; max-height:92vh; overflow-y:auto;
}
.modal-sm  { max-width:440px; }
.modal-md  { max-width:560px; }
.modal-lg  { max-width:700px; }
.modal-xl  { max-width:880px; }
.modal-head {
  display:flex; align-items:flex-start; justify-content:space-between;
  padding:22px 24px; gap:12px; border-bottom:1px solid rgba(124,58,237,.08);
  background:linear-gradient(135deg, rgba(124,58,237,.04), rgba(167,139,250,.03));
}
.modal-head-client { display:flex; align-items:center; gap:14px; }
.modal-ttl { font-size:20px; font-weight:800; margin-bottom:3px; color:var(--k1); }
.modal-sub { font-size:13px; color:var(--text3); }
.modal-close-btn {
  width:32px; height:32px; border-radius:50%;
  background:rgba(124,58,237,.08); border:1px solid rgba(124,58,237,.14);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--text3); flex-shrink:0; transition:all .15s;
}
.modal-close-btn:hover { background:rgba(124,58,237,.15); color:var(--k2); }
.modal-body { padding:20px 24px; }
.modal-foot {
  display:flex; justify-content:flex-end; gap:10px;
  padding:14px 24px 22px; border-top:1px solid rgba(124,58,237,.08);
}

/* Ver cliente - stats bar */
.vc-stats-bar {
  display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid rgba(124,58,237,.1); border-radius:var(--radius-sm);
  overflow:hidden; margin-bottom:20px;
}
.vc-stat {
  padding:14px 16px;
  background:linear-gradient(135deg, rgba(124,58,237,.04), rgba(167,139,250,.03));
  border-right:1px solid rgba(124,58,237,.08);
}
.vc-stat:last-child { border-right:none; }
.vc-stat-lbl { font-size:10.5px; color:var(--text3); margin-bottom:4px; text-transform:uppercase; letter-spacing:.07em; }
.vc-stat-val { font-size:15px; font-weight:700; color:var(--text); }
.vc-stat-sm  { font-size:12px; }
.vc-gold     { color:var(--k3); }
.vc-movs-lbl { font-size:10.5px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.09em; margin-bottom:10px; }
.vc-movs-wrap { border:1px solid rgba(124,58,237,.1); border-radius:var(--radius-xs); overflow:hidden; }

/* Eliminar */
.del-warn {
  background:rgba(244,63,94,.05); border:1px solid rgba(244,63,94,.15);
  border-left:3px solid var(--err); border-radius:var(--radius-xs);
  padding:14px; font-size:13.5px; color:#9B1239;
  margin-bottom:16px; display:flex; gap:10px; align-items:flex-start; line-height:1.6;
}
.del-confirm-txt { font-size:14px; color:var(--text2); }

/* ── TOAST ──────────────────────────────────────── */
.toast {
  position:fixed; bottom:24px; right:24px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(124,58,237,.12);
  border-radius:var(--radius-sm); padding:14px 20px;
  display:flex; align-items:center; gap:10px;
  font-size:13.5px; font-weight:500;
  box-shadow:var(--shadow-xl);
  transform:translateY(100px); opacity:0;
  transition:all .35s cubic-bezier(.34,1.56,.64,1); z-index:500; max-width:380px;
}
.toast.show { transform:translateY(0); opacity:1; }
.toast.ok  { border-left:3px solid var(--ok); }
.toast.ok .t-ico { color:var(--ok); }
.toast.err { border-left:3px solid var(--err); }
.toast.err .t-ico { color:var(--err); }

/* ── INFO HIGHLIGHT ─────────────────────────────── */
.info-highlight {
  background:linear-gradient(135deg, rgba(124,58,237,.05), rgba(167,139,250,.04));
  border:1px solid rgba(124,58,237,.14); border-left:3px solid var(--k3);
  border-radius:var(--radius-sm); padding:14px 16px;
  font-size:13px; color:var(--text2); line-height:1.6; margin-bottom:8px;
}
.info-highlight strong { color:var(--k1); }

/* ── BLOQUEO ────────────────────────────────────── */
.bloqueo-page { max-width:680px; margin:0 auto; display:flex; flex-direction:column; gap:16px; animation:fadeUp .4s ease; }
.bloqueo-header { text-align:center; padding:32px 20px 8px; }
.bloqueo-icon-bg {
  width:72px; height:72px; border-radius:50%;
  background:rgba(244,63,94,.08); border:2px solid rgba(244,63,94,.15);
  display:flex; align-items:center; justify-content:center; margin:0 auto 16px;
}
.bloqueo-icon-emoji { font-size:30px; line-height:1; }
.bloqueo-title { font-size:24px; font-weight:800; margin-bottom:8px; color:var(--k1); }
.bloqueo-subtitle { font-size:14px; color:var(--text2); }
.bloqueo-motivo-card {
  background:rgba(255,255,255,.85); backdrop-filter:blur(16px);
  border:1px solid rgba(124,58,237,.1); border-left:3px solid var(--err);
  border-radius:var(--radius); padding:22px 24px;
}
.bmc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; flex-wrap:wrap; gap:8px; }
.bmc-badge {
  background:rgba(244,63,94,.08); color:var(--err); font-size:11px; font-weight:700;
  padding:3px 10px; border-radius:var(--radius-pill); text-transform:uppercase; letter-spacing:.06em;
}
.bmc-fecha { font-size:12px; color:var(--text3); }
.bmc-concepto { font-size:17px; font-weight:700; margin-bottom:8px; color:var(--k1); }
.bmc-desc { font-size:13.5px; color:var(--text2); line-height:1.7; }
.bmc-nota {
  margin-top:14px; padding:12px 14px;
  background:rgba(124,58,237,.05); border-radius:var(--radius-xs);
  font-size:13px; color:var(--text2); line-height:1.6; display:flex; gap:8px;
}
.bmc-nota-ico { flex-shrink:0; }
.bloqueo-pago-card {
  background:rgba(255,255,255,.85); backdrop-filter:blur(16px);
  border:1px solid rgba(124,58,237,.1); border-radius:var(--radius); padding:24px;
  display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:start;
}
.bloqueo-pago-card.sin-cargo { grid-template-columns:auto 1fr; align-items:center; }
.sin-cargo-ico { font-size:28px; }
.bpc-label { font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.07em; margin-bottom:6px; }
.bpc-monto { font-size:34px; font-weight:800; color:var(--k1); margin-bottom:10px; }
.bpc-instruccion { font-size:13px; color:var(--text2); line-height:1.7; }
.bpc-datos-box { background:linear-gradient(135deg,#0F0520,#1A0533); border-radius:var(--radius-sm); padding:18px; color:#fff; border-top:2px solid var(--k3); }
.bpc-datos-title { display:flex; align-items:center; gap:7px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.09em; color:var(--k4); margin-bottom:14px; }
.bpc-row { display:flex; justify-content:space-between; font-size:13px; padding:6px 0; border-bottom:1px solid rgba(255,255,255,.06); color:rgba(255,255,255,.55); }
.bpc-row:last-child { border-bottom:none; }
.bpc-row span:last-child { font-weight:600; color:#fff; text-align:right; }
.bpc-clabe { font-family:'DM Mono',monospace; font-size:12px; letter-spacing:1px; }
.bpc-total { margin-top:8px; padding-top:10px; border-top:1px solid rgba(255,255,255,.15)!important; }
.bpc-total span:last-child { color:var(--k4)!important; font-size:15px; }
.bloqueo-aviso {
  display:flex; align-items:center; gap:10px;
  background:rgba(124,58,237,.05); border:1px solid rgba(124,58,237,.12);
  border-radius:var(--radius-xs); padding:14px 16px;
  font-size:13px; color:var(--text2);
}
.bloqueo-aviso svg { flex-shrink:0; color:var(--k3); }
.vc-bloqueo-banner {
  display:flex; gap:12px;
  background:rgba(244,63,94,.05); border:1px solid rgba(244,63,94,.15);
  border-radius:var(--radius-xs); padding:14px; align-items:flex-start;
}
.vc-bl-icon  { font-size:20px; flex-shrink:0; }
.vc-bl-title { font-size:13.5px; font-weight:700; color:var(--err); margin-bottom:4px; }
.vc-bl-desc  { font-size:13px; color:var(--text2); line-height:1.5; }
.vc-bl-monto { margin-top:8px; font-size:13px; color:var(--text); }
.vc-bl-nota  { margin-top:6px; font-size:12px; color:var(--text3); font-style:italic; }
.bl-concepto-desc {
  font-size:13px; color:var(--text2); background:rgba(124,58,237,.05);
  border-radius:var(--radius-xs); padding:10px 14px; margin-bottom:14px;
  line-height:1.6; min-height:0; transition:all .2s;
}
.bl-concepto-desc:empty { display:none; }
.bl-aviso-warn {
  display:flex; align-items:flex-start; gap:8px;
  background:rgba(167,139,250,.08); border:1px solid rgba(124,58,237,.2);
  border-radius:var(--radius-xs); padding:10px 14px;
  font-size:13px; color:var(--k2); margin-bottom:8px;
}
.bl-aviso-warn svg { flex-shrink:0; margin-top:1px; }
.form-group textarea { resize:vertical; min-height:80px; line-height:1.6; }

/* ── MODAL LOGIN / SEGURIDAD ────────────────────── */
.modal-login-inner { max-width:460px; overflow:hidden; }
.modal-login-head { display:flex; align-items:center; justify-content:space-between; padding:24px 28px 0; }
.modal-login-brand { display:flex; align-items:center; gap:10px; }
.modal-login-body { padding:20px 28px 28px; }
.login-head { margin-bottom:28px; }
.login-head h2 { font-size:24px; font-weight:800; margin-bottom:6px; color:var(--k1); }
.login-head p  { font-size:13.5px; color:var(--text3); }
.modal-login-footer { text-align:center; margin-top:18px; font-size:12px; color:var(--text3); }
.field { margin-bottom:18px; }
.field label { display:block; font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:7px; }
.inp-wrap { position:relative; display:flex; align-items:center; }
.inp-ico { position:absolute; left:16px; top:50%; transform:translateY(-50%); color:var(--text3); pointer-events:none; }
.inp-wrap input {
  width:100%; padding:13px 16px 13px 44px;
  background:rgba(248,247,255,.92); border:1.5px solid rgba(124,58,237,.14);
  border-radius:var(--radius-sm); font-family:'Inter',sans-serif;
  font-size:14px; color:var(--text); outline:none; transition:all .2s;
}
.inp-wrap input:focus {
  border-color:var(--k3); background:#fff;
  box-shadow:0 0 0 4px rgba(124,58,237,.08);
}
.inp-tog {
  position:absolute; right:14px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; color:var(--text3); display:flex; transition:color .15s;
}
.inp-tog:hover { color:var(--text2); }
.err-box {
  background:rgba(244,63,94,.05); border:1px solid rgba(244,63,94,.2);
  border-left:3px solid var(--err); border-radius:var(--radius-xs);
  padding:10px 14px; font-size:13px; color:var(--err);
  display:none; align-items:center; gap:8px; margin-bottom:16px;
}
.err-box.show { display:flex; }
.btn-login {
  width:100%; padding:14px; background:var(--grad-violet); color:#fff;
  border:none; border-radius:var(--radius-pill);
  font-family:'Inter',sans-serif; font-size:14.5px; font-weight:700;
  cursor:pointer; transition:all .28s; margin-top:6px;
  box-shadow:0 6px 24px rgba(124,58,237,.35); letter-spacing:.02em;
}
.btn-login:hover { box-shadow:0 12px 40px rgba(124,58,237,.55); transform:translateY(-2px); }
.btn-login:disabled { opacity:.65; cursor:not-allowed; transform:none; }

/* Seg modal */
.seg-modal { max-width:480px; }
.seg-header { text-align:center; padding:30px 28px 10px; }
.seg-icon-wrap { font-size:36px; margin-bottom:12px; }
.seg-title { font-size:22px; font-weight:800; color:var(--k1); margin-bottom:6px; }
.seg-subtitle { font-size:13px; color:var(--text3); }
.seg-body { padding:6px 28px 10px; }
.seg-alert {
  display:flex; gap:12px; padding:14px;
  background:rgba(244,63,94,.05); border:1px solid rgba(244,63,94,.15);
  border-radius:var(--radius-sm); margin-bottom:12px;
  font-size:13px; color:var(--text2); line-height:1.6;
}
.seg-alert-ico { font-size:20px; flex-shrink:0; }
.seg-alert strong { display:block; color:var(--text); margin-bottom:4px; font-size:13.5px; }
.seg-reminder {
  display:flex; gap:12px; padding:14px;
  background:rgba(124,58,237,.05); border:1px solid rgba(124,58,237,.14);
  border-radius:var(--radius-sm); font-size:13px; color:var(--text2); line-height:1.6;
}
.seg-reminder-ico { font-size:20px; flex-shrink:0; }
.seg-reminder strong { display:block; color:var(--text); margin-bottom:4px; font-size:13.5px; }
.seg-foot { padding:16px 28px 26px; }
.seg-btn { width:100%; justify-content:center; padding:14px; font-size:14.5px; }

/* ── RESPONSIVE ──────────────────────────────────── */
@media(max-width:700px) {
  .bloqueo-pago-card { grid-template-columns:1fr; gap:16px; }
  .bloqueo-pago-card.sin-cargo { grid-template-columns:auto 1fr; }
  .bpc-monto { font-size:28px; }
  .report-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:480px) {
  .report-grid { grid-template-columns:1fr; }
  .modal-body, .modal-head { padding-left:16px; padding-right:16px; }
}

/* ═══════════════════════════════════════════════════════════════
   ESTILOS NUEVOS - SISTEMA DE TRANSFERENCIAS
═══════════════════════════════════════════════════════════════ */

/* Subtabs */
.subtab-panel {
  display: none;
}
.subtab-panel.active {
  display: block;
}

/* Botones de subtab */
.btn-text {
  background: none !important;
  color: var(--text2);
  border: none;
  padding: 12px 16px;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 500;
  font-size: 14px;
}
.btn-text:hover {
  color: var(--k1);
}
.btn-text.active {
  color: var(--k3);
  border-bottom-color: var(--k3);
}

/* Mensajes de error */
.error-msg {
  display: none;
  padding: 12px;
  background: rgba(244, 63, 94, 0.1);
  border-left: 3px solid var(--err);
  border-radius: 4px;
  color: var(--err);
  font-size: 13px;
  margin: 16px 0;
  animation: slideIn 0.3s ease;
}
.error-msg.show {
  display: block;
}

/* Badges */
.badge-sm {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.badge-blue {
  background: rgba(56, 189, 248, 0.15);
  color: var(--k7);
}

.badge-purple {
  background: rgba(124, 58, 237, 0.15);
  color: var(--k3);
}

/* Tablas mejoradas para transferencias */
.tbl tbody tr:hover {
  background-color: var(--glass);
}

.tbl td {
  padding: 14px;
  vertical-align: middle;
}

/* Estado de transacciones */
.pill {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 600;
}

.pill-g {
  background: rgba(16, 185, 129, 0.15);
  color: var(--ok);
}

.pill-r {
  background: rgba(244, 63, 94, 0.15);
  color: var(--err);
}

.pill-y {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
}

/* Alertas de seguridad */
.alerta-badge {
  display: inline-block;
  background: var(--err);
  color: white;
  padding: 2px 6px;
  border-radius: 50%;
  font-size: 10px;
  font-weight: bold;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

/* Transición suave */
@keyframes slideIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Dark mode compatible */
@media (prefers-color-scheme: dark) {
  .btn-text {
    color: var(--text2);
  }
  .btn-text:hover {
    color: var(--k4);
  }
  .btn-text.active {
    color: var(--k4);
  }
}


/* Global light dark controls */
.theme-toggle {
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:10050;
  display:inline-flex;
  align-items:center;
  gap:9px;
  min-height:42px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(124,58,237,.18);
  background:rgba(255,255,255,.82);
  color:var(--text);
  box-shadow:0 14px 34px rgba(76,29,149,.18);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  cursor:pointer;
  font:800 12px/1 'Inter',system-ui,sans-serif;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.theme-toggle:hover { transform:translateY(-2px); border-color:rgba(124,58,237,.36); }
.theme-toggle svg {
  width:17px;
  height:17px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
:root[data-theme="dark"] .theme-toggle {
  background:rgba(25,16,43,.86);
  border-color:rgba(216,206,255,.2);
  color:var(--text);
  box-shadow:0 16px 38px rgba(0,0,0,.38);
}
:root[data-theme="dark"] .card,
:root[data-theme="dark"] .modal,
:root[data-theme="dark"] .transfer-card,
:root[data-theme="dark"] .tbl-wrap {
  background:rgba(24,15,43,.82);
  border-color:rgba(216,206,255,.13);
  box-shadow:var(--shadow-card);
}
:root[data-theme="dark"] .card-head,
:root[data-theme="dark"] .transfer-card-head,
:root[data-theme="dark"] .tbl thead th {
  background:linear-gradient(135deg, rgba(157,124,255,.1), rgba(103,212,255,.035));
  border-color:rgba(216,206,255,.12);
}
:root[data-theme="dark"] .card-ttl,
:root[data-theme="dark"] .modal-ttl { color:var(--text); }
:root[data-theme="dark"] .info-list .ir,
:root[data-theme="dark"] .mov-row,
:root[data-theme="dark"] .tbl tbody tr,
:root[data-theme="dark"] .modal-head,
:root[data-theme="dark"] .modal-foot {
  border-color:rgba(216,206,255,.1);
}
:root[data-theme="dark"] .tbl tbody tr:hover,
:root[data-theme="dark"] .mov-row:hover { background:rgba(157,124,255,.08); }
:root[data-theme="dark"] .mov-party {
  background:rgba(255,255,255,.055);
  border-color:rgba(216,206,255,.14);
}
:root[data-theme="dark"] .mov-chip {
  background:rgba(157,124,255,.12);
  color:var(--text2);
}
:root[data-theme="dark"] input,
:root[data-theme="dark"] select,
:root[data-theme="dark"] textarea,
:root[data-theme="dark"] .form-group input,
:root[data-theme="dark"] .form-group select,
:root[data-theme="dark"] .form-group textarea {
  background:rgba(10,5,21,.76);
  color:var(--text);
  border-color:rgba(216,206,255,.16);
}
:root[data-theme="dark"] input::placeholder,
:root[data-theme="dark"] textarea::placeholder { color:rgba(211,199,239,.58); }
:root[data-theme="dark"] .app-main,
:root[data-theme="dark"] .page { background:transparent; }
:root[data-theme="dark"] .empty-state { color:var(--text3); }
@media (max-width: 560px) {
  .theme-toggle {
    right:12px;
    bottom:12px;
    min-height:38px;
    padding:9px 11px;
  }
  .theme-toggle span { display:none; }
}

/* Dark theme component contrast fixes */
:root[data-theme="dark"] .modal,
:root[data-theme="dark"] .modal-inner,
:root[data-theme="dark"] .info-highlight,
:root[data-theme="dark"] .bloqueo-motivo-card,
:root[data-theme="dark"] .bloqueo-pago-card {
  background:rgba(24,15,43,.9);
  border-color:rgba(216,206,255,.14);
  color:var(--text);
}
:root[data-theme="dark"] .ir-v,
:root[data-theme="dark"] .mov-desc,
:root[data-theme="dark"] .mov-party strong,
:root[data-theme="dark"] .tbl td,
:root[data-theme="dark"] .form-group label,
:root[data-theme="dark"] .modal label {
  color:var(--text);
}
:root[data-theme="dark"] .ir-l,
:root[data-theme="dark"] .mov-date,
:root[data-theme="dark"] .mov-ref,
:root[data-theme="dark"] .mov-bal,
:root[data-theme="dark"] .mov-party-label,
:root[data-theme="dark"] .modal-sub,
:root[data-theme="dark"] .form-hint,
:root[data-theme="dark"] .empty-state {
  color:var(--text2);
}
:root[data-theme="dark"] .btn-out,
:root[data-theme="dark"] .btn-nav-ghost {
  background:rgba(255,255,255,.06);
  color:var(--text);
  border-color:rgba(216,206,255,.22);
}
:root[data-theme="dark"] .btn-out:hover,
:root[data-theme="dark"] .btn-nav-ghost:hover {
  background:rgba(157,124,255,.12);
  color:#F8F4FF;
  border-color:rgba(188,168,255,.36);
}
:root[data-theme="dark"] .tbl thead th {
  color:#D8CEFF;
}

/* Dark theme form and utility contrast fixes */
:root[data-theme="dark"] .btn-glass,
:root[data-theme="dark"] .search-box,
:root[data-theme="dark"] .filter-select,
:root[data-theme="dark"] .filter-input-sm,
:root[data-theme="dark"] .toast {
  background:rgba(24,15,43,.88);
  color:var(--text);
  border-color:rgba(216,206,255,.16);
  box-shadow:0 16px 38px rgba(0,0,0,.3);
}
:root[data-theme="dark"] .form-group input:focus,
:root[data-theme="dark"] .form-group select:focus,
:root[data-theme="dark"] .form-group textarea:focus {
  background:rgba(10,5,21,.9);
  border-color:var(--k4);
  box-shadow:0 0 0 4px rgba(157,124,255,.16);
}
:root[data-theme="dark"] .form-group input[readonly] {
  background:rgba(157,124,255,.09);
  color:var(--text2);
}
:root[data-theme="dark"] .filter-bar,
:root[data-theme="dark"] .vc-stat,
:root[data-theme="dark"] .bl-concepto-desc,
:root[data-theme="dark"] .bloqueo-aviso,
:root[data-theme="dark"] .bmc-nota {
  background:rgba(157,124,255,.08);
  border-color:rgba(216,206,255,.13);
  color:var(--text2);
}
:root[data-theme="dark"] .filter-lbl,
:root[data-theme="dark"] .vc-stat-lbl,
:root[data-theme="dark"] .bmc-fecha,
:root[data-theme="dark"] .bpc-label,
:root[data-theme="dark"] .vc-bl-nota {
  color:var(--text2);
}
:root[data-theme="dark"] .vc-stat-val,
:root[data-theme="dark"] .bmc-concepto,
:root[data-theme="dark"] .bpc-monto,
:root[data-theme="dark"] .info-highlight strong,
:root[data-theme="dark"] .bloqueo-title {
  color:var(--text);
}
:root[data-theme="dark"] .del-confirm-txt,
:root[data-theme="dark"] .bmc-desc,
:root[data-theme="dark"] .bpc-instruccion,
:root[data-theme="dark"] .vc-bl-desc {
  color:var(--text2);
}

/* CEO notifications */
.ceo-notify-card {
  margin: 0 0 18px;
}
.notify-count {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  margin-left:8px;
  padding:0 7px;
  border-radius:999px;
  background:var(--err);
  color:#fff;
  font-size:11px;
  font-weight:800;
}
.notify-count.is-empty {
  background:rgba(124,58,237,.12);
  color:var(--text3);
}
.ceo-notify-list {
  display:grid;
  gap:8px;
  padding:0 18px 18px;
}
.notify-item {
  display:grid;
  grid-template-columns:10px minmax(0, 1fr) auto;
  align-items:center;
  gap:12px;
  width:100%;
  padding:12px 14px;
  border:1px solid rgba(124,58,237,.12);
  border-radius:14px;
  background:rgba(255,255,255,.76);
  color:var(--text);
  text-align:left;
  cursor:pointer;
}
.notify-item:hover {
  border-color:rgba(124,58,237,.28);
  box-shadow:0 12px 24px rgba(76,29,149,.08);
}
.notify-item.is-unread {
  background:linear-gradient(135deg, rgba(124,58,237,.09), rgba(103,212,255,.08));
}
.notify-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(124,58,237,.24);
}
.notify-item.is-unread .notify-dot {
  background:var(--k1);
  box-shadow:0 0 0 4px rgba(124,58,237,.12);
}
.notify-main {
  min-width:0;
  display:grid;
  gap:3px;
}
.notify-main strong {
  font-size:13px;
  line-height:1.25;
}
.notify-main small,
.notify-main em {
  color:var(--text2);
  font-size:12px;
  line-height:1.35;
  font-style:normal;
  overflow-wrap:anywhere;
}
.notify-main em {
  color:var(--text3);
  font-family:'DM Mono', monospace;
  font-size:11px;
}
.notify-amount {
  color:var(--k4);
  font-weight:800;
  white-space:nowrap;
}
:root[data-theme="dark"] .notify-item {
  background:rgba(24,15,43,.88);
  border-color:rgba(216,206,255,.13);
  color:var(--text);
}
:root[data-theme="dark"] .notify-item.is-unread {
  background:linear-gradient(135deg, rgba(157,124,255,.16), rgba(103,212,255,.08));
}
