.sub-hero{background:var(--night);color:var(--on-night);position:relative;overflow:hidden}
.sub-hero .lines{position:absolute;inset:0;width:100%;height:100%;opacity:.45}
.sub-hero .lines path{fill:none;stroke-linecap:round}
.sub-hero .inner{position:relative;z-index:1;padding-block:clamp(46px,7vw,82px)}
.sub-hero .inner h1,.sub-hero .inner p{max-width:62ch}
.sub-hero h1{color:var(--on-night);font-size:clamp(34px,5.4vw,62px);letter-spacing:-.015em;line-height:1.02}
.sub-hero .lede{color:var(--on-night-muted);font-size:clamp(17px,2vw,21px);margin-top:18px}

.builder{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:start}
@media (max-width:880px){.builder{grid-template-columns:1fr}}
.bcard{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px}
.bcard h3{font-size:20px;letter-spacing:-.01em;margin-bottom:6px}
.bcard .hint{color:var(--muted);font-size:14px;margin-bottom:18px}
.step{margin-bottom:28px}
.step:last-child{margin-bottom:0}
.step .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:9px;margin-bottom:13px}
.step .lbl .num{width:20px;height:20px;border-radius:50%;background:var(--ink);color:var(--yellow);display:grid;place-items:center;font-size:11px;font-weight:700}
.chipset{display:flex;gap:9px;flex-wrap:wrap}
.tchip{font-family:var(--display);font-weight:600;font-size:14px;padding:9px 15px;border-radius:100px;border:1.5px solid var(--line-2);background:var(--card);color:var(--ink-2);cursor:pointer;transition:all .2s var(--ease);display:inline-flex;align-items:center;gap:7px}
.tchip:hover{border-color:var(--ink)}
.tchip.sel{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.tchip.sel.route-chip{background:var(--yellow);border-color:var(--yellow);color:var(--on-yellow)}
.tchip .x{opacity:0;width:0;overflow:hidden;transition:opacity .2s}
.tchip.sel .x{opacity:1;width:13px}
.tchip .x svg{width:13px;height:13px;display:block}
.field{display:flex;gap:10px;flex-wrap:wrap}
.field input{flex:1;min-width:220px;border:1.5px solid var(--line-2);background:var(--card);border-radius:12px;padding:13px 16px;font-family:var(--body);font-size:15px;color:var(--ink)}
.field input:focus{outline:none;border-color:var(--ink)}
.freq{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
@media (max-width:520px){.freq{grid-template-columns:1fr 1fr}}
.freq label{position:relative;cursor:pointer}
.freq input{position:absolute;opacity:0}
.freq .b{display:block;text-align:center;padding:12px 6px;border:1.5px solid var(--line-2);border-radius:11px;font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink-2);transition:all .2s}
.freq input:checked + .b{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.consent{display:flex;flex-direction:column;gap:11px;margin-top:6px}
.consent label{display:block;position:relative;padding-left:28px;font-size:13.5px;color:var(--ink-2);line-height:1.5}
.consent input{position:absolute;left:0;top:3px;accent-color:var(--ink);width:17px;height:17px}
.consent a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.form-done2{display:none;align-items:center;gap:13px;background:var(--ok-bg);border:1px solid #bfe3cf;color:#155c39;border-radius:14px;padding:18px 20px;font-family:var(--display);font-weight:700;margin-top:18px;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.form-done2.in{opacity:1;transform:none}
.form-done2 svg{width:22px;height:22px;flex:none}

.summary{position:sticky;top:96px;background:var(--ink);color:var(--on-night);border-radius:18px;padding:26px}
.summary h4{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--on-night-muted);margin-bottom:18px}
.summary .line{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--night-line);font-size:14px}
.summary .line:last-of-type{border-bottom:0}
.summary .line .k{color:var(--on-night-muted)}
.summary .line .v{font-weight:600;text-align:right;max-width:62%}
.summary .total{display:flex;justify-content:space-between;align-items:baseline;margin:18px 0;padding-top:16px;border-top:1px solid var(--night-line)}
.summary .total .p{font-family:var(--display);font-weight:900;font-size:30px;color:var(--yellow)}
.summary .total .p small{font-size:13px;color:var(--on-night-muted);font-weight:500}

/* plans */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:880px){.plans{grid-template-columns:1fr}}
.plan{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px;display:flex;flex-direction:column}
.plan.feat{border:2px solid var(--ink);position:relative}
.plan.feat::before{content:"Recomendado";position:absolute;top:-12px;left:30px;background:var(--yellow);color:var(--on-yellow);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:4px 11px;border-radius:100px;font-weight:600}
.plan .pn{font-family:var(--display);font-weight:800;font-size:20px}
.plan .pp{font-family:var(--display);font-weight:900;font-size:42px;letter-spacing:-.03em;margin:14px 0 4px}
.plan .pp small{font-size:15px;font-weight:500;color:var(--muted)}
.plan .pd{color:var(--muted);font-size:14px;margin-bottom:20px}
.plan ul{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:11px;flex:1}
.plan li{display:flex;gap:10px;font-size:14.5px;color:var(--ink-2);align-items:flex-start}
.plan li svg{width:17px;height:17px;color:var(--ok);flex:none;margin-top:2px}
.plan li.off{color:var(--faint)}
.plan li.off svg{color:var(--faint)}