/* ═══════════════════════════════════════════════════════════════════
   MÓDULO INVERSIONES (inversiones.js) — prefijo .iv-
   Reutiliza los tokens de :root de styles.css
   ═══════════════════════════════════════════════════════════════════ */
.iv-root{animation:ivf .25s ease}
@keyframes ivf{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.iv-loading,.iv-empty{padding:40px;text-align:center;color:var(--mist);font-size:13px}
.iv-tabs{display:flex;gap:6px;overflow-x:auto;border-bottom:1px solid var(--border);margin-bottom:18px;-webkit-overflow-scrolling:touch}
.iv-tab{display:flex;align-items:center;gap:7px;padding:10px 16px;border:none;background:none;color:var(--slate);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:.15s}
.iv-tab span{font-size:15px}
.iv-tab:hover{color:var(--ocean)}
.iv-tab.active{color:var(--ocean);border-bottom-color:var(--ocean)}
.iv-mono{font-family:var(--mono)}
.iv-up{color:var(--green)!important}.iv-down{color:var(--red)!important}.iv-flat{color:var(--slate)!important}.iv-muted{color:var(--mist)!important}

.iv-hero{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;background:linear-gradient(135deg,var(--ink),var(--ocean));border-radius:14px;padding:24px 26px;color:#fff;margin-bottom:18px;box-shadow:var(--shadow-md)}
.iv-hero-lbl{font-size:12px;text-transform:uppercase;letter-spacing:.08em;opacity:.7}
.iv-hero-val{font-family:var(--serif);font-size:40px;line-height:1.05;margin:6px 0 12px}
.iv-hero-tags{display:flex;gap:8px;flex-wrap:wrap}
.iv-chip{padding:5px 11px;border-radius:20px;font-size:12px;font-weight:600;background:rgba(255,255,255,.14)}
.iv-chip.iv-up{background:rgba(5,150,105,.28);color:#9ff0c8!important}
.iv-chip.iv-down{background:rgba(229,62,62,.28);color:#ffc2c2!important}
.iv-chip.iv-neutral{background:rgba(255,255,255,.14)}
.iv-hero-side{display:flex;flex-direction:column;justify-content:center;gap:9px;border-left:1px solid rgba(255,255,255,.16);padding-left:20px}
.iv-hs-row{display:flex;justify-content:space-between;font-size:13px;opacity:.92}
.iv-hs-row b{font-family:var(--mono);font-weight:600}
.iv-hs-row .iv-up{color:#9ff0c8!important}.iv-hs-row .iv-down{color:#ffc2c2!important}

.iv-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.iv-kpi{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;box-shadow:var(--shadow)}
.iv-kpi-lbl{font-size:11px;color:var(--mist);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.iv-kpi-val{font-family:var(--mono);font-size:21px;font-weight:600;color:var(--ink);margin:5px 0 2px}
.iv-kpi-sub{font-size:12px;font-weight:600}

.iv-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.iv-card-h{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px}
.iv-card-t{font-size:15px;font-weight:700;color:var(--ink)}
.iv-card-s{font-size:12px;color:var(--mist);margin-top:2px}
.iv-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.iv-note{font-size:12px;color:var(--mist);margin-top:10px;line-height:1.5}

.iv-donut-wrap{position:relative;width:168px;margin:0 auto 8px}
.iv-donut{width:168px;height:168px}
.iv-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.dc-v{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--ink)}
.dc-l{font-size:11px;color:var(--mist)}
.iv-legend{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.iv-leg{display:flex;align-items:center;gap:8px;font-size:13px}
.iv-leg-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.iv-leg-name{flex:1;color:var(--slate)}
.iv-leg-val{font-family:var(--mono);font-weight:600;color:var(--ink)}
.iv-leg-pct{font-family:var(--mono);color:var(--mist);width:38px;text-align:right}

.iv-line{width:100%;height:auto;display:block}
.iv-xlabel{font-size:10px;fill:var(--mist);text-anchor:middle;font-family:var(--sans)}
.iv-bars{display:flex;align-items:flex-end;gap:6px;height:150px;padding-top:18px}
.iv-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}
.iv-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}
.iv-bar{width:70%;max-width:34px;border-radius:5px 5px 0 0;position:relative;min-height:4px;transition:.3s}
.iv-bar-tip{position:absolute;top:-16px;left:50%;transform:translateX(-50%);font-size:9px;font-family:var(--mono);color:var(--slate);white-space:nowrap;opacity:0;transition:.15s}
.iv-bar-col:hover .iv-bar-tip{opacity:1}
.iv-bar-lbl{font-size:10px;color:var(--mist);margin-top:5px}

.iv-callout{display:flex;align-items:center;gap:14px;background:var(--teal-dim);border:1px solid var(--teal-glow);border-radius:var(--r);padding:14px 18px;font-size:13px;color:var(--slate);margin-bottom:16px}
.iv-callout span:first-child{font-size:22px}
.iv-callout div{flex:1;line-height:1.5}

.iv-pill{padding:3px 9px;border-radius:14px;font-size:11px;font-weight:600;display:inline-block}
.iv-pill-green{background:var(--green-dim);color:var(--green)}
.iv-pill-ocean{background:var(--ocean-dim);color:var(--ocean)}
.iv-pill-amber{background:var(--amber-dim);color:var(--amber)}
.iv-pill-mist{background:var(--cloud);color:var(--slate)}
.iv-risk{display:inline-flex;align-items:center;gap:3px}
.iv-risk-dot{width:7px;height:7px;border-radius:50%}
.iv-risk-lbl{font-size:11px;font-weight:600;margin-left:4px}
.iv-btn{border:none;border-radius:8px;padding:8px 14px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:.15s}
.iv-btn-sm{padding:6px 11px;font-size:12px}
.iv-btn-primary{background:var(--ocean);color:#fff}
.iv-btn-primary:hover{background:var(--deep)}
.iv-btn-gold{background:var(--gold);color:#3a2e08}
.iv-btn-ghost{background:var(--cloud);color:var(--slate)}
.iv-btn-ghost:hover{background:var(--border)}
.iv-mini{border:none;background:var(--cloud);color:var(--slate);width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:12px}
.iv-mini:hover{background:var(--border)}
.iv-back{border:none;background:none;color:var(--ocean);font-weight:600;font-size:13px;cursor:pointer;padding:4px 0;margin-bottom:12px}

.iv-prop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.iv-prop-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:.18s;box-shadow:var(--shadow)}
.iv-prop-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--ocean)}
.iv-prop-top{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.iv-prop-ico{font-size:24px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:10px}
.iv-prop-id{flex:1;min-width:0}
.iv-prop-name{font-size:14px;font-weight:700;color:var(--ink)}
.iv-prop-loc{font-size:12px;color:var(--mist)}
.iv-prop-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px 0;border-top:1px solid var(--border)}
.iv-m-l{font-size:11px;color:var(--mist)}
.iv-m-v{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--ink)}
.iv-prop-foot{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--slate);padding-top:10px;border-top:1px solid var(--border)}
.iv-prop-foot b{font-family:var(--mono)}
.iv-prop-cta{font-size:12px;color:var(--ocean);font-weight:600;margin-top:10px}

.iv-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.iv-detail-name{font-family:var(--serif);font-size:24px;color:var(--ink)}
.iv-detail-sub{font-size:13px;color:var(--mist);margin-top:2px}
.iv-detail-tags{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

.iv-cap{display:flex;flex-direction:column;gap:2px}
.iv-cap-row{display:flex;justify-content:space-between;font-size:13px;padding:8px 10px;border-radius:7px}
.iv-cap-row span:first-child{color:var(--slate)}
.iv-cap-row.strong{background:var(--surface);font-weight:700}
.iv-cap-row.strong span:first-child{color:var(--ink)}
.iv-hip{margin-top:12px;font-size:12px;color:var(--slate);background:var(--surface);padding:10px 12px;border-radius:8px}
.iv-inline-edit{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;margin-top:12px}
.iv-inline-edit label{font-size:11px;color:var(--mist);display:block;margin-bottom:4px;width:100%}
.iv-inline-edit input{flex:1;min-width:140px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-family:var(--mono);font-size:14px}

.iv-ledger,.iv-ins-tbl,.iv-tx-tbl,.iv-mae-tbl,.iv-bud-tbl{overflow-x:auto;-webkit-overflow-scrolling:touch}
.iv-led-row{display:grid;grid-template-columns:90px 1fr 1fr 1fr 90px 1fr 32px;gap:8px;align-items:center;padding:9px 8px;border-bottom:1px solid var(--border);font-size:13px;min-width:620px}
.iv-led-head{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--mist);font-weight:700;border-bottom:1px solid var(--border)}
.iv-led-row span{text-align:right}
.iv-led-row span:first-child{text-align:left}
.iv-led-per{font-weight:600;color:var(--ink);text-transform:capitalize}

.iv-ins-row{display:grid;grid-template-columns:2.4fr 1.2fr 1.2fr 1fr 1fr .8fr 1fr;gap:10px;align-items:center;padding:11px 8px;border-bottom:1px solid var(--border);font-size:13px;min-width:720px;cursor:pointer;transition:.12s}
.iv-ins-row[data-ins]:hover{background:var(--surface)}
.iv-ins-head{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--mist);font-weight:700;cursor:default}
.iv-ins-head:hover{background:none}
.iv-ins-row span{text-align:right}
.iv-ins-name{text-align:left!important;display:flex;align-items:center;gap:9px}
.iv-ins-name i{width:9px;height:9px;border-radius:3px;flex-shrink:0}
.iv-ins-name b{font-size:13px;color:var(--ink);display:block}
.iv-ins-name small{font-size:11px;color:var(--mist)}
.iv-ins-fam{text-align:left!important;color:var(--slate)}
.iv-weight{display:flex;align-items:center;gap:6px;justify-content:flex-end;font-family:var(--mono);color:var(--slate)}
.iv-weight-bar{width:44px;height:6px;background:var(--cloud);border-radius:3px;overflow:hidden}
.iv-weight-bar i{display:block;height:100%}

.iv-tx-row{display:grid;grid-template-columns:1.2fr 1fr .8fr 1fr 1fr;gap:10px;padding:10px 8px;border-bottom:1px solid var(--border);font-size:13px;min-width:520px;align-items:center}
.iv-tx-row span{text-align:right}.iv-tx-row span:first-child,.iv-tx-row span:nth-child(2){text-align:left}
.iv-tx-head{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--mist);font-weight:700}
.iv-mae-row{display:grid;grid-template-columns:2.2fr 1.4fr 1fr 1fr 1.2fr;gap:10px;padding:11px 8px;border-bottom:1px solid var(--border);font-size:13px;min-width:640px;align-items:center}
.iv-mae-head{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--mist);font-weight:700}
.iv-fam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.iv-fam{border:1px solid var(--border);border-radius:10px;padding:13px}
.iv-fam-h{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);margin-bottom:9px}
.iv-fam-dot{width:11px;height:11px;border-radius:3px}
.iv-fam-subs{display:flex;flex-wrap:wrap;gap:6px}
.iv-sub-chip{font-size:11px;background:var(--surface);color:var(--slate);padding:4px 9px;border-radius:12px;border:1px solid var(--border)}

.iv-bud-row{display:grid;grid-template-columns:160px repeat(12,minmax(56px,1fr)) 78px;gap:2px;align-items:center;font-size:12px;min-width:980px;padding:2px 0}
.iv-bud-head{font-size:10px;text-transform:uppercase;color:var(--mist);font-weight:700;border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:4px}
.iv-bud-c{text-align:right;font-family:var(--mono)}
.iv-bud-tot{text-align:right;font-family:var(--mono);font-weight:700;color:var(--ink)}
.iv-bud-grp{margin-bottom:6px}
.iv-bud-grp-h{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--ocean);background:var(--surface);padding:6px 8px;border-radius:6px;margin:6px 0 2px}
.iv-bud-n3{color:var(--slate);padding-left:8px}
.iv-bud-row .iv-bud-c{color:var(--slate)}

.iv-empty-big{text-align:center;padding:60px 20px}
.iv-empty-ico{font-size:46px;margin-bottom:14px}
.iv-empty-t{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:6px}
.iv-empty-s{font-size:13px;color:var(--mist);max-width:420px;margin:0 auto;line-height:1.55}
.iv-modal-ov{position:fixed;inset:0;background:rgba(13,27,42,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:18px}
.iv-modal{background:#fff;border-radius:14px;padding:20px;width:100%;max-width:440px;box-shadow:var(--shadow-lg)}
.iv-modal-h{display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:14px;text-transform:capitalize}
.iv-modal-f{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
.iv-cobro-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.iv-cobro-row input{padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px}
.iv-ci-g{flex:1}.iv-ci-m{width:120px;font-family:var(--mono)}

@media(max-width:768px){
.iv-hero{grid-template-columns:1fr}.iv-hero-side{border-left:none;border-top:1px solid rgba(255,255,255,.16);padding-left:0;padding-top:14px}
.iv-hero-val{font-size:32px}
.iv-kpis{grid-template-columns:1fr 1fr}
.iv-grid2{grid-template-columns:1fr}
}

/* formularios de alta/edición */
.iv-tabhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:10px;flex-wrap:wrap}
.iv-tabhead-t{font-size:15px;font-weight:700;color:var(--ink)}
.iv-modal-lg{max-width:600px;max-height:88vh;overflow-y:auto}
.iv-ff-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px}
.iv-ff-row{display:flex;flex-direction:column;gap:4px;grid-column:1 / -1}
.iv-ff-row.half{grid-column:auto}
.iv-ff-row label{font-size:11px;color:var(--mist);font-weight:600}
.iv-ff{padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--sans);width:100%}
.iv-ff[type=number]{font-family:var(--mono)}
@media(max-width:560px){.iv-ff-row.half{grid-column:1 / -1}}

/* cashflow: comparación meta vs real */
.iv-bud2-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr .8fr 36px;gap:8px;align-items:center;font-size:12px;min-width:560px;padding:5px 0}
.iv-bud2-row span{text-align:right}
.iv-bud2-row span:first-child{text-align:left}
.iv-cmp-legend{display:flex;gap:16px;justify-content:flex-end;font-size:11px;color:var(--slate);margin-bottom:6px}
.iv-cmp-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:5px;vertical-align:-1px}
.iv-cmp-legend i.meta{background:var(--mist)}.iv-cmp-legend i.real{background:var(--teal)}
.iv-cmp-row{display:flex;align-items:flex-end;gap:8px;height:150px;overflow-x:auto;padding-top:18px}
.iv-cmp-col{flex:1;min-width:46px;display:flex;flex-direction:column;align-items:center;height:100%}
.iv-cmp-pair{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;gap:3px}
.iv-cmp-bar{width:42%;max-width:18px;border-radius:4px 4px 0 0;position:relative;min-height:3px;transition:.3s}
.iv-cmp-bar.meta{background:var(--mist);opacity:.55}
.iv-cmp-bar.real{background:var(--teal)}
.iv-cmp-col:hover .iv-bar-tip{opacity:1}

/* insights + acciones de cabecera + selector de orden */
.iv-tabhead-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.iv-sortsel{padding:6px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;font-family:var(--sans);background:#fff;color:var(--slate);cursor:pointer}
.iv-insight{display:flex;gap:11px;align-items:flex-start;padding:11px 12px;border-radius:9px;font-size:13px;line-height:1.45;color:var(--slate);margin-bottom:7px;border:1px solid var(--border);background:var(--surface)}
.iv-insight span{font-size:17px;line-height:1.2}
.iv-insight b{color:var(--ink)}
.iv-ins-good{background:var(--green-dim);border-color:rgba(5,150,105,.18)}
.iv-ins-bad{background:var(--red-dim);border-color:rgba(229,62,62,.18)}
.iv-ins-warning{background:var(--gold-dim);border-color:rgba(201,168,76,.25)}
.iv-ins-info{background:var(--ocean-dim);border-color:rgba(27,79,126,.15)}

/* objetivos (metas vs real) */
.iv-goal{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px}
.iv-goal-h{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--slate);margin-bottom:9px;gap:8px}
.iv-goal-h b{font-family:var(--mono);font-size:13px}
.iv-goalbar{height:9px;background:var(--cloud);border-radius:5px;overflow:hidden}
.iv-goalbar i{display:block;height:100%;border-radius:5px;transition:width .5s}

/* ── Informe Patrimonial (reportes.js) ── */
.rep-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.rep-actions-t{font-size:16px;font-weight:700;color:var(--ink)}
.rep-actions-s{font-size:12px;color:var(--mist);margin-top:2px}
.rep-doc{background:#fff;border:1px solid var(--border);border-radius:12px;padding:32px 34px;box-shadow:var(--shadow);max-width:860px;margin:0 auto}
.rep-up{color:var(--green)}.rep-down{color:var(--red)}
.rep-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border-bottom:2px solid var(--ink);padding-bottom:16px;margin-bottom:20px;flex-wrap:wrap}
.rep-brand{display:flex;align-items:center;gap:11px}
.rep-mark{width:42px;height:42px;border-radius:9px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--serif);font-size:17px}
.rep-org{font-size:15px;font-weight:700;color:var(--ink)}
.rep-orgsub{font-size:11px;color:var(--mist)}
.rep-meta{text-align:right}
.rep-doc-t{font-size:14px;font-weight:700;color:var(--ocean)}
.rep-doc-c{font-size:12px;color:var(--slate);margin-top:2px}
.rep-doc-d{font-size:11px;color:var(--mist)}
.rep-hero{background:var(--surface);border-radius:10px;padding:16px 20px;margin-bottom:22px;text-align:center}
.rep-hero-l{font-size:12px;color:var(--mist);text-transform:uppercase;letter-spacing:.06em}
.rep-hero-v{font-family:var(--serif);font-size:34px;color:var(--ink);margin-top:4px}
.rep-sec{margin-bottom:22px}
.rep-sec h3{font-size:13px;font-weight:700;color:var(--ink);border-bottom:1px solid var(--border);padding-bottom:6px;margin:0 0 12px}
.rep-kgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rep-k{border:1px solid var(--border);border-radius:9px;padding:12px 14px}
.rep-k-l{font-size:11px;color:var(--mist)}
.rep-k-v{font-family:var(--mono);font-size:18px;font-weight:600;color:var(--ink);margin:3px 0}
.rep-k-s{font-size:12px;color:var(--slate)}
.rep-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.rep-tbl th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--mist);font-weight:700;padding:7px 8px;border-bottom:1px solid var(--border)}
.rep-tbl td{padding:8px;border-bottom:1px solid var(--cloud);color:var(--slate)}
.rep-tbl td small{color:var(--mist)}
.rep-r{text-align:right;font-family:var(--mono)}
.rep-dot{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:7px;vertical-align:-1px}
.rep-empty{text-align:center;color:var(--mist)}
.rep-foot{font-size:10.5px;color:var(--mist);line-height:1.5;border-top:1px solid var(--border);padding-top:12px;margin-top:8px}
@media(max-width:560px){.rep-kgrid{grid-template-columns:1fr}.rep-doc{padding:20px 16px}}
@media print{
  #login-screen,.sidebar,.topbar,.bottom-nav,#menu-btn,.rep-actions,.iv-tabs{display:none!important}
  #app.visible{display:block!important}
  .main{margin:0!important}.content{padding:0!important}
  .view:not(.active){display:none!important}
  .rep-doc{box-shadow:none;border:none;max-width:100%;padding:0}
  body{background:#fff}
}

/* ── Vencimientos & Pendientes (pendientes.js) ── */
.ven-list{display:flex;flex-direction:column}
.ven-row{display:flex;align-items:center;gap:13px;padding:13px 6px;border-bottom:1px solid var(--border)}
.ven-row:last-child{border-bottom:none}
.ven-row-late{background:var(--red-dim);border-radius:8px;padding-left:10px;padding-right:10px}
.ven-ico{font-size:20px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:10px;flex-shrink:0}
.ven-main{flex:1;min-width:0}
.ven-title{font-size:14px;font-weight:600;color:var(--ink)}
.ven-sub{font-size:12px;color:var(--mist);margin-top:2px;text-transform:capitalize}
.ven-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ven-monto{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--ink)}
.ven-badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:12px;white-space:nowrap}
.ven-red{background:var(--red-dim);color:var(--red)}
.ven-amber{background:var(--amber-dim);color:var(--amber)}
.ven-green{background:var(--green-dim);color:var(--green)}
.ven-pill{font-size:10px;background:var(--cloud);color:var(--slate);padding:2px 7px;border-radius:10px;text-transform:capitalize}
.ven-clear{text-align:center;padding:60px 20px}
.ven-clear-t{font-size:18px;font-weight:700;color:var(--ink);margin:10px 0 6px}
.ven-clear-s{font-size:13px;color:var(--mist);max-width:400px;margin:0 auto;line-height:1.55}
@media(max-width:560px){.ven-right{flex-direction:column;align-items:flex-end;gap:5px}.ven-monto{font-size:13px}}

/* desglose patrimonio por fuente: leyenda clicable */
.iv-leg-click{cursor:pointer;border-radius:7px;padding:4px 6px;margin:-2px -6px;transition:.12s}
.iv-leg-click:hover{background:var(--surface)}
.iv-leg-click:hover .iv-leg-name{color:var(--ocean)}

/* KPIs configurables */
.iv-kpis-wrap{margin-bottom:18px}
.iv-kpis-wrap .iv-kpis{margin-bottom:0}
.iv-kpi-cfg{display:block;margin:0 0 8px auto;border:none;background:var(--cloud);color:var(--slate);font-size:12px;font-weight:600;cursor:pointer;padding:5px 11px;border-radius:7px}
.iv-kpi-cfg:hover{background:var(--border);color:var(--ocean)}

/* proyección interactiva (móvil + sliders + tooltip) */
.iv-proj-chart{position:relative;width:100%;height:210px;touch-action:none;cursor:crosshair}
.iv-proj-svg{width:100%;height:210px;display:block}
.iv-tip{position:absolute;pointer-events:none;background:var(--ink);color:#fff;border-radius:8px;padding:5px 9px;font-size:11px;opacity:0;transition:opacity .1s;white-space:nowrap;box-shadow:var(--shadow-md);z-index:2;display:flex;flex-direction:column;align-items:center}
.iv-tip b{font-family:var(--mono);font-size:12px}
.iv-tip span{opacity:.7;text-transform:capitalize;font-size:10px}
/* Eje X y marcadores como HTML sobre el SVG (no se estiran al escalar el SVG con
   preserveAspectRatio="none"). Posicionados por % sobre el ancho fijo del viewBox. */
.iv-xaxis{position:absolute;left:0;right:0;bottom:1px;height:14px;pointer-events:none}
.iv-xl{position:absolute;transform:translateX(-50%);font-size:10px;color:var(--mist);white-space:nowrap}
.iv-cdot{position:absolute;width:9px;height:9px;border-radius:50%;border:2px solid #fff;transform:translate(-50%,-50%);pointer-events:none;box-sizing:border-box}
.iv-cdot-lg{width:11px;height:11px}
.iv-proj-controls{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:14px 0 4px}
.iv-proj-ctl label{display:flex;justify-content:space-between;font-size:12px;color:var(--slate);margin-bottom:6px}
.iv-proj-ctl label b{font-family:var(--mono);color:var(--ink)}
.iv-proj-ctl input[type=range]{width:100%;accent-color:var(--gold);height:4px}
@media(max-width:560px){.iv-proj-controls{grid-template-columns:1fr}}

/* Wealth Management banner + tarjeta tributaria */
.iv-wealth{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#1A2E45,#0E7C7B);color:#fff;border-radius:14px;padding:18px 22px;margin-bottom:16px;box-shadow:var(--shadow-md);flex-wrap:wrap}
.iv-wealth-ic{font-size:30px;flex-shrink:0}
.iv-wealth-txt{flex:1;min-width:200px}
.iv-wealth-t{font-size:15px;font-weight:700}
.iv-wealth-s{font-size:12.5px;opacity:.85;margin-top:3px;line-height:1.5}
.iv-wealth-cta{display:flex;gap:8px;flex-wrap:wrap}
.iv-wealth-ghost{background:rgba(255,255,255,.16);color:#fff}
.iv-wealth-ghost:hover{background:rgba(255,255,255,.26)}
.iv-tax .iv-card-t{color:var(--ink)}
@media(max-width:560px){.iv-wealth-cta{width:100%}.iv-wealth-cta .iv-btn{flex:1}}

/* previsional como dato informativo (no suma) */
.iv-hs-sep{height:1px;background:rgba(255,255,255,.16);margin:4px 0}
.iv-hs-muted{opacity:.72}
.iv-hs-foot{font-size:10.5px;opacity:.6;margin-top:1px}
.iv-prev-chip{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px;padding:10px 12px;background:var(--purple-dim);border:1px dashed rgba(124,58,237,.32);border-radius:9px;font-size:13px;color:var(--slate);cursor:pointer}
.iv-prev-chip span{flex:1}
.iv-prev-chip b{font-family:var(--mono);color:var(--purple)}
.iv-prev-chip small{flex-basis:100%;font-size:11px;color:var(--mist)}

/* simulador de flujo de caja / liquidez */
.iv-cf-presets{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.iv-cf-presets>span{font-size:12px;color:var(--mist);font-weight:600}
.iv-cf-presets .iv-btn.active{background:var(--ocean);color:#fff}
.iv-cf-controls{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px}
.iv-cf-ctl label{display:flex;justify-content:space-between;font-size:12px;color:var(--slate);margin-bottom:6px;font-weight:600}
.iv-cf-ctl label b{font-family:var(--mono);color:var(--ink)}
.iv-cf-ctl input[type=number]{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-family:var(--mono);font-size:14px}
.iv-cf-ctl input[type=range]{width:100%;accent-color:var(--ocean);height:4px}
.iv-cf-banner{display:flex;gap:12px;align-items:center;border-radius:10px;padding:13px 16px;font-size:13px;margin-bottom:14px;line-height:1.45}
.iv-cf-banner>:first-child{font-size:22px;flex-shrink:0}
.iv-cf-banner.danger{background:var(--red-dim);border:1px solid rgba(229,62,62,.3)}
.iv-cf-banner.warn{background:var(--amber-dim);border:1px solid rgba(217,119,6,.3)}
.iv-cf-banner.ok{background:var(--green-dim);border:1px solid rgba(5,150,105,.25)}
.iv-cf-banner b{color:var(--ink)}
.iv-cf-det{margin-bottom:14px}
.iv-cf-det>summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--ocean);padding:10px 0;list-style:none}
.iv-cf-det>summary::-webkit-details-marker{display:none}
.iv-cf-det>summary:before{content:'▸ '}
.iv-cf-det[open]>summary:before{content:'▾ '}
@media(max-width:560px){.iv-cf-controls{grid-template-columns:1fr}}

/* ── Tooltips educativos ── */
.iv-gtip{position:absolute;z-index:3000;max-width:280px;background:var(--ink);color:#fff;border-radius:10px;padding:10px 12px;font-size:12px;line-height:1.5;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(4px);transition:opacity .14s,transform .14s;pointer-events:none}
.iv-gtip.on{opacity:1;transform:none}
.iv-gtip-d{font-weight:600}
.iv-gtip-r{margin-top:5px;opacity:.85;font-size:11px}
.iv-gtip-r b{color:var(--gold-lt);font-weight:600}
.iv-i{font-size:11px;color:var(--mist);cursor:help;vertical-align:1px}
[data-tip]{cursor:help}
.iv-kpi[data-tip],.iv-chip[data-tip]{cursor:help}

/* ── Wealth Management dashboard ── */
@keyframes iv-rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.iv-wm-reveal{animation:iv-rise .5s ease backwards}
.iv-wm-hero{text-align:center;background:radial-gradient(120% 140% at 50% 0%,#16324d 0%,var(--ink) 60%);color:#fff;border-radius:16px;padding:30px 22px 26px;margin-bottom:16px;box-shadow:var(--shadow-md)}
.iv-wm-tag{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--gold-lt);background:rgba(201,168,76,.14);border:1px solid rgba(201,168,76,.3);padding:5px 14px;border-radius:20px;margin-bottom:16px}
.iv-wm-lbl{font-size:13px;opacity:.8;text-transform:uppercase;letter-spacing:.06em}
.iv-wm-lbl .iv-i{color:rgba(255,255,255,.6)}
.iv-wm-val{font-family:var(--serif);font-size:46px;line-height:1.05;margin:6px 0 14px}
.iv-wm-tags{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.iv-wm-tags .iv-chip{background:rgba(255,255,255,.14)}
@media(max-width:560px){.iv-wm-val{font-size:36px}}

.iv-wm-distrow{display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:center}
.iv-donut-lg{width:200px}
.iv-donut-lg .iv-donut{width:200px;height:200px}
.iv-donut-lg .dc-v{font-size:20px}
@keyframes iv-pop{from{transform:scale(.9);opacity:.4}to{transform:none;opacity:1}}
.iv-donut-i{animation:iv-pop .55s cubic-bezier(.2,.8,.2,1)}
@keyframes iv-seg-in{from{opacity:0}to{opacity:1}}
.iv-dseg{opacity:0;animation:iv-seg-in .5s ease forwards;transition:stroke-width .15s;cursor:pointer}
.iv-dseg:hover{stroke-width:34}
.iv-wm-legend{flex:1;min-width:240px;display:flex;flex-direction:column;gap:4px}
.iv-wmleg{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;cursor:pointer;transition:.14s;font-size:13px}
.iv-wmleg:hover{background:var(--surface)}
.iv-wmleg:hover .iv-wmleg-go{transform:translateX(3px);color:var(--ocean)}
.iv-wmleg-ic{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.iv-wmleg-name{flex:1;color:var(--slate);font-weight:600;min-width:0}
.iv-wmleg-bar{width:64px;height:7px;background:var(--cloud);border-radius:4px;overflow:hidden;flex-shrink:0}
.iv-wmleg-bar i{display:block;height:100%;border-radius:4px;width:0;animation:iv-barw .7s .2s ease forwards}
@keyframes iv-barw{from{width:0}}
.iv-wmleg-val{font-family:var(--mono);font-weight:600;color:var(--ink);width:64px;text-align:right;flex-shrink:0}
.iv-wmleg-pct{font-family:var(--mono);color:var(--mist);width:38px;text-align:right;flex-shrink:0}
.iv-wmleg-go{color:var(--border);font-size:18px;font-weight:700;transition:.14s;flex-shrink:0}

.iv-evo-toggle{display:flex;gap:4px;background:var(--cloud);border-radius:9px;padding:3px}
.iv-etg{border:none;background:none;padding:6px 12px;border-radius:7px;font-size:12px;font-weight:600;color:var(--slate);cursor:pointer;transition:.14s}
.iv-etg.active{background:#fff;color:var(--ocean);box-shadow:var(--shadow)}
.iv-wm-detlbl{font-size:12px;color:var(--mist);margin:6px 0 12px}

/* ============================================================
   App móvil — targets táctiles ≥44px en controles de Inversiones que
   se renderizan sin datos (tabs y botones de acción). Solo <=768px
   (anti-regresión). Los controles densos dependientes de datos
   (.iv-mini, .iv-btn-sm) quedan pendientes hasta poder verificar su
   layout con sesión real.
   ============================================================ */
@media(max-width:768px){
.iv-tab{min-height:44px}
.iv-btn:not(.iv-btn-sm){min-height:44px;display:inline-flex;align-items:center;justify-content:center}
}

/* campo de ahorro escribible en simulaciones */
.iv-proj-ctl input[type=number]{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-family:var(--mono);font-size:14px}
