:root{
  /* Fondos */
  --bg:#FFFFFF; --surface:#F2F7F6; --surface2:#E2EFED;
  /* Bordes */
  --border:#C2D9D5;
  /* Primario — Verde corporativo Banca March */
  --gold:#016658; --gold-l:#018A76;
  /* Texto */
  --text:#0D2926; --muted:#5A7A76;
  /* Semánticos */
  --red:#B52828; --teal:#016658; --amber:#C47A00; --blue:#0D4A8A;
  /* Acento dorado Banca March */
  --accent:#E7B256; --accent-d:#C8922A;
}

*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;min-height:100vh;overflow-x:hidden;}

/* HEADER */
header{padding:14px 60px 12px;border-bottom:1px solid var(--border);background:#fff;position:sticky;top:0;z-index:100;}
.logo-line{display:flex;align-items:center;gap:14px;margin-bottom:0;}
.logo-icon{width:24px;height:24px;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;transform:rotate(45deg);font-size:9px;color:var(--gold);}
h1{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:18px;font-weight:800;letter-spacing:-0.3px;background:linear-gradient(135deg,var(--gold-l),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.subtitle{color:var(--muted);font-size:12px;letter-spacing:3px;text-transform:uppercase;margin-left:46px;}

/* NAV TABS */
.nav-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-top:16px;overflow-x:auto;}
.nav-tab{padding:10px 20px;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .2s;}
.nav-tab:hover{color:var(--gold);}
.nav-tab.active{color:var(--gold);border-bottom-color:var(--gold);}

/* LAYOUT */
.container{max-width:1100px;margin:0 auto;padding:36px 60px;}
@media(max-width:700px){.container{padding:20px 16px;}header{padding:10px 16px 8px;}.subtitle{margin-left:0;}}

/* SECTIONS */
.section{display:none;}
.section.active{display:block;}

/* STEP CARDS */
.card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:28px 32px;margin-bottom:20px;}
.card-title{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:15px;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:10px;}
.card-sub{font-size:12px;color:var(--muted);margin-bottom:20px;}
.section-header{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.section-header::after{content:'';flex:1;height:1px;background:var(--border);}

/* GRID */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
.grid4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px;}
@media(max-width:800px){.grid2,.grid3,.grid4{grid-template-columns:1fr 1fr;}}
@media(max-width:500px){.grid2,.grid3,.grid4{grid-template-columns:1fr;}}

/* FORM FIELDS */
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);font-weight:600;}
.field input,.field select,.field textarea{border:1.5px solid var(--border);border-radius:6px;padding:11px 14px;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:14px;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s;}
.field input::placeholder,.field textarea::placeholder{color:#d4d4d4;opacity:1;}
.field input:focus,.field select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(26,92,42,.07);}
.field input[type=number]{-moz-appearance:textfield;}
.field input[type=number]::-webkit-outer-spin-button,.field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;}
.field input.spin-visible[type=number]{-moz-appearance:auto;}
.field input.spin-visible[type=number]::-webkit-outer-spin-button,.field input.spin-visible[type=number]::-webkit-inner-spin-button{-webkit-appearance:auto;}

.sug-chip{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:5px 12px;background:rgba(1,102,88,.05);border:1px solid rgba(1,102,88,.18);border-radius:20px;cursor:pointer;transition:all .2s;animation:chipIn .3s ease;}
.sug-chip:hover{background:rgba(1,102,88,.12);border-color:#016658;}
.sug-chip-text{font-size:11px;color:#016658;font-weight:600;}
.sug-chip-btn{font-size:9px;color:#fff;background:#016658;padding:2px 8px;border-radius:10px;font-weight:700;letter-spacing:.3px;}
@keyframes chipIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.auto-detected{display:inline-flex;align-items:center;gap:5px;margin-top:4px;padding:4px 10px;background:rgba(231,178,86,.1);border:1px solid rgba(231,178,86,.3);border-radius:12px;font-size:10px;font-weight:600;color:#8B6914;animation:chipIn .3s ease;}
.ahorro-pills{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px;}
.ahorro-pills button{padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:#fff;font-size:11px;color:#5A7A76;cursor:pointer;transition:all .15s;}
.ahorro-pills button:hover{border-color:#016658;color:#016658;}
.ahorro-pills button.sel{background:#016658;color:#fff;border-color:#016658;}
.field-hint{font-size:11px;color:var(--muted);font-style:italic;}

/* TOGGLE */
.toggle-group{display:flex;border:1.5px solid var(--border);border-radius:6px;overflow:hidden;}
.toggle-opt{flex:1;padding:10px 8px;text-align:center;font-size:13px;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;cursor:pointer;background:var(--bg);color:var(--muted);border:none;transition:all .2s;font-weight:400;}
.toggle-opt.on{background:var(--gold);color:#fff;font-weight:600;}

/* COMPUTED BADGE */
.computed-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(26,92,42,.08);border:1px solid rgba(26,92,42,.2);border-radius:20px;font-size:13px;color:var(--gold);font-weight:600;}
.computed-badge.warn{background:rgba(196,122,0,.08);border-color:rgba(196,122,0,.3);color:var(--amber);}
.computed-badge.danger{background:rgba(181,40,40,.08);border-color:rgba(181,40,40,.3);color:var(--red);}

/* DYNAMIC ROWS */
.dyn-table{margin-bottom:16px;}
.dyn-row{display:grid;gap:10px;align-items:end;padding:14px 16px;background:var(--bg);border:1.5px solid var(--border);border-radius:6px;margin-bottom:8px;position:relative;}
.dyn-row:hover{border-color:var(--gold);}
.dyn-row .del-btn{position:absolute;top:10px;right:10px;width:26px;height:26px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--red);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.dyn-row .del-btn:hover{background:rgba(181,40,40,.1);border-color:var(--red);}
.add-row-btn{display:flex;align-items:center;gap:8px;border:1.5px dashed var(--border);border-radius:6px;background:transparent;color:var(--gold);font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:13px;font-weight:600;padding:11px 20px;cursor:pointer;transition:all .2s;width:100%;justify-content:center;}
.add-row-btn:hover{border-color:var(--gold);background:rgba(26,92,42,.04);}

/* COLCHON */
.colchon-result{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:20px 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:600px){.colchon-result{grid-template-columns:1fr;}}
.cr-item .cr-lbl{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
.cr-item .cr-val{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:22px;font-weight:700;color:var(--gold);}
.cr-item .cr-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.slider-wrap{margin-top:16px;}
.slider-lbl{font-size:12px;color:var(--muted);margin-bottom:8px;}
input[type=range]{width:100%;-webkit-appearance:none;height:3px;background:var(--border);border-radius:2px;outline:none;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 2px 8px rgba(26,92,42,.3);}
.slider-ticks{display:flex;justify-content:space-between;margin-top:6px;font-size:10px;color:var(--muted);}
.alert-box{padding:14px 18px;border-radius:6px;font-size:13px;line-height:1.6;margin-top:14px;}
.alert-box.warn{background:rgba(196,122,0,.07);border:1.5px solid rgba(196,122,0,.3);color:#7a4800;}
.alert-box.danger{background:rgba(181,40,40,.06);border:1.5px solid rgba(181,40,40,.25);color:var(--red);}
.alert-box.info{background:rgba(26,92,42,.06);border:1.5px solid rgba(26,92,42,.2);color:var(--gold);}
.opts-row{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;}
.opt-btn{padding:9px 18px;border-radius:4px;font-size:13px;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;cursor:pointer;border:1.5px solid;transition:all .2s;font-weight:600;}
.opt-btn.danger{border-color:var(--red);color:var(--red);background:transparent;}
.opt-btn.danger.sel,.opt-btn.danger:hover{background:var(--red);color:#fff;}
.opt-btn.primary{border-color:var(--gold);color:var(--gold);background:transparent;}
.opt-btn.primary.sel,.opt-btn.primary:hover{background:var(--gold);color:#fff;}

/* QUIZ */
.quiz-progress{display:flex;gap:6px;margin-bottom:24px;}
.quiz-pip{height:4px;flex:1;border-radius:2px;background:var(--border);transition:background .3s;}
.quiz-pip.done{background:var(--gold);}
.quiz-pip.active{background:var(--gold-l);}
.quiz-q{display:none;}
.quiz-q.active{display:block;}
.quiz-q-num{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.quiz-q-text{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:16px;font-weight:700;margin-bottom:18px;line-height:1.4;}
.quiz-opts{display:flex;flex-direction:column;gap:8px;}
.quiz-opt{display:flex;align-items:flex-start;gap:14px;padding:13px 16px;border:1.5px solid var(--border);border-radius:6px;cursor:pointer;background:var(--surface);transition:all .2s;}
.quiz-opt:hover{border-color:var(--gold-l);background:var(--surface2);}
.quiz-opt.sel{border-color:var(--gold);background:var(--surface2);box-shadow:0 0 0 3px rgba(26,92,42,.08);}
.quiz-opt-ltr{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted);flex-shrink:0;transition:all .2s;}
.quiz-opt.sel .quiz-opt-ltr{background:var(--gold);border-color:var(--gold);color:#fff;}
.quiz-opt-txt{font-size:13px;line-height:1.5;padding-top:2px;}
.quiz-nav{display:flex;justify-content:space-between;align-items:center;margin-top:20px;}
.q-btn{padding:10px 22px;border-radius:4px;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:1.5px solid;transition:all .2s;}
.q-btn.prev{border-color:var(--border);color:var(--muted);background:transparent;}
.q-btn.prev:hover{border-color:var(--gold);color:var(--gold);}
.q-btn.next{border-color:var(--gold);background:var(--gold);color:#fff;}
.q-btn.next:disabled{opacity:.35;cursor:not-allowed;}
.perfil-badge{display:none;align-items:center;gap:20px;padding:20px 24px;border-radius:8px;border:1.5px solid;margin-top:16px;flex-wrap:wrap;}
.perfil-badge.show{display:flex;}
.perfil-icon{font-size:36px;}
.perfil-name{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:20px;font-weight:900;}
.perfil-score{font-size:12px;color:var(--muted);margin-top:2px;}
.perfil-desc{font-size:13px;margin-top:4px;line-height:1.5;}
.perfil-retry{margin-left:auto;padding:8px 16px;border:1.5px solid var(--border);border-radius:4px;background:transparent;font-size:12px;color:var(--muted);cursor:pointer;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;}
.perfil-retry:hover{border-color:var(--gold);color:var(--gold);}

/* OBJECTIVES */
.obj-priority-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.obj-priority-badge.p1{background:rgba(181,40,40,.1);color:var(--red);}
.obj-priority-badge.p2{background:rgba(196,122,0,.1);color:var(--amber);}
.obj-priority-badge.acc{background:rgba(26,92,42,.08);color:var(--gold);}

/* RUN BUTTON */
.run-btn{width:100%;padding:20px;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:17px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--gold-l),var(--gold));border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:14px;transition:all .3s;}
.run-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px rgba(26,92,42,.3);}
.run-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;}
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:none;}
.run-btn.loading .spinner{display:block;}
.run-btn.loading .btn-text{opacity:.6;}
@keyframes spin{to{transform:rotate(360deg);}}

/* RESULTS */
#secResultados{display:none;}
.pdf-btn{width:100%;margin-top:24px;padding:18px;font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:15px;font-weight:700;color:#fff;background:linear-gradient(135deg,#8b1a1a,#b52828);border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s;}
.pdf-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(181,40,40,.3);}
.pdf-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.pdf-progress{display:none;margin-top:12px;font-size:13px;color:var(--muted);text-align:center;}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
@media(max-width:700px){.kpi-row{grid-template-columns:1fr 1fr;}}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:18px 16px;text-align:center;}
.kpi-val{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:24px;font-weight:900;color:var(--gold);line-height:1;}
.kpi-val.pos{color:var(--gold-l);}
.kpi-val.neg{color:var(--red);}
.kpi-val.warn{color:var(--amber);}
.kpi-lbl{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:5px;}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px 28px;margin-bottom:20px;}
.chart-card h3{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:14px;font-weight:700;margin-bottom:4px;}
.chart-card .chart-sub{font-size:11px;color:var(--muted);margin-bottom:20px;}
.chart-card canvas{max-height:320px;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
@media(max-width:800px){.two-col{grid-template-columns:1fr;}}

/* OBJETIVO RESULT */
.obj-result-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:14px 18px;border-radius:6px;border:1px solid var(--border);margin-bottom:8px;background:var(--bg);}
.obj-result-icon{font-size:22px;}
.obj-result-name{font-weight:600;font-size:14px;}
.obj-result-date{font-size:12px;color:var(--muted);}
.obj-result-status{font-size:12px;font-weight:700;padding:4px 12px;border-radius:12px;}
.obj-result-status.ok{background:rgba(26,92,42,.1);color:var(--gold);}
.obj-result-status.ko{background:rgba(181,40,40,.1);color:var(--red);}
.obj-result-status.parcial{background:rgba(196,122,0,.1);color:var(--amber);}

/* CARTERA COMPARISON */
.ratio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px;}
.ratio-item{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:12px;text-align:center;position:relative;}
.ratio-val{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;font-size:18px;font-weight:700;color:var(--gold);}
.ratio-val.neg{color:var(--red);}
.ratio-lbl{font-size:10px;font-weight:600;letter-spacing:1px;color:var(--text);}
.ratio-sub{font-size:9px;color:var(--muted);margin-top:2px;}
.ratio-interp{font-size:11px;color:var(--muted);margin-top:8px;padding-top:8px;border-top:1px solid var(--border);text-align:left;line-height:1.55;}
.res-hidden{display:none !important;}
.ratio-info{position:absolute;top:6px;right:8px;width:14px;height:14px;border-radius:50%;background:var(--border);color:var(--muted);font-size:9px;font-weight:700;cursor:help;display:flex;align-items:center;justify-content:center;line-height:1;}
.ratio-info:hover::after{content:attr(data-tip);position:absolute;bottom:120%;right:0;background:#222;color:#fff;font-size:10px;font-weight:400;padding:6px 9px;border-radius:5px;white-space:pre-wrap;max-width:200px;z-index:99;line-height:1.5;box-shadow:0 4px 16px rgba(0,0,0,0.25);}

/* TABLA COMPARATIVA */
.comp-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px;}
.comp-table th{padding:9px 14px;font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);font-weight:600;border-bottom:2px solid var(--gold);text-align:right;}
.comp-table th:first-child{text-align:left;}
.comp-table td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle;text-align:right;font-weight:600;font-size:13px;}
.comp-table td:first-child{text-align:left;font-weight:400;color:var(--muted);font-size:12px;}
.comp-table tr:last-child td{border-bottom:none;}
.comp-table tr:hover td{background:var(--surface2);}
.delta-pos{color:#1a7a3a;}
.delta-neg{color:#b52828;}
.delta-neu{color:var(--muted);}
.comp-semaforo{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle;}

/* LEGEND */
.legend-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;}
.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);}
.legend-dot{width:16px;height:3px;border-radius:1px;}
.legend-dot.dashed{border-top:2px dashed;background:transparent;}

/* MISC */
.gap-alert{padding:16px 20px;background:rgba(181,40,40,.06);border:1.5px solid rgba(181,40,40,.3);border-radius:6px;font-size:13px;line-height:1.6;}
.gap-alert strong{color:var(--red);}

.panel-palanca{background:#f9f7f3;border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:12px;}
.pal-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
.pal-num{width:28px;height:28px;border-radius:50%;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;}
.pal-title{font-weight:600;font-size:14px;margin-bottom:3px;}
.pal-sub{font-size:12px;color:var(--muted);}
.pal-body{padding-left:40px;}

/* ── Intro banner ──────────────────────────────────────── */
.intro-banner{
  background: linear-gradient(160deg, #014d3e 0%, #016658 100%);
  border-bottom: 3px solid var(--gold);
  padding: 0;
}
.intro-banner-inner{
  max-width: 900px;
  margin: 0 auto;
  padding: 32px 36px;
  display: flex;
  gap: 32px;
  align-items: flex-start;
}
.intro-banner-accent{
  flex-shrink: 0;
  width: 4px;
  align-self: stretch;
  background: var(--gold);
  border-radius: 2px;
  min-height: 80px;
}
.intro-banner-text{ flex: 1; }
.intro-banner-lead{
  font-size: 15.5px;
  font-weight: 600;
  color: #fff;
  line-height: 1.5;
  margin: 0 0 14px 0;
}
.intro-banner-lead em{
  font-weight: 400;
  font-style: italic;
  color: rgba(255,255,255,0.9);
}
.intro-banner-body{
  font-size: 13.5px;
  line-height: 1.7;
  color: rgba(255,255,255,0.75);
  margin: 0 0 10px 0;
}
.intro-banner-body:last-child{ margin-bottom: 0; }
.intro-banner-body strong{ color: rgba(255,255,255,0.95); font-weight: 600; }

/* ── Proyección inmobiliaria ───────────────────────────── */
/* Paleta explícita (sin variables --green / --green-dark que no existen) */
/* Fondos: blanco #fff / gris muy claro #f7f9f7                           */
/* Texto principal: #0d2e14  Texto secundario: #3a5a42  Énfasis: #1a5c2a  */
/* Positivo: #1a5c2a  Negativo: #b52828  Dorado: #c47a00                  */

.inm-proy-summary {
  display: flex; gap: 1px; background: #c5d9c5;
  border-radius: 8px; overflow: hidden; margin-bottom: 16px;
}
.inm-proy-sum-cell {
  flex: 1; background: #fff; padding: 12px 16px;
  display: flex; flex-direction: column; gap: 3px;
}
.inm-proy-sum-cell:first-child { border-radius: 8px 0 0 8px; }
.inm-proy-sum-cell:last-child  { border-radius: 0 8px 8px 0; }
.inm-proy-sum-lbl { font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #3a5a42; }
.inm-proy-sum-val { font-size: 17px; font-weight: 800; color: #1a5c2a; }
.inm-proy-sum-val.red { color: #b52828; }
.inm-proy-sum-val.gold { color: #c47a00; }
.inm-proy-sum-hint { font-size: 10px; color: #3a5a42; }

.inm-proy-momento-hdr { display: grid; gap: 0; margin-bottom: 3px; }
.inm-proy-momento-lbl {
  text-align: center; padding: 7px 6px; font-size: 10px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase; color: #fff; border-radius: 5px 5px 0 0;
  margin: 0 2px;
}
.inm-proy-momento-lbl.hoy { background: #1a7a3a; }
.inm-proy-momento-lbl.jub { background: #c47a00; }
.inm-proy-momento-lbl.hor { background: #0d4a20; }
.inm-proy-momento-sub { font-size: 9px; font-weight: 400; letter-spacing: 0; text-transform: none; opacity: .9; display: block; margin-top: 1px; }

.inm-proy-card {
  background: #fff; border: 1px solid #c5d9c5; border-radius: 8px;
  margin-bottom: 10px; overflow: hidden;
}
.inm-proy-card-hdr {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  background: #eaf2ea; border-bottom: 1px solid #c5d9c5;
}
.inm-proy-badge {
  font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  padding: 2px 8px; border-radius: 20px; color: #fff; background: #1a7a3a;
}
.inm-proy-badge.alquiler { background: #c47a00; }
.inm-proy-badge.habitual { background: #0d4a20; }
.inm-proy-badge.segunda  { background: #2a6a4a; }
.inm-proy-badge.sinuso   { background: #666; }
.inm-proy-card-name { font-size: 13px; font-weight: 700; color: #0d2e14; }
.inm-proy-card-tipo { font-size: 10px; color: #3a5a42; margin-left: auto; font-weight: 600; }

.inm-proy-grid { display: grid; }
.inm-proy-row-lbl {
  padding: 9px 14px; font-size: 11px; color: #3a5a42; font-weight: 500;
  display: flex; align-items: center; border-bottom: 1px solid #e4ede4;
  background: #f7f9f7;
}
.inm-proy-row-lbl b { color: #0d2e14; font-weight: 700; }
.inm-proy-row-lbl:last-child { border-bottom: none; }
.inm-proy-cell {
  padding: 9px 12px; text-align: right; border-left: 1px solid #e4ede4;
  border-bottom: 1px solid #e4ede4; font-size: 12px; background: #fff;
  display: flex; flex-direction: column; align-items: flex-end; justify-content: center; gap: 2px;
}
.inm-proy-cell:last-child { border-bottom: none; }
.inm-proy-cell .v { font-weight: 700; font-size: 13px; color: #0d2e14; }
.inm-proy-cell .v.g { color: #1a5c2a; }
.inm-proy-cell .v.r { color: #b52828; }
.inm-proy-cell .v.m { color: #666; }
.inm-proy-cell .d { font-size: 10px; color: #3a5a42; }
.inm-proy-cell .d.up { color: #1a5c2a; font-weight: 600; }
.inm-proy-barwrap { width: 100%; height: 5px; background: #ddeedd; border-radius: 3px; margin-top: 5px; overflow: hidden; }
.inm-proy-bar { height: 100%; border-radius: 3px; }
.inm-proy-bar.hoy { background: #1a7a3a; }
.inm-proy-bar.jub { background: #c47a00; }
.inm-proy-bar.hor { background: #0d4a20; }

.inm-proy-totales {
  background: #0d3a1a; border-radius: 8px; overflow: hidden; margin-bottom: 16px;
}
.inm-proy-totales-grid { display: grid; }
.inm-proy-tot-lbl {
  padding: 11px 14px; font-size: 11px; font-weight: 600; color: #a8d4b4;
  display: flex; align-items: center; border-bottom: 1px solid rgba(255,255,255,.10);
}
.inm-proy-tot-lbl.big { font-size: 13px; color: #fff; font-weight: 800; }
.inm-proy-tot-lbl:last-child { border-bottom: none; }
.inm-proy-tot-cell {
  padding: 11px 12px; text-align: right; border-left: 1px solid rgba(255,255,255,.10);
  border-bottom: 1px solid rgba(255,255,255,.10);
  display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
}
.inm-proy-tot-cell:last-child { border-bottom: none; }
.inm-proy-tot-cell .v { font-size: 15px; font-weight: 800; color: #fff; }
.inm-proy-tot-cell .v.big { font-size: 17px; color: #7ee8a0; }
.inm-proy-tot-cell .v.gold { color: #ffd06a; }
.inm-proy-tot-cell .d { font-size: 10px; color: #7aaa8a; }
.inm-proy-tot-cell .d.up { color: #7ee8a0; font-weight: 600; }

.inm-proy-yield {
  display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px;
}
.inm-proy-yield-card {
  flex: 1; min-width: 180px; background: #fff; border: 1px solid #c5d9c5;
  border-radius: 8px; padding: 12px 14px;
}
.inm-proy-yield-title {
  font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: #3a5a42; margin-bottom: 8px;
}
.inm-proy-yield-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 4px 0; border-bottom: 1px solid #e4ede4; font-size: 11px; color: #0d2e14;
}
.inm-proy-yield-row:last-child { border-bottom: none; }
.inm-proy-yield-row span { font-weight: 700; color: #1a5c2a; }
.inm-proy-yield-row span.red { color: #b52828; }
.inm-proy-nota {
  background: #fff8ec; border-left: 3px solid #c47a00;
  border-radius: 0 6px 6px 0; padding: 10px 14px;
  font-size: 11px; color: #3a3a1a; line-height: 1.6;
}
.inm-proy-nota b { color: #c47a00; }

/* ══════════════════════════════════════════════════
   MÓDULO IA — Panel de análisis
══════════════════════════════════════════════════ */
#ia-fab{
  position:fixed;bottom:32px;right:32px;z-index:900;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#018A76,#016658);
  border:none;cursor:pointer;box-shadow:0 4px 20px rgba(1,102,88,.45);
  display:none;align-items:center;justify-content:center;
  transition:transform .2s,box-shadow .2s;
}
#ia-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(1,102,88,.55);}
#ia-fab svg{width:26px;height:26px;fill:#fff;}
#ia-fab .ia-badge{
  position:absolute;top:-4px;right:-4px;width:18px;height:18px;
  background:#c47a00;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:9px;font-weight:700;color:#fff;
  border:2px solid #fff;
}

#ia-drawer{
  position:fixed;top:0;right:-440px;width:440px;height:100vh;
  background:#fff;border-left:1px solid var(--border);
  z-index:950;display:flex;flex-direction:column;
  transition:right .35s cubic-bezier(.4,0,.2,1);
  box-shadow:-8px 0 40px rgba(0,0,0,.12);
}
#ia-drawer.open{right:0;}
@media(max-width:480px){
  #ia-drawer{width:100vw;right:-100vw;}
}

.ia-drawer-header{
  padding:18px 20px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;flex-shrink:0;
  background:linear-gradient(135deg,#014d3e,#016658);
}
.ia-drawer-logo{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;font-size:17px;
}
.ia-drawer-title{color:#fff;font-size:14px;font-weight:700;letter-spacing:.3px;}
.ia-drawer-sub{color:rgba(255,255,255,.65);font-size:11px;margin-top:1px;}
.ia-close-btn{
  margin-left:auto;width:30px;height:30px;border-radius:50%;
  border:1px solid rgba(255,255,255,.25);background:transparent;
  color:#fff;font-size:16px;cursor:pointer;display:flex;
  align-items:center;justify-content:center;transition:background .2s;
}
.ia-close-btn:hover{background:rgba(255,255,255,.15);}

.ia-tabs{
  display:flex;border-bottom:1px solid var(--border);flex-shrink:0;
}
.ia-tab{
  flex:1;padding:10px;font-size:12px;font-weight:600;letter-spacing:.5px;
  text-transform:uppercase;color:var(--muted);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  background:transparent;border-top:none;border-left:none;border-right:none;
  transition:color .2s;text-align:center;
}
.ia-tab.active{color:var(--gold);border-bottom-color:var(--gold);}

.ia-panel{display:none;flex:1;overflow-y:auto;flex-direction:column;}
.ia-panel.active{display:flex;}

/* Panel narrativa */
.ia-narr-body{padding:20px;flex:1;}
.ia-narr-btn{
  width:100%;padding:14px;background:linear-gradient(135deg,#018A76,#016658);
  color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  gap:10px;transition:opacity .2s;margin-bottom:16px;
}
.ia-narr-btn:disabled{opacity:.45;cursor:not-allowed;}
.ia-narr-spinner{
  width:16px;height:16px;border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;
  display:none;
}
.ia-narr-btn.loading .ia-narr-spinner{display:block;}
.ia-narr-btn.loading .ia-narr-btn-txt{opacity:.6;}

.ia-narr-output{
  font-size:13px;line-height:1.8;color:var(--text);
  background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:18px 20px;min-height:80px;
  white-space:pre-wrap;display:none;
}
.ia-narr-output.visible{display:block;}
.ia-narr-output h4{
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);margin:14px 0 6px;
}
.ia-narr-output h4:first-child{margin-top:0;}
.ia-narr-cursor{
  display:inline-block;width:2px;height:14px;
  background:var(--gold);animation:blink 1s step-end infinite;
  vertical-align:middle;margin-left:2px;
}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}

/* Panel chat */
.ia-chat-messages{
  flex:1;overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:12px;
}
.ia-msg{max-width:88%;display:flex;flex-direction:column;gap:4px;}
.ia-msg.user{align-self:flex-end;}
.ia-msg.bot{align-self:flex-start;}
.ia-msg-bubble{
  padding:10px 14px;border-radius:12px;
  font-size:13px;line-height:1.65;
}
.ia-msg.user .ia-msg-bubble{
  background:var(--gold);color:#fff;
  border-bottom-right-radius:3px;
}
.ia-msg.bot .ia-msg-bubble{
  background:var(--surface);border:1px solid var(--border);
  color:var(--text);border-bottom-left-radius:3px;
}
.ia-msg-time{font-size:10px;color:var(--muted);padding:0 4px;}

.ia-typing{
  display:flex;align-items:center;gap:5px;
  padding:10px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:12px;
  width:fit-content;
}
.ia-typing span{
  width:7px;height:7px;border-radius:50%;background:var(--muted);
  animation:typing-dot 1.2s ease-in-out infinite;
}
.ia-typing span:nth-child(2){animation-delay:.2s;}
.ia-typing span:nth-child(3){animation-delay:.4s;}
@keyframes typing-dot{
  0%,80%,100%{transform:scale(1);opacity:.4;}
  40%{transform:scale(1.3);opacity:1;}
}
.ia-chat-suggestions{
  padding:8px 16px 0;display:flex;flex-wrap:wrap;gap:6px;
}
.ia-sugg{
  padding:6px 12px;border:1px solid var(--border);border-radius:20px;
  font-size:11px;color:var(--muted);cursor:pointer;background:var(--surface);
  transition:all .2s;white-space:nowrap;
}
.ia-sugg:hover{border-color:var(--gold);color:var(--gold);background:rgba(26,92,42,.05);}

.ia-chat-input-wrap{
  padding:12px 16px;border-top:1px solid var(--border);
  display:flex;gap:8px;flex-shrink:0;
}
.ia-chat-input{
  flex:1;border:1.5px solid var(--border);border-radius:8px;
  padding:10px 14px;font-size:13px;font-family:Arial,sans-serif;
  color:var(--text);background:var(--bg);outline:none;resize:none;
  max-height:100px;transition:border-color .2s;
}
.ia-chat-input:focus{border-color:var(--gold);}
.ia-send-btn{
  width:40px;height:40px;border-radius:8px;background:var(--gold);
  border:none;cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:background .2s;flex-shrink:0;
  align-self:flex-end;
}
.ia-send-btn:hover{background:var(--gold-l);}
.ia-send-btn svg{width:18px;height:18px;fill:#fff;}
.ia-send-btn:disabled{opacity:.4;cursor:not-allowed;}

/* Chip de estado IA en resultados */
.ia-result-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;background:rgba(26,92,42,.07);
  border:1px solid rgba(26,92,42,.2);border-radius:20px;
  font-size:12px;color:var(--gold);font-weight:600;cursor:pointer;
  margin-top:12px;transition:all .2s;
}
.ia-result-chip:hover{background:rgba(26,92,42,.13);}
.ia-result-chip .dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold-l);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{transform:scale(1);opacity:1;}
  50%{transform:scale(1.5);opacity:.6;}
}

/* ── Objetivo card ─────────────────────────────────────── */
.obj-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  margin-bottom:12px;
  overflow:hidden;
}
.obj-card-header{
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:14px 16px 10px;
  background:#f8faf8;
  border-bottom:1px solid var(--border);
}
.obj-card-left{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  flex:1;
}
.obj-card-body{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  padding:14px 16px;
}
