:root{
  --ink:#131a24;
  --ink-soft:#33414f;
  --paper:#e9ecf1;
  --surface:#ffffff;
  --surface-2:#f4f6f9;
  --line:#dbe0e7;
  --line-strong:#c6cdd6;
  --muted:#657081;
  --con:#157a72;          /* conservador — teal */
  --con-soft:#e2f1ef;
  --agg:#b07a22;          /* agresivo — latón */
  --agg-soft:#f6ecda;
  --accent:#22415e;       /* interacción — azul tinta */
  --danger:#b23b3b;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 1px 2px rgba(19,26,36,.05), 0 12px 30px -18px rgba(19,26,36,.28);
  --ff-display:"Space Grotesk",system-ui,sans-serif;
  --ff-body:"Inter",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  font-feature-settings:"tnum" 1,"cv05" 1;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background:
    radial-gradient(1200px 600px at 82% -10%, rgba(34,65,94,.10), transparent 60%),
    radial-gradient(900px 500px at -5% 110%, rgba(21,122,114,.08), transparent 55%);
}
button{font:inherit;cursor:pointer}
input,select{font:inherit;color:inherit}
table{border-collapse:collapse;width:100%}
small{font-size:.72em;font-weight:500}

/* ---------- Masthead ---------- */
.masthead{position:relative;z-index:2;border-bottom:1px solid var(--line);background:rgba(233,236,241,.8);backdrop-filter:blur(8px)}
.masthead__inner{max-width:1120px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--ff-display);font-weight:600;letter-spacing:-.01em}
.brand__mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;background:var(--ink);color:#eef4f1}
.brand__text{font-size:1.06rem}
.brand__text em{font-style:normal;color:var(--muted);font-weight:500}

.region{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:3px}
.region__btn{border:0;background:transparent;color:var(--muted);padding:7px 15px;border-radius:999px;font-size:.85rem;font-weight:600;transition:.18s}
.region__btn.is-active{background:var(--ink);color:#eef4f1}
.region__btn:not(.is-active):hover{color:var(--ink)}

/* ---------- Layout ---------- */
.layout{position:relative;z-index:1;max-width:1120px;margin:0 auto;padding:28px 24px 12px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:28px;align-items:start}
.lede{margin:0 0 18px;color:var(--ink-soft);font-size:.96rem;max-width:46ch}

/* ---------- Paneles (acordeón) ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;box-shadow:var(--shadow);overflow:hidden}
.panel__head{list-style:none;display:flex;align-items:center;gap:12px;padding:16px 18px;cursor:pointer;user-select:none}
.panel__head::-webkit-details-marker{display:none}
.panel__title{font-family:var(--ff-display);font-weight:600;font-size:1rem;letter-spacing:-.01em}
.panel__meta{margin-left:auto;font-family:var(--ff-display);font-weight:600;font-size:.9rem;color:var(--con);background:var(--con-soft);padding:3px 10px;border-radius:999px}
.panel__chev{width:9px;height:9px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .2s;flex:none}
.panel[open] .panel__chev{transform:rotate(-135deg)}
.panel__body{padding:4px 18px 20px;border-top:1px solid var(--line)}
.panel__hint,.panel__body>.panel__hint{margin:14px 0 4px;color:var(--muted);font-size:.85rem}

/* ---------- Campos ---------- */
.field{padding:15px 0;border-bottom:1px dashed var(--line)}
.field:last-child{border-bottom:0;padding-bottom:2px}
.field--compact{padding:0;border:0}
.field__label{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:8px}
.field__money{display:flex;align-items:center;background:var(--surface-2);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:0 12px;transition:border-color .15s, box-shadow .15s}
.field__money:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,65,94,.12)}
.field__prefix,.field__suffix{color:var(--muted);font-weight:600;font-size:.9rem;flex:none}
.field__suffix{margin-left:4px;font-size:.8rem}
.field__input{flex:1;min-width:0;border:0;background:transparent;padding:11px 6px;font-family:var(--ff-display);font-weight:600;font-size:1.05rem;text-align:right;outline:none}
.field__money--suffix .field__input{text-align:left;padding-left:2px}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px 14px;padding-top:16px}
.select{position:relative}
.select select{width:100%;appearance:none;background:var(--surface-2);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:11px 34px 11px 12px;font-weight:600;outline:none}
.select select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,65,94,.12)}
.select::after{content:"";position:absolute;right:14px;top:50%;width:7px;height:7px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:translateY(-70%) rotate(45deg);pointer-events:none}

/* ---------- Slider ---------- */
.slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;margin-top:14px;border-radius:99px;background:var(--line-strong);outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);box-shadow:0 2px 5px rgba(19,26,36,.2);cursor:pointer;transition:transform .12s}
.slider::-webkit-slider-thumb:hover{transform:scale(1.12)}
.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);box-shadow:0 2px 5px rgba(19,26,36,.2);cursor:pointer}
.slider:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 4px rgba(34,65,94,.2)}

/* ---------- Resultados ---------- */
.results{position:sticky;top:20px;background:var(--surface);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:26px 26px 22px}

.verdict__eyebrow{margin:0;color:var(--muted);font-size:.88rem;font-weight:600;letter-spacing:.01em}
.verdict__range{margin:6px 0 8px;font-family:var(--ff-display);font-weight:700;letter-spacing:-.02em;line-height:1.05;display:flex;flex-wrap:wrap;align-items:baseline;gap:10px}
.verdict__num{font-size:clamp(1.9rem,5vw,2.7rem);color:var(--con)}
.verdict__num--agg{color:var(--agg)}
.verdict__to{font-family:var(--ff-body);font-weight:500;font-size:1rem;color:var(--muted)}
.verdict__sub{margin:0;font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:4px}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:3px}
.dot--con{background:var(--con)}
.dot--agg{background:var(--agg)}

/* ---------- Signature: medidor ---------- */
.gauge{margin:22px 0 26px}
.gauge__track{position:relative;height:10px;border-radius:99px;background:var(--surface-2);border:1px solid var(--line);margin:26px 0 8px}
.gauge__fill{position:absolute;top:-1px;bottom:-1px;left:0;width:0;border-radius:99px;background:linear-gradient(90deg,var(--con),var(--agg));transition:width .6s cubic-bezier(.2,.8,.2,1),left .6s cubic-bezier(.2,.8,.2,1)}
.gauge__node{position:absolute;top:50%;width:18px;height:18px;border-radius:50%;background:var(--surface);border:3px solid var(--con);transform:translate(-50%,-50%);transition:left .6s cubic-bezier(.2,.8,.2,1);box-shadow:0 2px 6px rgba(19,26,36,.18)}
.gauge__node--agg{border-color:var(--agg)}
.gauge__flag{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);white-space:nowrap;font-size:.68rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--muted)}
.gauge__node--con .gauge__flag{color:var(--con)}
.gauge__node--agg .gauge__flag{color:var(--agg)}
.gauge__scale{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);font-family:var(--ff-display);font-weight:500}

/* ---------- Pestañas + gráfica ---------- */
.tabs{display:flex;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:4px;margin-bottom:16px}
.tab{flex:1;border:0;background:transparent;color:var(--muted);font-weight:600;font-size:.86rem;padding:9px;border-radius:8px;transition:.15s}
.tab.is-active{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px rgba(19,26,36,.12)}
.chartwrap{position:relative;height:240px;margin-bottom:18px}

/* ---------- Tablas ---------- */
.bd{font-size:.86rem}
.bd th{text-align:left;font-weight:500;color:var(--ink-soft);padding:9px 0}
.bd thead th{font-family:var(--ff-display);font-weight:600;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;text-align:right;border-bottom:1px solid var(--line)}
.bd thead th:first-child{text-align:left}
.bd td{text-align:right;font-family:var(--ff-display);font-weight:600;padding:9px 0 9px 14px;color:var(--ink);white-space:nowrap}
.bd thead th:not(:first-child){padding-left:14px}
.bd tbody tr{border-bottom:1px solid var(--line)}
.bd tbody tr:last-child{border-bottom:0}
.bd__total th{color:var(--ink);font-weight:700}
.bd__total td{color:var(--ink)}
.bd th small{display:block;color:var(--muted);font-weight:500}

.breakdown{margin-bottom:18px}

/* ---------- Caja NY ---------- */
.nybox{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:16px 16px 8px;margin-bottom:18px}
.nybox__head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.nybox__title{font-family:var(--ff-display);font-weight:600;font-size:.95rem}
.nybox__badge{margin-left:auto;font-size:.72rem;font-weight:700;color:var(--agg);background:var(--agg-soft);padding:3px 9px;border-radius:999px}
.nybox__hint{margin:0 0 6px;color:var(--muted);font-size:.8rem}
.bd--ny td:first-of-type{color:var(--con)}
.bd--ny td:last-of-type{color:var(--agg)}

.disclaimer{margin:2px 0 0;font-size:.74rem;line-height:1.55;color:var(--muted)}

.foot{position:relative;z-index:1;text-align:center;color:var(--muted);font-size:.76rem;padding:22px 24px 34px}

/* ---------- Animación de conteo ---------- */
.is-flash{animation:flash .5s ease}
@keyframes flash{0%{color:var(--accent)}100%{}}

/* ---------- Responsivo ---------- */
@media (max-width:880px){
  .layout{grid-template-columns:1fr;gap:22px;padding:22px 18px 8px}
  .results{position:static;order:-1;padding:22px 18px}
  .masthead__inner{padding:14px 18px}
  .brand__text em{display:none}
}
@media (max-width:420px){
  .grid2{grid-template-columns:1fr}
  .verdict__range{gap:6px}
  .region__btn{padding:7px 11px;font-size:.8rem}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
