/* ============================================================
   AUDITIO — Landing Estudio Fonético
   Sistema visual: base Oticon (limpio, aireado, imágenes a sangre)
   Colores Auditio · gris #3e3e3e (principal) · acento gris oscuro
   ============================================================ */

:root{
  --base-size: 18px;
  --head-font: 'Poppins', system-ui, sans-serif;
  --body-font: 'Open Sans', system-ui, sans-serif;

  /* marca — gris Auditio como color principal */
  --blue: #3e3e3e;
  --blue-ink: #ffffff;
  --blue-deep: color-mix(in oklab, var(--blue) 82%, #000000);   /* texto/acento sobre claro */
  --blue-soft: color-mix(in oklab, var(--blue) 9%, #ffffff);    /* tintes suaves */
  --blue-tint: color-mix(in oklab, var(--blue) 5%, #ffffff);    /* bandas */

  --ink: #3e3e3e;
  --muted: #6c7882;
  --head: #233039;            /* slate oscuro para títulos */

  --page-bg: #ffffff;
  --band-bg: var(--blue-tint);
  --dark-bg: #1b2b34;
  --dark-ink: #d7e4ec;

  --line: #e6edf1;
  --card-bg: #ffffff;
  --card-shadow: 0 22px 50px -28px rgba(26,52,71,.28);

  --radius: 24px;
  --radius-sm: 16px;
  --radius-pill: 999px;

  --maxw: 1180px;
  --gutter: clamp(20px, 5vw, 40px);
}

/* tipografía de títulos (Tweak) */
:root[data-headfont="poppins"]{ --head-font:'Poppins', system-ui, sans-serif; }
:root[data-headfont="montserrat"]{ --head-font:'Montserrat', system-ui, sans-serif; }

/* radio de imágenes (Tweak) */
:root[data-imground="soft"]{ --media-radius: 28px; --media-inset: clamp(16px,3vw,40px); }
:root[data-imground="edge"]{ --media-radius: 0px;  --media-inset: 0px; }

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--body-font);
  font-size:var(--base-size);
  line-height:1.7;
  color:var(--ink);
  background:var(--page-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
h1,h2,h3,h4{
  font-family:var(--head-font); font-weight:700;
  letter-spacing:-.015em; line-height:1.12; margin:0; color:var(--head);
  text-wrap:balance;
}
p{ margin:0; text-wrap:pretty; }
a{ color:inherit; }
em{ font-style:normal; color:var(--blue-deep); }
:focus-visible{ outline:3px solid var(--blue); outline-offset:3px; border-radius:6px; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(56px,8vw,108px); }
.section.band{ background:var(--band-bg); }
.section.dark{ background:var(--dark-bg); color:var(--dark-ink); }
.section.dark h1,.section.dark h2,.section.dark h3{ color:#fff; }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--head-font); font-weight:600;
  font-size:.95rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--blue-deep); margin-bottom:16px;
}
.eyebrow::before{ content:""; width:24px; height:2px; border-radius:2px; background:var(--blue); }
.section.dark .eyebrow{ color:#b7c2c9; }

.h-xl{ font-size:clamp(2.2rem,5.6vw,3.6rem); }
.h-lg{ font-size:clamp(1.85rem,4vw,2.7rem); }
.h-md{ font-size:clamp(1.35rem,2.5vw,1.8rem); }
.lead{ font-size:clamp(1.08rem,1.5vw,1.3rem); color:var(--muted); line-height:1.65; }
.center{ text-align:center; }
.center .eyebrow{ justify-content:center; }
.measure{ max-width:50ch; }
.measure.center{ margin-inline:auto; }

/* ---------- Botones (pill) ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:11px;
  font-family:var(--head-font); font-weight:600; font-size:clamp(1.02rem,1.3vw,1.15rem);
  text-decoration:none; cursor:pointer; border:none;
  padding:17px 30px; min-height:60px; border-radius:var(--radius-pill);
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  line-height:1.15; text-align:center;
}
.btn-primary{ background:var(--blue); color:var(--blue-ink);
  box-shadow:0 14px 28px -12px color-mix(in oklab, var(--blue) 70%, transparent); }
.btn-primary:hover{ transform:translateY(-2px); background:color-mix(in oklab, var(--blue) 90%, #000);
  box-shadow:0 20px 34px -14px color-mix(in oklab, var(--blue) 72%, transparent); }
.btn-primary:active{ transform:translateY(0); }
.btn-ghost{ background:transparent; color:var(--head); border:1.6px solid var(--line); }
.btn-ghost:hover{ border-color:var(--blue); color:var(--blue-deep); }
.btn-block{ width:100%; }
.btn .ico{ width:22px; height:22px; flex:none; }

/* ---------- CTA por sección ---------- */
.section-cta{ display:flex; justify-content:center; margin-top:clamp(34px,5vw,50px); }
.section.dark .section-cta .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.38); }
.section.dark .section-cta .btn-ghost:hover{ border-color:#fff; color:#fff; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in oklab, var(--page-bg) 88%, transparent);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:13px; }
.brand{ display:flex; align-items:center; text-decoration:none; }
.brand img{ height:42px; width:auto; }
.nav-right{ display:flex; align-items:center; gap:14px; }
.lang{ display:flex; align-items:center; gap:6px; }
.lang-btn{ width:34px; height:24px; padding:0; border:1.5px solid var(--line); background:none;
  border-radius:6px; overflow:hidden; cursor:pointer; opacity:.45; display:block;
  transition:opacity .15s ease, border-color .15s ease, transform .12s ease; }
.lang-btn:hover{ opacity:.85; }
.lang-btn:active{ transform:scale(.94); }
.lang-btn.is-active{ opacity:1; border-color:var(--blue); }
.lang-btn .flag{ display:block; width:100%; height:100%; }
.flag--es{ background:linear-gradient(#c60b1e 0 25%, #ffc400 25% 75%, #c60b1e 75% 100%); }
.flag--ca{ background:linear-gradient(#fcdd09 0 11.11%, #da121a 11.11% 22.22%, #fcdd09 22.22% 33.33%, #da121a 33.33% 44.44%, #fcdd09 44.44% 55.55%, #da121a 55.55% 66.66%, #fcdd09 66.66% 77.77%, #da121a 77.77% 88.88%, #fcdd09 88.88% 100%); }
.nav-phone{ display:flex; align-items:center; gap:9px; text-decoration:none;
  font-family:var(--head-font); font-weight:600; color:var(--head); white-space:nowrap; }
.nav-phone .ico{ width:20px; height:20px; color:var(--blue); }
.nav-phone .lbl{ display:none; }
.nav-address{ display:none; align-items:center; gap:9px; text-decoration:none;
  font-family:var(--head-font); font-weight:600; color:var(--head); white-space:nowrap; }
.nav-address .ico{ width:20px; height:20px; color:var(--blue); flex:none; }
.nav-cta{ display:none; }
@media(min-width:520px){ .nav-phone .lbl{ display:inline; } }
@media(min-width:880px){ .nav-address{ display:flex; } }
@media(min-width:900px){ .nav-cta{ display:inline-flex; padding:13px 24px; min-height:0; font-size:1rem; } }

/* ---------- Bleed helpers (imágenes de lado a lado) ---------- */
.ph{
  position:relative; overflow:hidden;
  background-color:#dbe6ee;
  background-image:repeating-linear-gradient(135deg,
     rgba(255,255,255,.55) 0 16px, rgba(255,255,255,0) 16px 32px);
  display:grid; place-items:center;
}
.ph::after{
  content:attr(data-label);
  font-family:'Courier New', monospace; font-size:.78rem; letter-spacing:.02em;
  color:#5b6f7d; text-align:center; line-height:1.5; padding:20px; max-width:34ch;
  text-transform:uppercase;
}

/* ---------- HERO (split-bleed estilo Oticon) ---------- */
.hero{ display:grid; grid-template-columns:1fr; }
.hero__body{ padding-block:clamp(44px,7vw,88px); padding-inline:var(--gutter); }
.hero__inner{ max-width:560px; margin-inline:auto; }
.hero__media{ position:relative; min-height:clamp(280px,62vw,420px); }
.hero__media .ph, .hero__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-title{ font-size:clamp(2.2rem,6.4vw,3.7rem); }
.hero-title .hl{ color:var(--blue-deep); }
.hero-sub{ margin-top:22px; }
.hero-sub b{ color:var(--head); }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.hero-assure{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:26px; }
.hero-assure span{ display:inline-flex; align-items:center; gap:8px; font-size:.97rem; color:var(--muted); font-weight:600; white-space:nowrap; }
.hero-assure .ico{ width:20px; height:20px; color:var(--blue); flex:none; }
.hero-badge{
  position:absolute; left:18px; bottom:18px;
  background:rgba(255,255,255,.94); backdrop-filter:blur(6px);
  border-radius:var(--radius-sm); padding:13px 18px; box-shadow:var(--card-shadow);
  display:flex; align-items:center; gap:13px; max-width:74%;
}
.hero-badge .num{ font-family:var(--head-font); font-weight:800; font-size:1.9rem; color:var(--blue-deep); line-height:1; }
.hero-badge small{ font-size:.85rem; color:var(--muted); line-height:1.3; }
@media(min-width:920px){
  .hero{ grid-template-columns:1fr 1fr; align-items:stretch; }
  .hero__body{ display:flex; flex-direction:column; justify-content:center;
    padding-inline:clamp(40px,5vw,72px);
    padding-left:max(var(--gutter), calc((100vw - var(--maxw))/2 + var(--gutter))); }
  .hero__inner{ margin:0; }
  .hero__media{ min-height:min(86vh,760px); }
}

/* ---------- Tira de confianza ---------- */
.trust{ display:grid; gap:22px; grid-template-columns:1fr; }
.trust-item{ display:flex; align-items:flex-start; gap:15px; }
.trust-item .ico{ width:34px; height:34px; color:var(--blue); flex:none; margin-top:3px; }
.trust-item h3{ font-size:1.1rem; margin-bottom:3px; }
.trust-item p{ font-size:.97rem; color:var(--muted); }
@media(min-width:760px){ .trust{ grid-template-columns:repeat(2,1fr); gap:34px 38px; } }
@media(min-width:1040px){ .trust{ grid-template-columns:repeat(4,1fr); } }

/* ---------- Pain points ---------- */
.pain-grid{ display:grid; gap:20px; grid-template-columns:1fr; margin-top:48px; }
@media(min-width:620px){ .pain-grid{ grid-template-columns:1fr 1fr; } }
@media(min-width:1000px){ .pain-grid{ grid-template-columns:repeat(4,1fr); } }
.pain-card{ background:var(--card-bg); border:1px solid var(--line); box-shadow:var(--card-shadow);
  border-radius:var(--radius); padding:0; overflow:hidden; display:flex; flex-direction:column; }
.pain-media{ position:relative; height:190px; flex:none; }
.pain-media .ph, .pain-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.pain-media .ph::after{ font-size:.66rem; padding:14px; }
.pain-media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(35,48,57,0) 45%, rgba(35,48,57,.45)); }
.pain-body{ padding:26px 24px 28px; }
.pain-ico{ position:absolute; left:16px; bottom:-30px; z-index:2;
  width:66px; height:66px; border-radius:17px; display:grid; place-items:center;
  background:#fff; box-shadow:var(--card-shadow); color:var(--blue-deep); margin:0; }
.pain-ico .ico{ width:38px; height:38px; }
.pain-card h3{ font-size:1.16rem; margin:20px 0 8px; }
.pain-card p{ font-size:.98rem; color:var(--muted); }

/* ---------- Simulaciones auditivas ---------- */
#simulacion{ position:relative; overflow:hidden; }
.sim-bg{ position:absolute; inset:0; z-index:0; pointer-events:none;
  display:flex; flex-wrap:wrap; align-content:center; gap:0 .6em;
  padding:4vw; overflow:hidden;
  font-family:var(--head-font); font-weight:700; line-height:1.5;
  font-size:clamp(1.6rem,4vw,3rem); color:var(--head);
  opacity:.07; filter:blur(2.5px); user-select:none; }
.sim-bg span{ white-space:nowrap; }
#simulacion > .container{ position:relative; z-index:1; }
.sim-inner{ max-width:720px; margin-inline:auto; }
.sim-quote{ font-family:var(--head-font); font-weight:700; color:var(--head);
  font-size:clamp(1.7rem,3.6vw,2.4rem); line-height:1.22; margin:0 auto; text-wrap:balance; }
.sim-cases{ display:grid; gap:16px; margin:36px auto 0; max-width:1060px; grid-template-columns:1fr; }
@media(min-width:760px){ .sim-cases{ grid-template-columns:1fr 1fr; } }
.sim-case{ background:var(--card-bg); border:1px solid var(--line); box-shadow:var(--card-shadow);
  border-radius:var(--radius); padding:clamp(22px,3vw,32px); display:flex; flex-direction:column; }
.sim-case__head{ display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.sim-case__badge{ flex:none; width:46px; height:46px; border-radius:13px;
  display:grid; place-items:center; background:var(--blue); color:#fff;
  font-family:var(--head-font); font-weight:800; font-size:1.35rem; line-height:1; }
.sim-case__meta{ display:flex; flex-direction:column; min-width:0; }
.sim-case__num{ font-family:var(--head-font); font-weight:700; font-size:.72rem;
  color:var(--blue-deep); letter-spacing:.1em; text-transform:uppercase; }
.sim-case__title{ font-family:var(--head-font); font-weight:600; font-size:1.05rem;
  color:var(--head); margin-top:2px; line-height:1.22; }
.sim-case__desc{ color:var(--muted); font-size:.95rem; margin-bottom:18px; }
.sim-text{ font-size:clamp(1.25rem,1.9vw,1.6rem); line-height:1.5; font-weight:500; color:var(--head);
  font-family:var(--head-font); letter-spacing:.002em; margin-top:auto;
  padding-top:18px; border-top:1px dashed var(--line); }
.sim-text .tok{ transition:opacity .4s ease, filter .4s ease; }
.sim-note{ font-size:.87rem; color:var(--muted); display:flex; gap:9px; align-items:flex-start; }
.sim-note--foot{ max-width:1060px; margin:22px auto 0; }
.sim-note .ico{ width:18px; height:18px; color:var(--blue); flex:none; margin-top:2px; }

/* ---------- Feature rows (imagen a sangre + texto) ---------- */
.feature{ display:grid; grid-template-columns:1fr; }
.feature__media{ position:relative; align-self:stretch; min-height:clamp(290px,64vw,380px);
  padding:var(--media-inset, 0px); overflow:hidden; }
.feature__media .ph, .feature__media img{ position:absolute; inset:var(--media-inset, 0px);
  width:calc(100% - 2*var(--media-inset, 0px)); height:calc(100% - 2*var(--media-inset, 0px));
  object-fit:cover; border-radius:var(--media-radius, 0px); }
.feature__body{ display:flex; flex-direction:column; justify-content:center;
  padding:clamp(32px,4.5vw,56px) var(--gutter); }
.feature__inner{ max-width:520px; margin-inline:auto; width:100%; }
.feature__inner .lead{ margin-top:14px; }
.feature__body .h-lg{ font-size:clamp(1.6rem,3vw,2.1rem); }
.feature__inner .meta-list{ margin-top:18px; }
@media(min-width:900px){
  .feature{ grid-template-columns:1fr 1fr; align-items:stretch; }
  .feature__media{ min-height:clamp(300px,32vw,440px); }
  .feature--reverse .feature__media{ order:2; }
  .feature--reverse .feature__body{ order:1; }
  .feature__body{ padding-inline:clamp(40px,5vw,76px); }
}

.meta-list{ list-style:none; padding:0; margin:26px 0 0; display:flex; flex-direction:column; gap:13px; }
.meta-list li{ display:flex; gap:12px; align-items:flex-start; font-size:1.04rem; }
.meta-list .ico{ width:23px; height:23px; color:var(--blue); flex:none; margin-top:5px; }
.feature__body .btn{ margin-top:30px; align-self:flex-start; }

/* flujo oído→cerebro→comprensión (dentro de feature) */
.flow{ display:flex; flex-direction:column; gap:11px; margin-top:22px; }
.flow-step{ display:flex; align-items:center; gap:16px; }
.flow-step .fico{ width:52px; height:52px; border-radius:14px; flex:none; display:grid; place-items:center;
  background:var(--blue-soft); box-shadow:var(--card-shadow); color:var(--blue-deep); }
.flow-step .fico .ico{ width:34px; height:34px; display:block; }
.flow-step h4{ font-size:1.1rem; }
.flow-step p{ font-size:.96rem; color:var(--muted); margin-top:1px; }
.flow-arrow{ display:grid; place-items:center; color:var(--blue); height:10px; margin-left:8px; }
.flow-arrow .ico{ width:22px; height:22px; transform:rotate(90deg); }

/* ---------- Garantía de adaptación (feature 50/50, fondo oscuro) ---------- */
.guarantee-feature{ background:var(--dark-bg); color:var(--dark-ink); }
.guarantee-feature h2,.guarantee-feature .h-lg{ color:#fff; }
.guarantee-feature .h-lg .hl{ color:#fff; }
.guarantee-feature .eyebrow{ color:#b7c2c9; }
.guarantee-feature .eyebrow::before{ background:#b7c2c9; }
.guarantee-feature .lead{ color:var(--dark-ink); }
.guarantee-feature .lead b{ color:#fff; font-weight:700; }

.guarantee-list{ list-style:none; padding:0; margin:22px 0 0;
  display:grid; gap:12px 22px; grid-template-columns:1fr; }
@media(min-width:520px){ .guarantee-list{ grid-template-columns:1fr 1fr; } }
.guarantee-list li{ display:flex; align-items:center; gap:12px;
  font-family:var(--head-font); font-weight:600; color:#fff; font-size:1rem; line-height:1.2; }
.guarantee-list .gico{ width:42px; height:42px; border-radius:12px; flex:none; display:grid; place-items:center;
  background:rgba(255,255,255,.08); }
.guarantee-list .gico .ico{ width:23px; height:23px; color:#fff; }

.guarantee-close__big{ font-family:var(--head-font); font-weight:700; color:#fff;
  font-size:clamp(1.2rem,2vw,1.5rem); line-height:1.3; margin:24px 0 0; text-wrap:balance; }
.guarantee-close__big em{ color:#fff; text-decoration:underline;
  text-decoration-color:rgba(255,255,255,.45); text-underline-offset:5px; }

/* ---------- Banda de imagen full-bleed ---------- */
.poster{ margin:0; }
.bridge{ text-align:center; padding-block:clamp(48px,7vw,84px); }
.bridge-text{ font-family:var(--head-font); font-weight:600; color:var(--head);
  font-size:clamp(1.3rem,2.8vw,2rem); line-height:1.35; max-width:26ch; margin-inline:auto; text-wrap:balance; }
.bridge-text em{ color:var(--blue-deep); }
.contrast-grid{ display:grid; gap:18px; grid-template-columns:1fr; max-width:1140px; margin-inline:auto; text-align:left; }
@media(min-width:760px){ .contrast-grid{ grid-template-columns:1fr 1fr; } }
.contrast-col{ background:var(--card-bg); border:1px solid var(--line); box-shadow:var(--card-shadow);
  border-radius:var(--radius); padding:clamp(24px,3.5vw,40px); }
.contrast-col--ok{ background:var(--blue-tint); border-color:color-mix(in oklab, var(--blue) 22%, #fff); }
.contrast-label{ display:inline-flex; align-items:center; gap:9px; font-family:var(--head-font);
  font-weight:700; font-size:.82rem; letter-spacing:.07em; text-transform:uppercase; margin-bottom:16px; }
.contrast-label .ico{ width:20px; height:20px; flex:none; }
.contrast-label--ok{ color:var(--blue-deep); }
.contrast-label--loss{ color:var(--muted); }
.contrast-text{ font-family:var(--head-font); font-weight:700; color:var(--head);
  font-size:clamp(1.05rem,1.7vw,1.4rem); line-height:1.45; margin:0; }
@media(min-width:760px){ .contrast-text{ white-space:nowrap; } }
.contrast-text--blur{ color:var(--muted); filter:blur(1.3px); user-select:none; }
.contrast-text--blur .f{ opacity:.12; filter:blur(2.2px); }
.poster img{ display:block; width:100%; max-width:600px; margin-inline:auto; height:auto;
  border-radius:var(--radius); box-shadow:var(--card-shadow); }

.imgband{ position:relative; width:100%; height:clamp(260px,40vw,520px); }
.imgband .ph, .imgband img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.imgband__overlay{ position:absolute; inset:0; display:grid; place-items:center; text-align:center;
  padding:clamp(24px,4vw,48px) var(--gutter);
  background:linear-gradient(180deg, rgba(18,26,33,.48) 0%, rgba(18,26,33,.22) 40%, rgba(18,26,33,.18) 100%); }
@media(max-width:600px){
  .imgband{ height:340px; }
  .imgband__overlay{ place-items:end center; padding-bottom:26px;
    background:linear-gradient(180deg, rgba(18,26,33,.10) 0%, rgba(18,26,33,.18) 42%, rgba(18,26,33,.72) 100%); }
}
.imgband__title{ font-family:var(--head-font); font-weight:800; color:#fff;
  text-transform:uppercase; letter-spacing:.01em;
  font-size:clamp(1.25rem,3vw,2.2rem); line-height:1.1;
  text-shadow:0 2px 22px rgba(0,0,0,.55); margin:0; }
.imgband__title .hl{ color:#d8b36a; }
.imgband__sub{ font-family:var(--head-font); font-weight:500; color:rgba(255,255,255,.94);
  font-size:clamp(.85rem,1.3vw,1.1rem); margin-top:clamp(6px,1vw,12px);
  text-shadow:0 2px 16px rgba(0,0,0,.6); }

/* ---------- Tabla comparativa ---------- */
.cmp{ margin-top:48px; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--card-shadow); background:var(--card-bg); }
.cmp-row{ display:grid; grid-template-columns:1.25fr 1fr 1.15fr; }
.cmp-row + .cmp-row{ border-top:1px solid var(--line); }
.cmp-cell{ padding:18px; font-size:.99rem; display:flex; align-items:center; }
.cmp-cell.feat{ font-family:var(--head-font); font-weight:600; color:var(--head); font-size:1rem; }
.cmp-cell.them{ color:var(--muted); }
.cmp-cell.us{ background:var(--blue-soft); font-weight:600; color:var(--blue-deep); }
.cmp-head .cmp-cell{ font-family:var(--head-font); font-weight:700; font-size:.92rem;
  text-transform:uppercase; letter-spacing:.04em; }
.cmp-head .feat{ color:transparent; }
.cmp-head .them{ color:var(--ink); background:color-mix(in oklab, var(--blue) 4%, #fff); }
.cmp-head .us{ color:#fff; background:var(--blue); }
@media(max-width:680px){
  .cmp-cell{ padding:13px; font-size:.9rem; }
  .cmp-row{ grid-template-columns:1.1fr .95fr 1fr; }
  .cmp-head .cmp-cell{ font-size:.74rem; }
}

/* ---------- Propuesta ---------- */
.offer-card{ background:var(--card-bg); border:1px solid var(--line); box-shadow:var(--card-shadow);
  border-radius:var(--radius); padding:clamp(28px,4vw,46px); }
.price-row{ display:flex; align-items:flex-end; gap:16px; margin:20px 0 6px; }
.price-now{ font-family:var(--head-font); font-weight:800; font-size:clamp(2.6rem,7vw,4rem); color:var(--blue-deep); line-height:.9; }
.price-old{ position:relative; font-family:var(--head-font); font-weight:700; font-size:1.5rem; color:var(--muted); }
.price-old::after{ content:""; position:absolute; left:-3px; right:-3px; top:52%; height:3px; background:#e05656; transform:rotate(-8deg); }
.price-tag{ font-size:.96rem; color:var(--muted); }
.offer-list{ list-style:none; padding:0; margin:24px 0; display:flex; flex-direction:column; gap:12px; }
.offer-list li{ display:flex; gap:12px; align-items:flex-start; font-size:1.04rem; }
.offer-list .ico{ width:24px; height:24px; color:var(--blue); flex:none; margin-top:4px; }
.exclusive{ display:inline-flex; align-items:center; gap:10px; margin-top:4px;
  background:var(--dark-bg); color:#fff; border-radius:var(--radius-pill);
  padding:11px 22px; font-family:var(--head-font); font-weight:600; font-size:1rem; }
.exclusive b{ color:#c4ced4; }

/* ---------- Formulario ---------- */
.form-wrap{ display:grid; gap:clamp(28px,4vw,56px); grid-template-columns:1fr; align-items:start; }
@media(min-width:920px){ .form-wrap{ grid-template-columns:.85fr 1.15fr; } }
.form-card{ background:var(--card-bg); border:1px solid var(--line); box-shadow:var(--card-shadow);
  border-radius:var(--radius); padding:clamp(26px,4vw,44px); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--head-font); font-weight:600; color:var(--head); font-size:1rem; margin-bottom:8px; }
.field label .req{ color:#e05656; }
.field .hint{ font-weight:500; color:var(--muted); font-size:.85rem; }
.input,.select{ width:100%; font-family:var(--body-font); font-size:1.05rem; color:var(--head);
  background:#fff; border:1.6px solid var(--line); border-radius:var(--radius-sm);
  padding:15px 16px; min-height:58px; transition:border-color .18s, box-shadow .18s; }
.input-icon{ position:relative; }
.input-icon .ico{ position:absolute; left:15px; top:50%; transform:translateY(-50%); width:22px; height:22px; color:#25d366; }
.input-icon .input{ padding-left:48px; }
.input:focus,.select:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 4px var(--blue-soft); }
.input::placeholder{ color:#9aa6ad; }
.field[data-state="ok"] .input{ border-color:#23a06b; }
.field[data-state="err"] .input{ border-color:#e05656; }
.err-msg{ display:none; color:#cf3d3d; font-size:.85rem; margin-top:7px; font-weight:600; }
.field[data-state="err"] .err-msg{ display:block; }
.check{ display:flex; gap:12px; align-items:flex-start; cursor:pointer; font-size:.95rem; color:var(--muted); }
.check input{ width:24px; height:24px; margin-top:2px; accent-color:var(--blue); flex:none; }
.form-foot{ margin-top:10px; font-size:.85rem; color:var(--muted); display:flex; gap:9px; align-items:flex-start; }
.form-foot .ico{ width:17px; height:17px; color:var(--blue); flex:none; margin-top:2px; }
.form-aside ul{ list-style:none; padding:0; margin:24px 0 0; display:flex; flex-direction:column; gap:15px; }
.form-aside li{ display:flex; gap:13px; align-items:flex-start; }
.form-aside .ico{ width:24px; height:24px; color:var(--blue); flex:none; margin-top:3px; }
.form-aside li b{ color:var(--head); font-family:var(--head-font); }
.form-success{ display:none; text-align:center; padding:20px 6px; }
.form-success.show{ display:block; }
.form-success .sico{ width:74px; height:74px; border-radius:50%; background:#25d366; color:#fff; display:grid; place-items:center; margin:0 auto 18px; }
.form-success .sico .ico{ width:40px; height:40px; }
.hp-field{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-error{ margin-top:12px; font-size:.9rem; font-weight:600; color:#cf3d3d;
  background:#fdeaea; border:1px solid #f3c4c4; border-radius:12px; padding:11px 14px; }
.form-error[hidden]{ display:none; }
.btn.is-loading{ opacity:.7; pointer-events:none; }

/* ---------- Testimonio ---------- */
.testi{ max-width:760px; margin:0 auto; text-align:center; }
.testi-stars{ display:inline-flex; gap:5px; color:#f6b40a; margin-bottom:20px; }
.testi-stars .ico{ width:28px; height:28px; }
.testi-quote{ font-family:var(--head-font); font-weight:600; font-size:clamp(1.4rem,3.4vw,2.05rem); line-height:1.35; color:var(--head); }
.testi-author{ display:inline-flex; align-items:center; gap:15px; margin-top:28px; }
.testi-author .ph{ width:66px; height:66px; border-radius:50%; flex:none; }
.testi-author img{ width:66px; height:66px; border-radius:50%; object-fit:cover; object-position:center top; flex:none; }
.testi-author .ph::after{ font-size:.5rem; padding:5px; }
.testi-author b{ font-family:var(--head-font); font-size:1.08rem; color:var(--head); display:block; }
.testi-source{ display:inline-flex; align-items:center; gap:7px; font-size:.92rem; color:var(--muted); margin-top:4px; }

/* ---------- Reseñas (grid) ---------- */
.reviews-grid{ display:grid; gap:20px; grid-template-columns:1fr; max-width:1080px; margin:48px auto 0; }
@media(min-width:780px){ .reviews-grid{ grid-template-columns:1fr 1fr; } }
.review{ margin:0; background:var(--card-bg); border:1px solid var(--line); box-shadow:var(--card-shadow);
  border-radius:var(--radius); padding:clamp(26px,3.2vw,38px); display:flex; flex-direction:column; }
.review-stars{ display:inline-flex; gap:4px; color:#f6b40a; margin-bottom:16px; }
.review-stars .ico{ width:22px; height:22px; }
.review-text{ margin:0; font-size:1.02rem; line-height:1.6; color:var(--ink); }
.review-author{ display:flex; align-items:center; gap:14px; margin-top:24px;
  padding-top:20px; border-top:1px solid var(--line); }
.review-ph{ width:88px; height:88px; border-radius:50%; flex:none; }
.review-author img{ width:88px; height:88px; border-radius:50%; object-fit:cover; flex:none; }
.review-ph.ph::after{ font-size:.48rem; padding:4px; }
.review-author b{ font-family:var(--head-font); font-size:1.05rem; color:var(--head); display:block; }

/* ---------- CTA final (banda imagen) ---------- */
.cta-band{ position:relative; isolation:isolate; }
.cta-band .ph, .cta-band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(18,33,45,.82), rgba(18,33,45,.72)); }
.cta-band .container{ text-align:center; padding-block:clamp(64px,9vw,120px); }
.cta-band h2,.cta-band .lead{ color:#fff; }
.cta-band .lead{ color:rgba(255,255,255,.85); }
.cta-band .btn-primary{ margin-top:30px; }
.cta-assure{ margin-top:22px; color:rgba(255,255,255,.72); font-size:.95rem; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--dark-bg); color:#9fb1bc; font-size:.92rem; }
.site-footer .container{ padding-block:48px; }
.foot-grid{ display:grid; gap:28px; grid-template-columns:1fr; }
@media(min-width:760px){ .foot-grid{ grid-template-columns:1.5fr 1fr 1fr; } }
.foot-logo{ display:inline-flex; background:#fff; border-radius:14px; padding:14px 18px; margin-bottom:16px; }
.foot-logo img{ height:38px; width:auto; }
.site-footer a{ text-decoration:none; color:#9fb1bc; }
.site-footer a:hover{ color:#fff; }
.foot-col h4{ color:#fff; font-size:.92rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px; }
.foot-col p{ margin-bottom:9px; }
.foot-legal{ border-top:1px solid rgba(255,255,255,.12); margin-top:34px; padding-top:22px; font-size:.82rem; color:#738794; }
.foot-legal-links{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-bottom:12px; }
.foot-legal-links a{ color:#b9c7d0; font-family:var(--head-font); font-weight:600; font-size:.86rem; }
.foot-legal-links a:hover{ color:#fff; }
.foot-legal-copy{ margin:0; }

/* ---------- WhatsApp flotante ---------- */
.wa-float{ position:fixed; right:18px; bottom:18px; z-index:55;
  display:flex; align-items:center; gap:11px; text-decoration:none;
  background:#25d366; color:#fff; font-family:var(--head-font); font-weight:600;
  padding:14px 20px; border-radius:var(--radius-pill); min-height:60px;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.55);
  transition:transform .15s ease; }
.wa-float:hover{ transform:translateY(-2px); }
.wa-float .ico{ width:28px; height:28px; flex:none; }
.wa-float .wa-txt{ display:none; }
@media(min-width:560px){ .wa-float .wa-txt{ display:inline; } }
@media(min-width:900px){ .wa-float{ right:24px; bottom:24px; } }

@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior:auto !important; transition-duration:.01ms !important; }
}
