/* ════════════════════════════════════════════════
   VisionPass · Calculadora de planes (wizard 4 pasos)
   ════════════════════════════════════════════════ */
.calc-section{padding:96px 0;background:var(--arena)}
.calc-shell{max-width:760px;margin:0 auto}

/* título con efecto de enfoque por máscara VP (solo sobre el título) */
.calc-head{text-align:center;margin-bottom:40px}
.calc-eyebrow{font-family:var(--f-mono);font-size:12.5px;letter-spacing:.08em;color:var(--morado);text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;margin-bottom:18px}
.calc-lenszone{--lx:50%;--ly:50%;--mask-w:260px;--mask-x:130px;--mask-y:98px;position:relative;display:inline-block;cursor:default;isolation:isolate}
.calc-title-layer{font-family:var(--f-display);font-weight:800;font-size:clamp(52px,7.4vw,94px);line-height:.98;letter-spacing:-.045em}
.calc-title-blur{position:relative;color:#c7beca;filter:blur(6px);opacity:.82}
.calc-title-clear{position:absolute;inset:0;z-index:1;color:var(--tinta);
  -webkit-mask-image:url('../images/logo-vp-9117bf.svg');
          mask-image:url('../images/logo-vp-9117bf.svg');
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-size:var(--mask-w) auto;mask-size:var(--mask-w) auto;
  -webkit-mask-position:calc(var(--lx) - var(--mask-x)) calc(var(--ly) - var(--mask-y));
          mask-position:calc(var(--lx) - var(--mask-x)) calc(var(--ly) - var(--mask-y));
  will-change:mask-position,-webkit-mask-position;
}
.calc-title-clear .accent{color:var(--morado)}
/* No se dibuja el logo morado encima del título; el SVG solo se usa como máscara invisible. */
.calc-lens{display:none}
.calc-lens::before,.calc-lens::after{content:none}
.calc-subtitle{color:var(--acero);font-size:16.5px;max-width:620px;margin:22px auto 0}
@media(max-width:980px){.calc-lenszone{--mask-w:220px;--mask-x:110px;--mask-y:83px}}
@media(max-width:760px){
  .calc-lenszone{display:block;width:100%;max-width:680px;margin:0 auto}
  .calc-title-blur{display:none}
  .calc-title-clear{position:relative;inset:auto;display:block;width:100%;-webkit-mask:none;mask:none;font-size:clamp(34px,9.4vw,52px);line-height:1.02;letter-spacing:-.04em;text-align:center}
  .calc-lens{display:none}
}
@media(prefers-reduced-motion:reduce){
  .calc-lenszone{display:block;width:100%;max-width:760px;margin:0 auto}
  .calc-title-blur{display:none}
  .calc-title-clear{position:relative;inset:auto;display:block;width:100%;-webkit-mask:none;mask:none;text-align:center}
  .calc-lens{display:none}
}

/* wizard card */
.calc-card{background:#fff;border:1px solid var(--borde-strong);border-radius:24px;box-shadow:0 24px 60px rgba(36,21,40,.1);overflow:hidden}
/* progreso */
.calc-progress{display:flex;align-items:center;gap:0;padding:24px 32px 0}
.calc-step-dot{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;position:relative}
.calc-step-dot .num{width:34px;height:34px;border-radius:50%;background:var(--arena-dark);color:var(--acero-light);display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:700;font-size:14px;transition:.3s;z-index:2}
.calc-step-dot .lbl{font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;color:var(--acero-light);text-transform:uppercase;transition:.3s}
.calc-step-dot::before{content:"";position:absolute;top:17px;left:-50%;width:100%;height:2px;background:var(--arena-dark);z-index:1}
.calc-step-dot:first-child::before{display:none}
.calc-step-dot.active .num{background:var(--morado);color:#fff;box-shadow:0 0 0 4px var(--morado-soft)}
.calc-step-dot.active .lbl{color:var(--morado)}
.calc-step-dot.done .num{background:var(--morado-light);color:#fff}
.calc-step-dot.done::before{background:var(--morado-light)}
@media(max-width:560px){.calc-step-dot .lbl{display:none}.calc-progress{padding:20px 20px 0}}

/* paso */
.calc-body{padding:34px 40px 40px}
@media(max-width:560px){.calc-body{padding:26px 22px 30px}}
.calc-step{display:none;animation:stepIn .4s ease}
.calc-step.active{display:block}
@keyframes stepIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
.calc-q{margin-bottom:26px}
.calc-q:last-child{margin-bottom:0}
.calc-q .q-label{font-family:var(--f-display);font-weight:600;font-size:17px;margin-bottom:6px}
.calc-q .q-help{font-size:13.5px;color:var(--acero-light);margin-bottom:14px}
.calc-q.hidden{display:none}

/* opciones tipo botón grande */
.opt-grid{display:grid;gap:10px}
.opt-grid.cols2{grid-template-columns:1fr 1fr}
@media(max-width:520px){.opt-grid.cols2{grid-template-columns:1fr}}
.opt{display:flex;align-items:center;gap:12px;padding:15px 18px;border:1.5px solid var(--borde-strong);border-radius:13px;background:#fff;cursor:pointer;transition:.2s;font-size:15px;font-family:var(--f-body);text-align:left;width:100%}
.opt:hover{border-color:var(--morado);background:var(--morado-soft)}
.opt.selected{border-color:var(--morado);background:var(--morado-soft);box-shadow:0 0 0 3px rgba(145,23,191,.1)}
.opt .opt-radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--borde-strong);flex-shrink:0;position:relative;transition:.2s}
.opt.selected .opt-radio{border-color:var(--morado)}
.opt.selected .opt-radio::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--morado)}
.opt .opt-text strong{font-family:var(--f-display);font-weight:600;display:block}
.opt .opt-text small{color:var(--acero-light);font-size:12.5px}

/* input edad */
.age-input{display:flex;align-items:center;gap:14px;max-width:260px}
.age-input input{font-family:var(--f-display);font-weight:700;font-size:24px;color:var(--tinta);border:1.5px solid var(--borde-strong);border-radius:13px;padding:14px 18px;width:120px;text-align:center;outline:none;transition:.2s}
.age-input input:focus{border-color:var(--morado);box-shadow:0 0 0 3px rgba(145,23,191,.1)}
.age-input .unit{font-size:15px;color:var(--acero)}
.calc-error{color:#c0392b;font-size:13px;margin-top:8px;display:none}
.calc-error.show{display:block}

/* navegación */
.calc-nav{display:flex;justify-content:space-between;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--borde)}
.calc-nav .btn{font-size:15px}
.calc-back{background:transparent;border:none;color:var(--acero);font-family:var(--f-display);font-weight:600;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;padding:10px 4px}
.calc-back:hover{color:var(--morado)}
.calc-back.hidden{visibility:hidden}

/* ───────── RESULTADO ───────── */
.calc-result{display:none}
.calc-result.show{display:block;animation:stepIn .5s ease}
.result-card{background:linear-gradient(135deg,var(--morado),var(--morado-light));border-radius:22px;padding:34px;color:#fff;margin-bottom:20px}
.result-card .rc-eyebrow{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:8px}
.result-card .rc-plan{font-family:var(--f-display);font-weight:800;font-size:32px;letter-spacing:-.02em;margin-bottom:6px}
.result-card .rc-sub{color:rgba(255,255,255,.9);font-size:14.5px;max-width:480px}
.result-figures{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
@media(max-width:520px){.result-figures{grid-template-columns:1fr}}
.rf{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);border-radius:14px;padding:16px 18px;backdrop-filter:blur(4px)}
.rf .k{font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.rf .v{font-family:var(--f-display);font-weight:700;font-size:22px;margin-top:4px}
.rf .v small{font-size:13px;font-weight:500;color:rgba(255,255,255,.8)}
.result-meta{background:#fff;border:1px solid var(--borde);border-radius:16px;padding:22px;margin-bottom:18px}
.result-meta .rm-row{display:flex;justify-content:space-between;gap:14px;padding:9px 0;font-size:14.5px}
.result-meta .rm-row+.rm-row{border-top:1px solid var(--borde)}
.result-meta .rm-k{color:var(--acero)}
.result-meta .rm-v{font-family:var(--f-display);font-weight:600;text-align:right}
.result-reason{background:var(--morado-soft);border-radius:14px;padding:18px 20px;margin-bottom:18px;font-size:14.5px;color:var(--morado-mid);display:flex;gap:12px}
.result-reason svg{flex-shrink:0;color:var(--morado);margin-top:2px}
.result-warnings{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.warn{display:flex;gap:11px;background:#FFF8E6;border:1px solid #F2D98C;border-radius:13px;padding:14px 16px;font-size:13.5px;color:#7a5b00;line-height:1.5}
.warn svg{flex-shrink:0;color:#C8951A;margin-top:1px}
.result-note{font-size:14px;color:var(--acero);background:var(--arena);border-radius:12px;padding:14px 16px;margin-bottom:22px;line-height:1.55}
.result-actions{display:flex;gap:12px;flex-wrap:wrap}
.result-actions .btn{flex:1;justify-content:center;min-width:160px}
.result-compare{margin-top:22px;border:1px dashed var(--borde-strong);border-radius:14px;padding:16px 18px}
.result-compare .rc-h{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--acero-light);margin-bottom:10px}
.result-compare .rc-row{display:flex;justify-content:space-between;font-size:14px;padding:6px 0}
.result-compare .rc-row .alt-plan{color:var(--acero)}
.result-compare .rc-row .alt-price{font-family:var(--f-display);font-weight:600}
.calc-legal{margin-top:26px;font-size:11.5px;color:var(--acero-light);line-height:1.7}
.calc-legal li{margin-bottom:5px;list-style:none;padding-left:16px;position:relative}
.calc-legal li::before{content:"·";position:absolute;left:4px;color:var(--morado)}
.calc-reset{text-align:center;margin-top:18px}
.calc-reset button{background:none;border:none;color:var(--morado);font-family:var(--f-mono);font-size:13px;cursor:pointer;text-decoration:underline}

/* ───────── Flujo empresarial / cotización preliminar B2B ───────── */
.calc-flow.hidden,.custom-mix.hidden{display:none!important}
.number-input{display:flex;align-items:center;gap:14px;max-width:340px}
.number-input input{font-family:var(--f-display);font-weight:700;font-size:24px;color:var(--tinta);border:1.5px solid var(--borde-strong);border-radius:13px;padding:14px 18px;width:150px;text-align:center;outline:none;transition:.2s}
.number-input input:focus{border-color:var(--morado);box-shadow:0 0 0 3px rgba(145,23,191,.1)}
.number-input .unit{font-size:15px;color:var(--acero)}
.employee-input{max-width:360px}
.mix-grid{margin-bottom:12px}
.mix-grid .opt{align-items:flex-start;min-height:84px}
.custom-mix{margin-top:14px}
.business-count-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px}
.business-count-grid.compact{max-width:520px;margin-top:0}
@media(max-width:620px){.business-count-grid{grid-template-columns:1fr}}
.count-field{position:relative;display:flex;flex-direction:column;gap:8px;background:#fff;border:1.5px solid var(--borde-strong);border-radius:16px;padding:16px 18px;transition:.2s}
.count-field:focus-within{border-color:var(--morado);box-shadow:0 0 0 3px rgba(145,23,191,.1)}
.count-field span{font-family:var(--f-display);font-weight:700;font-size:15px;color:var(--tinta)}
.count-field input{font-family:var(--f-display);font-weight:800;font-size:28px;color:var(--morado);border:0;border-bottom:1px solid var(--borde);outline:none;background:transparent;padding:8px 0 10px;width:100%}
.count-field em{font-style:normal;font-size:12.5px;color:var(--acero-light)}
.business-helper{font-size:13px;color:var(--acero);background:var(--arena);border-radius:12px;padding:12px 14px;margin-top:12px;line-height:1.45}
.business-note{font-size:13.5px;color:var(--acero);background:var(--morado-soft);border-radius:12px;padding:14px 16px;line-height:1.55;margin-top:18px}
.result-figures.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:720px){.result-figures.three{grid-template-columns:1fr}}
.business-result .rc-plan{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap}
.enterprise-breakdown{background:#fff;border:1px solid var(--borde);border-radius:16px;padding:20px;margin-bottom:18px}
.enterprise-breakdown .rc-h{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--acero-light);margin-bottom:12px}
.quote-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:11px 0;border-top:1px solid var(--borde);font-size:14px}
.quote-row span{color:var(--acero)}
.quote-row strong{font-family:var(--f-display);font-weight:700;text-align:right;color:var(--tinta)}
.quote-row.quote-total{border-top:1.5px solid var(--borde-strong);margin-top:6px;padding-top:14px;font-family:var(--f-display);font-weight:800}
.quote-row.quote-total span{color:var(--tinta)}
.quote-row.quote-total strong{color:var(--morado);font-size:18px}
@media(max-width:520px){.quote-row{align-items:flex-start;flex-direction:column}.quote-row strong{text-align:left}}

/* Sección de ahorro en resultados */
.result-savings{display:flex;align-items:center;gap:18px;background:linear-gradient(135deg,#9A19CB,#7d14a8);color:#fff;border-radius:16px;padding:20px 22px;margin:16px 0}
.rs-badge{font-family:var(--f-display,'Poppins',sans-serif);font-weight:800;font-size:26px;line-height:1;white-space:nowrap;padding:14px 16px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);border-radius:12px;flex-shrink:0}
.rs-text{display:flex;flex-direction:column;gap:4px}
.rs-text strong{font-family:var(--f-display,'Poppins',sans-serif);font-weight:600;font-size:16px}
.rs-text span{font-size:13.5px;opacity:.92;line-height:1.55}
.enterprise-fees{background:#fff;border:1px solid var(--borde,#ece7e1);border-radius:14px;padding:18px 20px;margin:16px 0}
.enterprise-fees .rc-h{font-family:var(--f-display,'Poppins',sans-serif);font-weight:600;font-size:14px;margin-bottom:12px;color:var(--tinta,#241528)}
@media(max-width:600px){.result-savings{flex-direction:column;align-items:flex-start;gap:12px}}
