:root {
  --bg: #fffaf2;
  --bg-soft: #fff4df;
  --surface: #ffffff;
  --surface-soft: #f7fffb;
  --text: #0c2340;
  --text-soft: #4f5f70;
  --muted: #7a8794;
  --line: rgba(12, 35, 64, 0.12);
  --line-strong: rgba(12, 35, 64, 0.22);
  --green: #009f73;
  --green-dark: #007f5c;
  --green-soft: #e8fbf4;
  --orange: #ff9700;
  --orange-dark: #ed7d00;
  --orange-soft: #fff0d5;
  --blue: #0d66c2;
  --blue-soft: #eaf4ff;
  --shadow: 0 22px 60px rgba(12, 35, 64, 0.14);
  --shadow-soft: 0 12px 34px rgba(12, 35, 64, 0.10);
  --radius: 24px;
  --radius-sm: 16px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--text);
  background: linear-gradient(180deg, #fffaf2 0%, #ffffff 42%, #f7fffb 100%);
  line-height: 1.55;
}
a { color: inherit; }
img, svg { max-width: 100%; }
button, input, select, textarea { font: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(12, 35, 64, 0.08);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 26px; min-height: 76px; }
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; font-weight: 850; font-size: 1.12rem; letter-spacing: -0.02em; }
.brand-mark { position: relative; display: inline-grid; place-items: center; width: 35px; height: 35px; border-radius: 50%; background: #fff4d8; }
.brand-mark::before { content: ""; width: 14px; height: 14px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 5px rgba(255,151,0,.16); }
.brand-mark span { position: absolute; width: 3px; height: 8px; border-radius: 99px; background: var(--orange); transform-origin: 50% 17px; }
.brand-mark span:nth-child(1) { transform: rotate(0deg) translateY(-17px); }
.brand-mark span:nth-child(2) { transform: rotate(45deg) translateY(-17px); }
.brand-mark span:nth-child(3) { transform: rotate(90deg) translateY(-17px); }
.brand-mark span:nth-child(4) { transform: rotate(135deg) translateY(-17px); }
.brand-mark span:nth-child(5) { transform: rotate(180deg) translateY(-17px); }
.brand-mark span:nth-child(6) { transform: rotate(225deg) translateY(-17px); }
.brand-mark span:nth-child(7) { transform: rotate(270deg) translateY(-17px); }
.brand-mark span:nth-child(8) { transform: rotate(315deg) translateY(-17px); }
.main-nav { display: flex; align-items: center; gap: 28px; font-weight: 750; font-size: .92rem; color: var(--text); }
.main-nav a { text-decoration: none; }
.header-cta, .button, .offer-button, .hero-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  border: 0; border-radius: 14px; padding: 14px 22px; cursor: pointer; text-decoration: none;
  background: linear-gradient(135deg, var(--orange), #ffb22d); color: #fff; font-weight: 850;
  box-shadow: 0 10px 24px rgba(255, 151, 0, 0.28);
}
.header-cta { padding: 12px 18px; }
.button { width: auto; min-width: 145px; background: linear-gradient(135deg, var(--green), #00b886); box-shadow: 0 12px 28px rgba(0, 159, 115, .24); }
.button-muted { background: #eef3f6; color: var(--text); box-shadow: none; }
.button:disabled { opacity: .5; cursor: not-allowed; }

.hero {
  position: relative;
  overflow: hidden;
  padding: 58px 0 42px;
  background:
    radial-gradient(circle at 7% 20%, rgba(255,151,0,.18), transparent 32%),
    radial-gradient(circle at 75% 8%, rgba(0,159,115,.15), transparent 30%),
    linear-gradient(135deg, #fffaf2 0%, #ffffff 52%, #effff9 100%);
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto -10vw -160px 44%;
  height: 420px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(135deg, rgba(0,159,115,.11), rgba(255,151,0,.12));
  filter: blur(3px);
  pointer-events: none;
}
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: .92fr 1.16fr; gap: 42px; align-items: center; }
.hero-copy { max-width: 560px; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; margin: 0 0 14px; color: var(--green-dark); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; }
.eyebrow::before { content: ""; width: 9px; height: 9px; background: var(--orange); border-radius: 50%; box-shadow: 0 0 0 5px rgba(255,151,0,.15); }
.hero h1 { margin: 0; font-size: clamp(2.35rem, 5vw, 4.9rem); line-height: .96; letter-spacing: -0.06em; }
.hero h1 strong { color: var(--green); font-weight: 900; }
.hero-text { margin: 22px 0 0; color: var(--text-soft); font-size: 1.12rem; max-width: 600px; }
.hero-points { display: grid; gap: 12px; margin: 28px 0; padding: 0; list-style: none; font-weight: 800; }
.hero-points li { display: flex; align-items: center; gap: 10px; }
.hero-points li::before { content: "✓"; display: grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; background: var(--green); color: #fff; font-size: .85rem; }
.trust-card { width: fit-content; max-width: 100%; padding: 16px 18px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.82); box-shadow: var(--shadow-soft); }
.stars { color: var(--green); letter-spacing: 2px; font-weight: 900; }
.trust-card p { margin: 6px 0 0; color: var(--text-soft); font-size: .94rem; }

.form-shell { position: relative; }
.lead-form {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(12, 35, 64, .10);
  border-radius: 30px;
  box-shadow: var(--shadow);
  padding: clamp(22px, 3vw, 34px);
  overflow: hidden;
}
.form-card-head { margin: 0 0 22px; }
.form-card-head h2 { margin: 0; font-size: clamp(1.35rem, 2vw, 2rem); letter-spacing: -.035em; line-height: 1.1; }
.form-card-head p:not(.eyebrow) { margin: 10px 0 0; color: var(--text-soft); }
.stepper { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin: 20px 0 12px; }
.stepper-item { border: 0; background: transparent; display: grid; place-items: center; gap: 6px; color: var(--muted); font-weight: 850; cursor: default; padding: 0; }
.stepper-item span { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; border: 2px solid #dbe3ea; background: #fff; }
.stepper-item small { font-size: .72rem; }
.stepper-item.is-active span, .stepper-item.is-complete span { background: var(--green); border-color: var(--green); color: #fff; }
.stepper-item.is-active, .stepper-item.is-complete { color: var(--green-dark); }
.form-progress { height: 8px; border-radius: 999px; background: #e9eef2; margin-bottom: 24px; overflow: hidden; }
.form-progress span { display: block; height: 100%; width: 20%; background: linear-gradient(90deg, var(--green), #00bd89); border-radius: inherit; transition: width .25s ease; }
.form-step { display: none; }
.form-step.is-active { display: block; animation: fadeSlide .22s ease; }
@keyframes fadeSlide { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.step-kicker { margin: 0 0 8px; color: var(--orange-dark); font-size: .82rem; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.form-step h3 { margin: 0 0 18px; font-size: clamp(1.22rem, 2vw, 1.7rem); letter-spacing: -.035em; }
.choice-grid { display: grid; gap: 16px; }
.choice-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.choice-card { position: relative; display: grid; align-content: center; min-height: 142px; padding: 22px; border: 2px solid #dce5eb; border-radius: 20px; background: #fff; cursor: pointer; transition: .18s ease; }
.choice-card:hover { border-color: rgba(0,159,115,.45); transform: translateY(-2px); box-shadow: var(--shadow-soft); }
.choice-card input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.choice-card:has(input:checked) { border-color: var(--green); background: linear-gradient(180deg, #fff, #f1fff9); box-shadow: 0 14px 32px rgba(0,159,115,.13); }
.choice-card:has(input:checked)::after { content: "✓"; position: absolute; right: 16px; top: 16px; display: grid; place-items: center; width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: #fff; font-weight: 900; }
.choice-icon { width: 42px; height: 42px; margin-bottom: 12px; border-radius: 14px; background: var(--orange-soft); position: relative; }
.icon-bolt::before { content: "⚡"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 24px; }
.icon-flame::before, .icon-fire::before { content: "♨"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 24px; }
.icon-home::before, .icon-house::before { content: "⌂"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 24px; }
.icon-key::before { content: "⌁"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 25px; }
.icon-shop::before { content: "▣"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 22px; }
.icon-building::before { content: "▥"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 24px; }
.choice-title { display: block; font-weight: 900; font-size: 1.08rem; }
.choice-text { display: block; margin-top: 5px; color: var(--text-soft); font-size: .93rem; }
.field-grid { display: grid; gap: 16px; }
.two-cols { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.field-full { grid-column: 1 / -1; }
.field { display: grid; gap: 8px; margin-bottom: 16px; }
.field span, .fieldset-like legend { font-weight: 850; font-size: .93rem; }
.field input, .field select, .field textarea {
  width: 100%; border: 1px solid #d8e1e8; border-radius: 14px; padding: 14px 15px; background: #fff; color: var(--text); outline: none;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--green); box-shadow: 0 0 0 4px rgba(0,159,115,.12); }
.branch-block { display: none; margin: 18px 0; padding: 18px; border: 1px solid var(--line); border-radius: 20px; background: linear-gradient(180deg, #ffffff, #fbfffd); }
.branch-block.is-visible { display: block; }
.branch-title { display: grid; gap: 2px; margin-bottom: 14px; }
.branch-title strong { font-size: 1rem; }
.branch-title span { color: var(--text-soft); font-size: .9rem; }
.spend-fields .is-hidden { display: none; }
.fieldset-like { border: 1px solid #d8e1e8; border-radius: 16px; padding: 14px 16px; background: #fff; margin: 0 0 16px; }
.fieldset-like label { display: block; margin-top: 9px; color: var(--text-soft); font-weight: 700; }
.checkbox-field { display: flex; gap: 12px; align-items: flex-start; padding: 14px; border: 1px solid var(--line); border-radius: 16px; background: #fff; }
.checkbox-field input { width: 18px; height: 18px; margin-top: 3px; accent-color: var(--green); flex: 0 0 auto; }
.checkbox-field span { color: var(--text-soft); font-size: .92rem; }
.checkbox-field a { color: var(--green-dark); font-weight: 850; }
.consent-box { display: grid; gap: 10px; margin-top: 18px; }
.consent-service-notice { padding: 16px; border: 1px solid rgba(0,159,115,.18); border-radius: 18px; background: var(--green-soft); color: var(--text-soft); }
.consent-service-notice strong { display: block; margin: 0 0 6px; color: var(--text); font-weight: 900; }
.consent-service-notice p { margin: 0; font-size: .92rem; }
.form-errors { display: none; margin-top: 18px; padding: 14px 16px; border-radius: 14px; background: #fff3f0; color: #aa2e18; font-weight: 800; border: 1px solid rgba(170,46,24,.18); }
.form-errors.is-visible { display: block; }
.form-actions { display: flex; justify-content: space-between; gap: 14px; margin-top: 24px; }
.form-safe { margin: 16px 0 0; color: var(--text-soft); text-align: center; font-size: .9rem; }
.hp-field { position: absolute; left: -5000px; width: 1px; height: 1px; opacity: 0; }

.benefit-strip { position: relative; z-index: 2; margin: -10px auto 0; }
.benefit-card { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; background: rgba(255,255,255,.95); border: 1px solid var(--line); box-shadow: var(--shadow-soft); border-radius: 22px; overflow: hidden; }
.benefit-item { display: grid; grid-template-columns: 42px 1fr; gap: 12px; padding: 22px; align-items: center; border-right: 1px solid var(--line); }
.benefit-item:last-child { border-right: 0; }
.benefit-icon { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 14px; background: var(--green-soft); color: var(--green); font-weight: 900; font-size: 20px; }
.benefit-item strong { display: block; font-size: .98rem; }
.benefit-item span { display: block; color: var(--text-soft); font-size: .88rem; }

.section { padding: 74px 0; }
.section-head { max-width: 760px; margin: 0 auto 34px; text-align: center; }
.section-head h2 { margin: 0; font-size: clamp(2rem, 3vw, 3rem); letter-spacing: -.055em; line-height: 1.04; }
.section-head p { margin: 14px 0 0; color: var(--text-soft); font-size: 1.04rem; }
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.process-card { position: relative; padding: 30px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow-soft); text-align: center; }
.process-number { position: absolute; top: 18px; left: 18px; width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: #fff; background: var(--green); font-weight: 900; }
.process-illustration { display: grid; place-items: center; width: 118px; height: 118px; margin: 0 auto 18px; border-radius: 50%; background: linear-gradient(135deg, var(--orange-soft), var(--green-soft)); font-size: 46px; }
.process-card h3 { margin: 0 0 8px; font-size: 1.22rem; }
.process-card p { margin: 0; color: var(--text-soft); }

.offers-panel { background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); border-radius: 28px; padding: clamp(20px, 3vw, 30px); }
.offers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.offer-card { padding: 22px; border: 1px solid var(--line); border-radius: 22px; background: #fff; display: flex; flex-direction: column; min-height: 100%; }
.offer-card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.offer-logo { display: flex; align-items: center; gap: 10px; font-size: 1.18rem; }
.offer-icon { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 12px; background: var(--orange-soft); }
.offer-icon-bolt::before { content: "⚡"; color: var(--orange-dark); }
.offer-icon-leaf::before { content: "●"; color: var(--green); }
.offer-icon-flame::before { content: "♨"; color: var(--blue); }
.offer-badge { display: inline-flex; padding: 6px 9px; border-radius: 999px; background: var(--orange-soft); color: var(--orange-dark); font-size: .72rem; font-weight: 900; }
.offer-green .offer-badge { background: var(--green-soft); color: var(--green-dark); }
.offer-blue .offer-badge { background: var(--blue-soft); color: var(--blue); }
.offer-card h3 { margin: 20px 0 8px; font-size: 1.12rem; }
.offer-card p { margin: 0; color: var(--text-soft); font-size: .94rem; }
.offer-list { display: grid; gap: 8px; margin: 18px 0; padding: 0; list-style: none; color: var(--text-soft); font-size: .94rem; }
.offer-list li { display: flex; gap: 8px; }
.offer-list li::before { content: "✓"; color: var(--green); font-weight: 900; }
.offer-price { margin-top: auto; display: grid; gap: 2px; }
.offer-price span { color: var(--muted); font-size: .82rem; }
.offer-price strong { font-size: 1.72rem; letter-spacing: -.04em; }
.offer-price small { color: var(--muted); }
.offer-button { margin-top: 18px; width: 100%; box-shadow: none; background: var(--orange); }
.offer-green .offer-button { background: #fff; color: var(--green-dark); border: 2px solid var(--green); }
.offer-blue .offer-button { background: #fff; color: var(--blue); border: 2px solid var(--blue); }
.offer-disclaimer { margin: 18px 0 0; color: var(--muted); text-align: center; font-size: .86rem; }

.reassurance { padding: 24px; border-radius: 24px; background: linear-gradient(135deg, #f0fff9, #fff7e9); border: 1px solid var(--line); }
.reassurance-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.reassurance-item { display: grid; gap: 6px; }
.reassurance-item strong { font-size: 1rem; }
.reassurance-item span { color: var(--text-soft); font-size: .92rem; }

.faq-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; max-width: 960px; margin: 0 auto; }
details { border: 1px solid var(--line); border-radius: 16px; background: #fff; padding: 16px 18px; }
summary { cursor: pointer; font-weight: 850; }
details p { margin: 12px 0 0; color: var(--text-soft); }

.site-footer { padding: 56px 0 24px; background: #fff6e7; border-top: 1px solid rgba(12, 35, 64, .08); }
.footer-grid { display: grid; grid-template-columns: 1.6fr .8fr .8fr 1fr; gap: 34px; }
.footer-brand p, .footer-contact p { color: var(--text-soft); }
.site-footer h2 { margin: 0 0 12px; font-size: .92rem; text-transform: uppercase; letter-spacing: .08em; }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.site-footer a { text-decoration: none; color: var(--text-soft); }
.footer-contact { padding: 20px; border-radius: 20px; background: #effff8; }
.footer-bottom { margin-top: 34px; color: var(--muted); font-size: .88rem; }

.legal-main { padding: 70px 0; }
.legal-content { max-width: 880px; padding: 34px; border-radius: 24px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.legal-content h1 { margin-top: 0; font-size: clamp(2rem, 4vw, 3.2rem); letter-spacing: -.05em; }
.legal-content h2 { margin-top: 34px; }

.thanks-card { max-width: 760px; margin: 70px auto; padding: 38px; border-radius: 28px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow); text-align: center; }
.thanks-card h1 { margin: 0; font-size: clamp(2rem, 4vw, 3.4rem); letter-spacing: -.055em; }
.thanks-card p { color: var(--text-soft); }

@media (max-width: 980px) {
  .main-nav { display: none; }
  .hero-grid { grid-template-columns: 1fr; }
  .benefit-card, .reassurance-grid { grid-template-columns: repeat(2, 1fr); }
  .steps-grid, .offers-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .container { width: min(100% - 28px, 1180px); }
  .header-inner { min-height: 68px; }
  .header-cta { display: none; }
  .hero { padding-top: 34px; }
  .choice-grid.two, .two-cols, .benefit-card, .reassurance-grid, .faq-grid, .footer-grid { grid-template-columns: 1fr; }
  .benefit-item { border-right: 0; border-bottom: 1px solid var(--line); }
  .benefit-item:last-child { border-bottom: 0; }
  .lead-form { border-radius: 22px; padding: 18px; }
  .stepper-item small { display: none; }
  .form-actions { flex-direction: column-reverse; }
  .button { width: 100%; }
}

/* V3 — Hub de recomendadores y navegación diferenciada */
.hub-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr .78fr;
  gap: 42px;
  align-items: center;
}
.hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; margin-top: 30px; }
.hero-link { font-weight: 900; color: var(--green-dark); text-decoration: none; }
.hub-summary-card {
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid var(--line);
  border-radius: 30px;
  background: rgba(255,255,255,.94);
  box-shadow: var(--shadow);
}
.hub-summary-card h2 { margin: 16px 0 10px; font-size: clamp(1.45rem, 2.2vw, 2.1rem); letter-spacing: -.045em; line-height: 1.08; }
.hub-summary-card p { margin: 0; color: var(--text-soft); }
.hub-summary-card ul { margin: 20px 0 0; padding: 0; list-style: none; display: grid; gap: 10px; font-weight: 850; }
.hub-summary-card li { display: flex; gap: 10px; align-items: center; }
.hub-summary-card li::before { content: "✓"; display: grid; place-items: center; width: 22px; height: 22px; border-radius: 50%; background: var(--green); color: #fff; font-size: .78rem; }
.hub-summary-icon { width: 68px; height: 68px; border-radius: 22px; background: linear-gradient(135deg, var(--orange-soft), var(--green-soft)); position: relative; }
.hub-summary-icon::before { content: ""; position: absolute; inset: 19px; border: 4px solid var(--orange); border-radius: 50%; box-shadow: 0 0 0 9px rgba(255,151,0,.12); }
.recommender-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.recommender-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 26px;
  border: 1px solid var(--line);
  border-radius: 26px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.recommender-card.is-active { border-color: rgba(0,159,115,.34); background: linear-gradient(180deg, #fff, #f5fffb); }
.recommender-card.is-soon { opacity: .78; }
.recommender-card-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.recommender-icon { display: grid; place-items: center; width: 54px; height: 54px; min-width: 54px; border-radius: 18px; background: var(--green-soft); color: var(--green-dark); position: relative; }
.recommender-icon::before { font-weight: 950; font-size: 1.35rem; line-height: 1; }
.recommender-icon.icon-bolt::before { content: "⚡"; color: var(--orange-dark); }
.recommender-icon.icon-shield::before { content: "✓"; }
.recommender-icon.icon-bank::before { content: "€"; }
.status-badge { display: inline-flex; align-items: center; justify-content: center; padding: 6px 10px; border-radius: 999px; font-size: .72rem; font-weight: 950; }
.status-active { background: var(--green-soft); color: var(--green-dark); }
.status-soon { background: #eef3f6; color: var(--text-soft); }
.recommender-card h3 { margin: 0; font-size: 1.35rem; letter-spacing: -.035em; }
.recommender-card p { margin: 0; color: var(--text-soft); }
.recommender-button { margin-top: auto; width: 100%; }
.button-disabled { background: #eef3f6; color: var(--muted); box-shadow: none; cursor: not-allowed; }
.footer-grid-clean { grid-template-columns: 1.6fr .8fr .8fr 1.05fr; }
.footer-note { padding: 20px; border-radius: 20px; background: #effff8; }
.footer-note p { margin: 0; color: var(--text-soft); }

/* V3 — iconos centrados dentro de su recuadro */
.benefit-icon {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  min-width: 42px;
  border-radius: 14px;
  background: var(--green-soft);
  color: var(--green);
  line-height: 1;
  overflow: hidden;
}
.benefit-icon::before,
.benefit-icon::after { box-sizing: border-box; }
.icon-clock::before {
  content: "";
  width: 19px;
  height: 19px;
  border: 2px solid currentColor;
  border-radius: 50%;
}
.icon-clock::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 7px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  left: 21px;
  top: 18px;
  transform: translate(-50%, -50%) rotate(-35deg);
  transform-origin: left bottom;
}
.icon-mail::before {
  content: "";
  width: 22px;
  height: 16px;
  border: 2px solid currentColor;
  border-radius: 3px;
}
.icon-mail::after {
  content: "";
  position: absolute;
  width: 15px;
  height: 15px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg) translate(1px, -5px);
}
.icon-euro::before { content: "€"; font-size: 20px; font-weight: 950; transform: translateY(-1px); }
.icon-check::before { content: "✓"; font-size: 20px; font-weight: 950; transform: translateY(-1px); }

@media (max-width: 980px) {
  .hub-hero-grid, .recommender-grid { grid-template-columns: 1fr; }
}


/* V4 — ofuscación, navegación móvil, resumen dinámico y página de gracias */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.mobile-nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-direction: column;
  cursor: pointer;
}
.mobile-nav-toggle span:not(.sr-only) {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 99px;
  background: var(--text);
}
.nav-cta-mobile { display: none; }
.obfuscated-email {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 2px;
  color: var(--green-dark);
  font-weight: 850;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  cursor: pointer;
}
.form-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: -8px 0 22px;
  padding: 12px;
  border: 1px solid rgba(0, 159, 115, .18);
  border-radius: 16px;
  background: linear-gradient(135deg, #f1fff9, #fffaf2);
}
.form-summary[hidden] { display: none; }
.form-summary span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #fff;
  color: var(--text-soft);
  font-size: .82rem;
  font-weight: 850;
  border: 1px solid var(--line);
}
.form-summary span::before {
  content: "✓";
  display: grid;
  place-items: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  font-size: .65rem;
}
.lead-reference {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--green-soft);
  color: var(--green-dark) !important;
  font-weight: 850;
}
.thanks-next {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 24px;
}

@media (max-width: 980px) {
  .mobile-nav-toggle { display: inline-flex; }
  .header-inner { position: relative; }
  .main-nav {
    position: absolute;
    top: calc(100% + 1px);
    left: 0;
    right: 0;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 0 0 22px 22px;
    background: rgba(255,255,255,.98);
    box-shadow: var(--shadow-soft);
  }
  .main-nav.is-open { display: flex; }
  .main-nav a {
    padding: 13px 12px;
    border-radius: 12px;
  }
  .main-nav a:hover { background: var(--green-soft); }
  .nav-cta-mobile { display: inline-flex !important; margin-top: 8px; width: 100%; }
  .header-cta-desktop { display: none; }
}

@media (max-width: 640px) {
  .header-cta { display: inline-flex; }
  .nav-cta-mobile { display: inline-flex !important; }
  .form-summary { margin-top: 0; }
  .thanks-next { flex-direction: column; }
  .thanks-next .hero-cta, .thanks-next .hero-link { width: 100%; justify-content: center; text-align: center; }
}

/* V4.0.1 — ajuste final de CTA móvil */
@media (max-width: 640px) {
  .header-cta-desktop { display: none !important; }
  .main-nav.is-open .nav-cta-mobile { display: inline-flex !important; }
}


/* V5 — corrección de navegación y ofuscación estilo Midamentum */
.mobile-nav-toggle {
  display: none !important;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-direction: column;
  cursor: pointer;
  box-shadow: none;
}
.mobile-nav-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 99px;
  background: var(--text);
}
.header-cta-desktop { display: inline-flex; }
.nav-cta-mobile { display: none !important; }
.obfuscated-email {
  display: inline-flex;
  align-items: center;
  color: var(--text);
  font-weight: 850;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  cursor: pointer;
}
.obfuscated-email:hover { color: var(--green-dark); }
@media (max-width: 980px) {
  .mobile-nav-toggle { display: inline-flex !important; }
  .header-inner { position: relative; }
  .main-nav {
    position: absolute;
    top: calc(100% + 1px);
    left: 0;
    right: 0;
    display: none !important;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 0 0 22px 22px;
    background: rgba(255,255,255,.98);
    box-shadow: var(--shadow-soft);
  }
  .main-nav.is-open { display: flex !important; }
  .main-nav a {
    padding: 13px 12px;
    border-radius: 12px;
  }
  .main-nav a:hover { background: var(--green-soft); }
  .header-cta-desktop { display: none !important; }
}

/* V6 — ofuscación sin href mailto persistente en enlaces legales */

/* V7 — nuevas verticales: seguros y bancarios */
.choice-grid.two .choice-card { min-height: 136px; }
.icon-car::before { content: "🚗"; position: absolute; inset: 0; display: grid; place-items: center; font-size: 22px; }
.icon-bike::before { content: "🏍"; position: absolute; inset: 0; display: grid; place-items: center; font-size: 21px; }
.icon-health::before { content: "+"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 26px; font-weight: 950; }
.icon-life::before { content: "♥"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 23px; }
.icon-shield::before { content: "✓"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 24px; font-weight: 950; }
.icon-paw::before { content: "●"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 18px; box-shadow: 0 -8px 0 -4px currentColor, 8px -5px 0 -4px currentColor, -8px -5px 0 -4px currentColor; border-radius: 50%; }
.icon-briefcase::before { content: "▣"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 22px; }
.icon-user::before { content: "●"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 21px; }
.icon-family::before { content: "●●"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 16px; letter-spacing: -2px; }
.icon-refresh::before { content: "↻"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 24px; font-weight: 900; }
.icon-plus::before { content: "+"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 28px; font-weight: 950; }
.icon-help::before { content: "?"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 23px; font-weight: 950; }
.icon-money::before { content: "€"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 23px; font-weight: 950; }
.icon-piggy::before { content: "€"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 22px; font-weight: 950; }
.icon-card::before { content: "▭"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 28px; font-weight: 950; }
.icon-safe::before { content: "▣"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 23px; }
.icon-mobile::before { content: "▯"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 28px; font-weight: 950; }

.offer-icon-shield::before { content: "✓"; color: var(--green); font-weight: 950; }
.offer-icon-car::before { content: "🚗"; }
.offer-icon-health::before { content: "+"; color: var(--blue); font-weight: 950; font-size: 22px; }
.offer-icon-bank::before { content: "€"; color: var(--green); font-weight: 950; }
.offer-icon-piggy::before { content: "€"; color: var(--orange-dark); font-weight: 950; }
.offer-icon-card::before { content: "▭"; color: var(--blue); font-weight: 950; font-size: 24px; }

.page-seguros .hero h1 strong { color: var(--blue); }
.page-seguros .hero { background: radial-gradient(circle at 7% 20%, rgba(13,102,194,.14), transparent 32%), radial-gradient(circle at 75% 8%, rgba(0,159,115,.12), transparent 30%), linear-gradient(135deg, #fffaf2 0%, #ffffff 52%, #eef6ff 100%); }
.page-bancarios .hero h1 strong { color: var(--orange-dark); }
.page-bancarios .hero { background: radial-gradient(circle at 7% 20%, rgba(255,151,0,.16), transparent 32%), radial-gradient(circle at 75% 8%, rgba(13,102,194,.12), transparent 30%), linear-gradient(135deg, #fffaf2 0%, #ffffff 52%, #fff7ea 100%); }

/* V8: nuevas verticales fibra/móvil y alarmas */
.icon-wifi::before { content: "⌁"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 25px; font-weight: 950; }
.icon-router::before { content: "▰"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 23px; font-weight: 950; }
.icon-tv::before { content: "▭"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 28px; font-weight: 950; }
.icon-phone::before { content: "▯"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 28px; font-weight: 950; }
.icon-alarm::before { content: "◉"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--orange-dark); font-size: 24px; font-weight: 950; }
.icon-camera::before { content: "◉"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--blue); font-size: 22px; font-weight: 950; box-shadow: inset 0 0 0 6px transparent; }
.recommender-icon.icon-wifi::before { content: "⌁"; color: var(--green); font-weight: 950; }
.recommender-icon.icon-alarm::before { content: "◉"; color: var(--orange-dark); font-weight: 950; }
.offer-icon-wifi::before { content: "⌁"; color: var(--green); font-weight: 950; }
.offer-icon-router::before { content: "▰"; color: var(--blue); font-weight: 950; }
.offer-icon-mobile::before { content: "▯"; color: var(--orange-dark); font-weight: 950; font-size: 24px; }
.offer-icon-alarm::before { content: "◉"; color: var(--orange-dark); font-weight: 950; }
.offer-icon-camera::before { content: "◉"; color: var(--blue); font-weight: 950; }


/* V10 — renting como comparador asistido, sin falsas ofertas */
.renting-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .72fr);
  gap: 42px;
  align-items: center;
}
.renting-hero-note {
  padding: clamp(22px, 3vw, 32px);
  border: 1px solid var(--line);
  border-radius: 30px;
  background: rgba(255,255,255,.9);
  box-shadow: var(--shadow-soft);
}
.renting-hero-note h2 {
  margin: 0 0 12px;
  font-size: clamp(1.45rem, 2vw, 2rem);
  letter-spacing: -.04em;
  line-height: 1.08;
}
.renting-hero-note p {
  margin: 0;
  color: var(--text-soft);
}
.renting-hero-note ul {
  display: grid;
  gap: 10px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
  color: var(--text-soft);
  font-weight: 800;
}
.renting-hero-note li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.renting-hero-note li::before {
  content: "✓";
  display: grid;
  place-items: center;
  width: 22px;
  min-width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  font-size: .72rem;
  font-weight: 950;
  margin-top: 1px;
}
.renting-form-section {
  padding-top: 46px;
}
.renting-form-shell {
  max-width: 980px;
}
.renting-diagnostic {
  margin-top: 18px;
  padding: clamp(18px, 2vw, 24px);
  border: 1px solid rgba(0,159,115,.22);
  border-radius: 22px;
  background: linear-gradient(135deg, #f2fff9, #fffaf2);
}
.renting-diagnostic-head {
  display: grid;
  gap: 6px;
  margin-bottom: 16px;
}
.renting-diagnostic-head strong {
  font-size: 1.08rem;
  letter-spacing: -.02em;
}
.renting-diagnostic-head span {
  color: var(--text-soft);
  font-size: .92rem;
}
.renting-diagnostic-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.renting-diagnostic-item {
  padding: 15px 16px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: rgba(255,255,255,.94);
}
.renting-diagnostic-item small {
  display: block;
  margin-bottom: 4px;
  color: var(--green-dark);
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .68rem;
}
.renting-diagnostic-item strong {
  display: block;
  font-size: 1rem;
  letter-spacing: -.02em;
}
.renting-diagnostic-item span {
  display: block;
  margin-top: 4px;
  color: var(--text-soft);
  font-size: .88rem;
}
.renting-diagnostic-note {
  margin: 16px 0 0;
  color: var(--text-soft);
  font-size: .92rem;
}
.renting-no-offers {
  padding: clamp(20px, 3vw, 32px);
  border: 1px dashed rgba(12,35,64,.22);
  border-radius: 24px;
  background: linear-gradient(135deg, #ffffff, #f8fffc);
  text-align: center;
}
.renting-no-offers h3 {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  letter-spacing: -.04em;
}
.renting-no-offers p {
  max-width: 760px;
  margin: 0 auto;
  color: var(--text-soft);
}
.lead-form .button[data-submit][hidden],
.lead-form button[data-submit][hidden] {
  display: none !important;
}

@media (max-width: 980px) {
  .renting-hero-grid { grid-template-columns: 1fr; }
  .renting-form-shell { max-width: 100%; }
}
@media (max-width: 640px) {
  .renting-diagnostic-grid { grid-template-columns: 1fr; }
}


/* V11 — formularios bajo hero en todas las verticales */
.vertical-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .72fr);
  gap: 42px;
  align-items: center;
}
.vertical-hero-note {
  padding: clamp(22px, 3vw, 32px);
  border: 1px solid var(--line);
  border-radius: 30px;
  background: rgba(255,255,255,.9);
  box-shadow: var(--shadow-soft);
}
.vertical-hero-note h2 {
  margin: 0 0 12px;
  font-size: clamp(1.45rem, 2vw, 2rem);
  letter-spacing: -.04em;
  line-height: 1.08;
}
.vertical-hero-note p {
  margin: 0;
  color: var(--text-soft);
}
.vertical-hero-note ul {
  display: grid;
  gap: 10px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
  color: var(--text-soft);
  font-weight: 800;
}
.vertical-hero-note li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.vertical-hero-note li::before {
  content: "✓";
  display: grid;
  place-items: center;
  width: 22px;
  min-width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  font-size: .72rem;
  font-weight: 950;
  margin-top: 1px;
}
.vertical-form-section {
  padding-top: 46px;
  padding-bottom: 34px;
}
.vertical-form-shell {
  max-width: 980px;
}
.vertical-form-shell .form-errors {
  margin-bottom: 18px;
}
@media (max-width: 980px) {
  .vertical-hero-grid { grid-template-columns: 1fr; }
  .vertical-form-shell { max-width: 100%; }
}


/* V12 — capa SEO sin alterar la estética base del recomendador */
.hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; margin-top: 30px; }
.hero-link { font-weight: 900; color: var(--green-dark); text-decoration: none; }
.page-luz-gas-seo .hero-copy h1 { max-width: 760px; }
.seo-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.seo-card-grid-three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.seo-card { display: flex; flex-direction: column; gap: 14px; padding: 26px; border: 1px solid var(--line); border-radius: 26px; background: #fff; box-shadow: var(--shadow-soft); min-height: 100%; }
.seo-card .tag { width: fit-content; margin: 0; padding: 6px 10px; border-radius: 999px; background: var(--green-soft); color: var(--green-dark); font-size: .72rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.seo-card h3 { margin: 0; font-size: 1.28rem; line-height: 1.15; letter-spacing: -.035em; }
.seo-card h3 a { text-decoration: none; }
.seo-card p:not(.tag) { margin: 0; color: var(--text-soft); }
.seo-card-link { margin-top: auto; color: var(--green-dark); font-weight: 900; text-decoration: none; }
.seo-section-action { display: flex; justify-content: center; margin-top: 30px; }
.section-head-left { margin: 0; text-align: left; }
.seo-split { display: grid; grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr); gap: 42px; align-items: start; }
.seo-content-flow { max-width: 860px; margin: 0 auto; display: grid; gap: 22px; }
.seo-content-flow h2 { margin: 18px 0 0; font-size: clamp(1.72rem, 2.8vw, 2.55rem); letter-spacing: -.05em; line-height: 1.06; }
.seo-content-flow h2:first-child { margin-top: 0; }
.seo-content-flow h3 { margin: 0 0 10px; font-size: 1.18rem; letter-spacing: -.03em; }
.seo-content-flow p { margin: 0; color: var(--text-soft); font-size: 1.02rem; }
.seo-content-flow ul, .seo-content-flow ol { margin: 0; padding-left: 22px; color: var(--text-soft); }
.seo-content-flow li + li { margin-top: 8px; }
.seo-content-box, .seo-cta-box { padding: clamp(20px, 3vw, 30px); border: 1px solid var(--line); border-radius: 24px; background: linear-gradient(135deg, #ffffff, #f7fffb); box-shadow: var(--shadow-soft); }
.seo-cta-box { text-align: center; background: linear-gradient(135deg, #f0fff9, #fff7e9); }
.seo-cta-box .hero-cta { margin-top: 6px; }
.seo-table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: var(--shadow-soft); }
.seo-table-wrap table { width: 100%; min-width: 680px; border-collapse: collapse; }
.seo-table-wrap th, .seo-table-wrap td { padding: 16px 18px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--line); }
.seo-table-wrap th { background: var(--green-soft); color: var(--green-dark); font-size: .88rem; text-transform: uppercase; letter-spacing: .06em; }
.seo-table-wrap tr:last-child td { border-bottom: 0; }
.seo-related { background: linear-gradient(180deg, #ffffff, #f7fffb); }
@media (max-width: 980px) { .seo-card-grid, .seo-card-grid-three, .seo-split { grid-template-columns: 1fr; } .section-head-left { text-align: center; margin: 0 auto 10px; } }
@media (max-width: 640px) { .hero-actions { align-items: stretch; } .hero-actions .hero-cta, .hero-actions .hero-link, .seo-section-action .hero-cta, .seo-cta-box .hero-cta { width: 100%; justify-content: center; text-align: center; } .seo-card, .seo-content-box, .seo-cta-box { border-radius: 20px; padding: 20px; } }

/* V13 — calculadora de ahorro luz y gas */
.calculator-layout {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr);
  gap: clamp(28px, 5vw, 54px);
  align-items: start;
}
.calculator-intro {
  position: sticky;
  top: 104px;
}
.calculator-note {
  margin-top: 24px;
}
.calculator-note p {
  margin: 0;
  color: var(--text-soft);
}
.savings-calculator {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--shadow-soft);
  padding: clamp(22px, 3vw, 34px);
}
.savings-calculator .field {
  margin-bottom: 0;
}
.savings-calculator .field input,
.savings-calculator .field select {
  min-height: 52px;
}
.calculator-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 24px;
}
.calculator-error {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #fff3f0;
  color: #aa2e18;
  font-weight: 850;
  border: 1px solid rgba(170, 46, 24, .18);
}
.calculator-result {
  margin-top: 28px;
  padding-top: 26px;
  border-top: 1px solid var(--line);
}
.result-head h3 {
  margin: 0 0 8px;
  font-size: clamp(1.45rem, 2.3vw, 2.05rem);
  line-height: 1.08;
  letter-spacing: -.045em;
}
.result-head p:not(.eyebrow) {
  margin: 0;
  color: var(--text-soft);
}
.result-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0;
}
.result-metrics div {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff, #f7fffb);
}
.result-metrics span {
  display: block;
  color: var(--text-soft);
  font-size: .84rem;
  font-weight: 800;
}
.result-metrics strong {
  display: block;
  margin-top: 6px;
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  letter-spacing: -.04em;
}
.result-breakdown {
  display: grid;
  gap: 12px;
}
.result-item {
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #fff;
}
.result-item strong {
  display: block;
  margin-bottom: 4px;
  font-size: 1rem;
}
.result-item p {
  margin: 0;
  color: var(--text-soft);
  font-size: .94rem;
}
.result-item-high {
  border-color: rgba(237, 125, 0, .35);
  background: linear-gradient(180deg, #fff, #fff7e9);
}
.result-item-medium {
  border-color: rgba(0, 159, 115, .26);
  background: linear-gradient(180deg, #fff, #f1fff9);
}
.result-item-low {
  background: #fbfdff;
}
.result-cta {
  margin-top: 22px;
}
.result-cta h3 {
  margin: 0;
  font-size: clamp(1.25rem, 2vw, 1.65rem);
  letter-spacing: -.04em;
  line-height: 1.12;
}
@media (max-width: 980px) {
  .calculator-layout {
    grid-template-columns: 1fr;
  }
  .calculator-intro {
    position: static;
  }
}
@media (max-width: 640px) {
  .calculator-actions,
  .calculator-actions .button {
    width: 100%;
  }
  .result-metrics {
    grid-template-columns: 1fr;
  }
}

/* V17 — navegación escalable solo en portada; los verticales mantienen su menú propio */
.site-header-home .header-inner {
  gap: 22px;
}

.site-header-home .main-nav {
  flex: 1 1 auto;
  justify-content: center;
  min-width: 0;
  gap: 34px;
}

.site-header-home .nav-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.site-header-home .nav-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
}

.site-header-home .nav-dropdown-toggle span {
  display: inline-block;
  font-size: .78em;
  transform: translateY(1px);
}

.site-header-home .nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 18px);
  left: 50%;
  z-index: 80;
  width: min(420px, calc(100vw - 40px));
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, .98);
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(-50%, 8px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
}

.site-header-home .nav-dropdown-menu::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 100%;
  height: 20px;
}

.site-header-home .nav-dropdown:hover .nav-dropdown-menu,
.site-header-home .nav-dropdown:focus-within .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.site-header-home .nav-dropdown-list {
  display: grid;
  gap: 6px;
}

.site-header-home .main-nav .nav-dropdown-item {
  display: grid;
  gap: 3px;
  padding: 12px 13px;
  border-radius: 15px;
  text-decoration: none;
  border: 1px solid transparent;
}

.site-header-home .main-nav .nav-dropdown-item:hover,
.site-header-home .main-nav .nav-dropdown-item:focus-visible {
  background: linear-gradient(135deg, var(--green-soft), #fffaf2);
  border-color: rgba(0, 159, 115, .16);
  outline: none;
}

.site-header-home .nav-dropdown-item strong {
  color: var(--text);
  font-size: .94rem;
  line-height: 1.2;
}

.site-header-home .nav-dropdown-item span {
  color: var(--text-soft);
  font-size: .78rem;
  line-height: 1.35;
  font-weight: 650;
}

@media (max-width: 980px) {
  .site-header-home .main-nav {
    gap: 0;
    justify-content: flex-start;
  }

  .site-header-home .nav-dropdown {
    display: block;
  }

  .site-header-home .nav-dropdown-toggle {
    padding: 13px 12px;
    border-radius: 12px;
  }

  .site-header-home .nav-dropdown-toggle:hover {
    background: var(--green-soft);
  }

  .site-header-home .nav-dropdown-menu {
    position: static;
    width: 100%;
    min-width: 0;
    padding: 4px 0 8px 10px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    transition: none;
  }

  .site-header-home .nav-dropdown-menu::before {
    display: none;
  }

  .site-header-home .nav-dropdown:hover .nav-dropdown-menu,
  .site-header-home .nav-dropdown:focus-within .nav-dropdown-menu {
    transform: none;
  }

  .site-header-home .nav-dropdown-list {
    gap: 7px;
  }

  .site-header-home .main-nav .nav-dropdown-item {
    padding: 11px 12px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, .72);
  }

  .site-header-home .nav-dropdown-item span {
    font-size: .76rem;
  }
}


/* V21 — dropdown de recomendadores con scroll interno en portada */
.site-header-home .nav-dropdown-menu {
  max-height: calc(100vh - 118px);
  max-height: calc(100dvh - 118px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.site-header-home .nav-dropdown-menu::-webkit-scrollbar {
  width: 8px;
}

.site-header-home .nav-dropdown-menu::-webkit-scrollbar-track {
  background: transparent;
}

.site-header-home .nav-dropdown-menu::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(12, 35, 64, .18);
}

.site-header-home .nav-dropdown-menu::-webkit-scrollbar-thumb:hover {
  background: rgba(12, 35, 64, .28);
}

@media (min-width: 981px) and (max-height: 760px) {
  .site-header-home .nav-dropdown-menu {
    top: calc(100% + 12px);
    max-height: calc(100vh - 104px);
    max-height: calc(100dvh - 104px);
    padding: 12px;
  }

  .site-header-home .nav-dropdown-list {
    gap: 5px;
  }

  .site-header-home .main-nav .nav-dropdown-item {
    padding: 10px 12px;
  }

  .site-header-home .nav-dropdown-item span {
    font-size: .75rem;
    line-height: 1.28;
  }
}

@media (max-width: 980px) {
  .main-nav.is-open {
    max-height: calc(100vh - 82px);
    max-height: calc(100dvh - 82px);
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  .site-header-home .nav-dropdown-menu {
    max-height: none;
    overflow: visible;
  }
}

/* Ajuste producción — evita que el desplegable de recomendadores se cierre al mover el cursor */
@media (min-width: 981px) {
  .site-header-home .nav-dropdown {
    overflow: visible;
  }

  .site-header-home .nav-dropdown::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    width: min(420px, calc(100vw - 40px));
    height: 26px;
    transform: translateX(-50%);
    z-index: 79;
  }

  .site-header-home .nav-dropdown-menu {
    top: calc(100% + 10px);
  }

  .site-header-home .nav-dropdown-menu::before {
    height: 14px;
  }
}

/* Ajuste producción — footer responsive móvil */
@media (max-width: 980px) {
  .site-footer .footer-grid-clean {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .site-footer {
    padding: 42px 0 22px;
  }

  .site-footer .footer-grid,
  .site-footer .footer-grid-clean {
    grid-template-columns: 1fr !important;
    gap: 22px;
  }

  .site-footer .footer-brand,
  .site-footer .footer-note,
  .site-footer .footer-contact {
    min-width: 0;
  }

  .site-footer .footer-note,
  .site-footer .footer-contact {
    padding: 18px;
    border-radius: 18px;
  }

  .site-footer .footer-bottom {
    margin-top: 24px;
  }
}
