/* ============================================================
   FisiotrainingLeira — Hoja de estilos única
   Paleta: turquesa (--tq) + azul oscuro (--az) + neutros
   Tipografía: Montserrat
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  /* Color */
  --az:#033b4a;          /* azul oscuro principal */
  --az-d:#022a35;        /* azul más oscuro */
  --az-l:#e7f1f4;        /* azul muy claro / fondo */
  --tq:#12c7d9;          /* turquesa accent */
  --tq-d:#0aa3b3;        /* turquesa oscuro */
  --tq-l:#e6f9fb;        /* turquesa muy claro */
  --wa:#25d366;          /* whatsapp verde */
  --wa-d:#1ea952;
  --wh:#ffffff;
  --gr-l:#f6f7f8;        /* gris muy claro */
  --gr:#eef0f2;          /* gris medio */
  --gr-b:#e2e6ea;        /* borde gris */
  --txt:#0d1b22;         /* texto principal */
  --txt2:#3a4a52;        /* texto secundario */
  --txt3:#6b7a82;        /* texto suave */
  --warn:#f59e0b;

  /* Radios */
  --r6:6px;
  --r8:8px;
  --r12:14px;
  --r20:22px;
  --rpill:999px;

  /* Sombras */
  --sh1:0 1px 2px rgba(3,59,74,.04), 0 2px 8px rgba(3,59,74,.04);
  --sh2:0 4px 14px rgba(3,59,74,.06), 0 12px 32px rgba(3,59,74,.06);
  --sh3:0 12px 40px rgba(3,59,74,.10), 0 24px 60px rgba(3,59,74,.08);

  /* Layout */
  --maxw:1240px;
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Montserrat', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size:16px;
  line-height:1.55;
  color:var(--txt);
  background:var(--wh);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4,h5,p{margin:0}
em{font-style:italic;color:var(--tq-d)}

/* ---------- UTILIDADES ---------- */
.sec{
  max-width:var(--maxw);
  margin:0 auto;
  padding:96px 28px;
}
.sec-wh{background:var(--wh)}
.sec-gr{background:var(--gr-l)}
.sec-az{background:var(--az);color:#fff}
.sec-az .eyebrow{color:var(--tq)}

.eyebrow{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--tq-d);
  padding:6px 12px;
  background:var(--tq-l);
  border-radius:var(--rpill);
  margin-bottom:18px;
}
.h2{
  font-size:clamp(34px, 4.4vw, 56px);
  font-weight:900;
  line-height:1.05;
  letter-spacing:-1.4px;
  color:var(--txt);
  margin-bottom:18px;
  text-wrap:balance;
}
.sec-az .h2{color:#fff}
.h2 .accent{color:var(--tq-d)}
.sec-az .h2 .accent{color:var(--tq)}
.lead{
  font-size:17px;
  line-height:1.65;
  color:var(--txt2);
  max-width:640px;
  margin-bottom:8px;
}
.sec-az .lead{color:rgba(255,255,255,.78)}

/* ---------- BOTONES ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 18px;
  border-radius:var(--rpill);
  font-weight:700;
  font-size:13px;
  letter-spacing:.2px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
  cursor:pointer;
  border:1px solid transparent;
}
.btn svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.btn-lg{padding:14px 22px;font-size:14px}
.btn-tq{background:var(--tq);color:var(--az)}
.btn-tq:hover{background:#0fb8c9;transform:translateY(-1px);box-shadow:0 8px 22px rgba(18,199,217,.35)}
.btn-az{background:var(--az);color:#fff}
.btn-az:hover{background:var(--az-d);transform:translateY(-1px);box-shadow:0 8px 22px rgba(3,59,74,.25)}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{background:var(--wa-d);transform:translateY(-1px);box-shadow:0 8px 22px rgba(37,211,102,.35)}
.btn-wh{background:#fff;color:var(--az)}
.btn-wh:hover{background:#f0f3f5;transform:translateY(-1px)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-outline:hover{background:rgba(255,255,255,.08);border-color:#fff}
.btn-outline-dk{background:transparent;color:var(--az);border-color:var(--gr-b)}
.btn-outline-dk:hover{background:var(--gr-l);border-color:var(--az)}

/* ---------- TAGS ---------- */
.tag{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  padding:5px 10px;
  border-radius:var(--rpill);
  letter-spacing:.6px;
  text-transform:uppercase;
}
.tag-tq{background:var(--tq-l);color:var(--tq-d)}
.tag-az{background:var(--az-l);color:var(--az)}
.tag-wh{background:rgba(255,255,255,.16);color:#fff;backdrop-filter:blur(4px)}

/* ---------- ANNOUNCE BAR ---------- */
.announce{
  background:var(--az);
  color:#fff;
  font-size:13px;
  padding:10px 24px;
  text-align:center;
}
.announce p{margin:0;letter-spacing:.1px}
.announce span{color:var(--tq);font-weight:700;margin-left:4px}

/* ---------- NAV ---------- */
nav{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--gr-b);
}
.nav-i{
  max-width:var(--maxw);
  margin:0 auto;
  padding:14px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo img{width:42px;height:42px;border-radius:10px;object-fit:cover;background:var(--az)}
.nav-logo-txt{font-weight:900;font-size:17px;letter-spacing:-.4px;color:var(--az);line-height:1}
.nav-logo-txt span{color:var(--tq-d)}
.nav-badge{font-size:10px;color:var(--txt3);font-weight:500;margin-top:3px;letter-spacing:.2px}
.nav-links{display:flex;gap:6px}
.nav-links a{
  font-size:13px;
  font-weight:600;
  color:var(--txt2);
  padding:8px 12px;
  border-radius:8px;
  transition:background .15s ease, color .15s ease;
}
.nav-links a:hover{background:var(--gr-l);color:var(--az)}
.nav-phone{font-weight:800;font-size:14px;color:var(--az);letter-spacing:.3px}

/* ---------- HERO ---------- */
.hero{
  max-width:var(--maxw);
  margin:0 auto;
  padding:54px 28px 96px;
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:56px;
  align-items:center;
}
.hero-l{min-width:0}
.hero-proof{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  background:var(--gr-l);
  border:1px solid var(--gr-b);
  border-radius:var(--rpill);
  margin-bottom:24px;
}
.hero-stars{display:flex;gap:1px;color:var(--warn);font-size:14px;line-height:1}
.hero-proof-txt{font-size:12px;color:var(--txt2)}
.hero-proof-txt strong{color:var(--txt)}
.hero-h1{
  font-size:clamp(46px,6vw,82px);
  font-weight:900;
  line-height:1;
  letter-spacing:-2.5px;
  color:var(--txt);
  margin-bottom:24px;
}
.hero-h1 .ln1{color:var(--txt)}
.hero-h1 .ln2{color:var(--az)}
.hero-h1 .ln3{color:var(--tq-d);font-style:italic;font-weight:700}
.hero-sub{
  font-size:18px;
  line-height:1.6;
  color:var(--txt2);
  margin-bottom:30px;
  max-width:540px;
}
.hero-sub strong{color:var(--az)}
.hero-btns{display:flex;gap:12px;margin-bottom:42px;flex-wrap:wrap}
.hero-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  padding-top:30px;
  border-top:1px solid var(--gr-b);
}
.hero-stat-n{
  font-size:34px;
  font-weight:900;
  color:var(--az);
  letter-spacing:-1.2px;
  line-height:1;
  margin-bottom:6px;
}
.hero-stat-l{font-size:12px;color:var(--txt3);font-weight:500}
.hero-r{position:relative}
.hero-photo{
  border-radius:var(--r20);
  overflow:hidden;
  aspect-ratio:4/5;
  background:var(--az-l);
  box-shadow:var(--sh3);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;
  inset:0;
  border-radius:var(--r20);
  background:linear-gradient(180deg, transparent 50%, rgba(3,59,74,.18) 100%);
  pointer-events:none;
}
.hero-card{
  position:absolute;
  left:-22px;
  bottom:30px;
  width:300px;
  background:#fff;
  border-radius:var(--r12);
  padding:18px 20px;
  box-shadow:var(--sh3);
  border:1px solid var(--gr-b);
}
.hero-card-badge{
  display:inline-block;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--tq-d);
  background:var(--tq-l);
  padding:4px 9px;
  border-radius:var(--rpill);
  margin-bottom:12px;
}
.hero-card p{font-size:13px;line-height:1.55;color:var(--txt2);margin-bottom:14px}
.hero-card-author{display:flex;align-items:center;gap:10px}
.hero-av{
  width:38px;height:38px;
  border-radius:50%;
  background:var(--az);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;
}
.hero-av-info p{font-size:12px;font-weight:700;color:var(--txt);margin:0 0 1px 0}
.hero-av-info span{font-size:10.5px;color:var(--txt3)}

/* ---------- TRUST BAR ---------- */
.trust{background:var(--az);padding:24px 28px;border-top:1px solid rgba(255,255,255,.06)}
.trust-i{
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.trust-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  font-weight:600;
  color:rgba(255,255,255,.85);
  letter-spacing:.2px;
}
.trust-icon{
  width:30px;height:30px;
  border-radius:50%;
  background:rgba(18,199,217,.12);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.trust-icon svg{width:14px;height:14px;stroke:var(--tq);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.trust-sep{width:1px;height:22px;background:rgba(255,255,255,.08)}

/* ---------- DIFERENCIADORES ---------- */
.diff-wrap{
  display:grid;
  grid-template-columns:340px 1fr;
  gap:54px;
  margin-top:8px;
}
.diff-sticky{position:sticky;top:90px;align-self:start}
.diff-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
.diff-item{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  padding:26px 22px;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.diff-item:hover{
  transform:translateY(-3px);
  box-shadow:var(--sh2);
  border-color:rgba(18,199,217,.4);
}
.di-icon{
  width:42px;height:42px;
  border-radius:10px;
  background:var(--tq-l);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.di-icon svg{width:20px;height:20px;stroke:var(--tq-d);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.diff-item h3{
  font-size:17px;
  font-weight:800;
  letter-spacing:-.3px;
  color:var(--txt);
  margin-bottom:8px;
}
.diff-item p{font-size:14px;line-height:1.6;color:var(--txt2);margin-bottom:14px}
.di-no{font-size:11px;font-weight:700;color:#b34243;letter-spacing:.2px}

/* ---------- PRUEBA SOCIAL BAR ---------- */
.sp-bar{background:var(--az-d);padding:32px 28px;color:#fff}
.sp-inner{
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:24px;
  justify-content:space-between;
  flex-wrap:wrap;
}
.sp-item{display:flex;align-items:center;gap:12px}
.sp-n{
  font-size:32px;
  font-weight:900;
  color:var(--tq);
  letter-spacing:-1.2px;
  line-height:1;
}
.sp-l{font-size:11px;color:rgba(255,255,255,.6);font-weight:500;line-height:1.4}
.sp-sep{width:1px;height:36px;background:rgba(255,255,255,.1)}

/* ---------- SERVICIOS ---------- */
.sv-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:32px;
  margin-bottom:48px;
}
.sv-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:20px;
}
.sv-card{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r20);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease;
}
.sv-card:hover{transform:translateY(-4px);box-shadow:var(--sh2)}
.sv-card.feat{
  background:var(--az);
  color:#fff;
  border-color:var(--az);
  box-shadow:var(--sh3);
}
.sv-card.feat .sv-title,
.sv-card.feat .sv-desc,
.sv-card.feat .sv-feat,
.sv-card.feat .sv-price,
.sv-card.feat .sv-price-note{color:inherit}
.sv-img{height:220px;background:var(--gr-l);overflow:hidden;position:relative}
.sv-img img{width:100%;height:100%;object-fit:cover}
.sv-body{padding:26px 24px 28px;display:flex;flex-direction:column;flex:1}
.sv-tag{margin-bottom:14px}
.sv-title{
  font-size:22px;
  font-weight:800;
  letter-spacing:-.5px;
  color:var(--txt);
  margin-bottom:8px;
}
.sv-desc{font-size:14px;line-height:1.6;color:var(--txt2);margin-bottom:18px}
.sv-card.feat .sv-desc{color:rgba(255,255,255,.78)}
.sv-feats{display:flex;flex-direction:column;gap:9px;margin-bottom:22px;flex:1}
.sv-feat{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--txt2);line-height:1.5}
.sv-card.feat .sv-feat{color:rgba(255,255,255,.82)}
.sv-check{
  width:18px;height:18px;
  border-radius:50%;
  background:var(--tq-l);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  margin-top:1px;
}
.sv-card.feat .sv-check{background:rgba(18,199,217,.18)}
.sv-check svg{width:10px;height:10px;stroke:var(--tq-d);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}
.sv-card.feat .sv-check svg{stroke:var(--tq)}
.sv-price{font-size:28px;font-weight:900;color:var(--az);letter-spacing:-.8px;line-height:1}
.sv-card.feat .sv-price{color:var(--tq)}
.sv-price-note{font-size:11.5px;color:var(--txt3);margin-top:6px;margin-bottom:18px}
.sv-card.feat .sv-price-note{color:rgba(255,255,255,.55)}
.sv-btn{
  width:100%;
  padding:13px 16px;
  border-radius:var(--rpill);
  font-size:13px;
  font-weight:800;
  letter-spacing:.3px;
  transition:transform .15s ease, background .15s ease;
}
.sv-btn-dk{background:var(--az);color:#fff}
.sv-btn-dk:hover{background:var(--az-d);transform:translateY(-1px)}
.sv-btn-tq{background:var(--tq);color:var(--az)}
.sv-btn-tq:hover{background:#0fb8c9;transform:translateY(-1px)}

/* ---------- PRECIOS ---------- */
.precios-tabs{
  display:inline-flex;
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--rpill);
  padding:4px;
  margin-bottom:32px;
  flex-wrap:wrap;
  gap:2px;
}
.ptab{
  padding:10px 20px;
  font-size:13px;
  font-weight:700;
  color:var(--txt3);
  border-radius:var(--rpill);
  transition:all .15s ease;
}
.ptab:hover{color:var(--az)}
.ptab.active{background:var(--az);color:#fff}
.ptab-content{display:none}
.ptab-content.active{display:block;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.pc-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.pc-card{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  padding:24px 22px 22px;
  display:flex;
  flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.pc-card:hover{transform:translateY(-3px);box-shadow:var(--sh2)}
.pc-card.hl{
  border:2px solid var(--tq);
  background:linear-gradient(180deg, var(--tq-l) 0%, #fff 60%);
  box-shadow:var(--sh2);
}
.pc-head{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--gr-b)}
.pc-cat{
  font-size:10.5px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.2px;
  color:var(--tq-d);
  margin-bottom:8px;
}
.pc-name{
  font-size:18px;
  font-weight:800;
  letter-spacing:-.3px;
  color:var(--txt);
  line-height:1.2;
}
.pc-body{flex:1;display:flex;flex-direction:column}
.pc-price{
  font-size:36px;
  font-weight:900;
  color:var(--az);
  letter-spacing:-1.4px;
  line-height:1;
  margin-bottom:6px;
}
.pc-note{font-size:12px;color:var(--txt3);margin-bottom:18px}
.pc-list{display:flex;flex-direction:column;gap:8px;margin-bottom:22px;flex:1}
.pc-item{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--txt2);line-height:1.45}
.pc-dot{
  width:6px;height:6px;
  border-radius:50%;
  background:var(--tq);
  flex-shrink:0;
  margin-top:7px;
}
.pc-foot{margin-top:auto}
.pc-btn{
  width:100%;
  padding:11px 16px;
  border-radius:var(--rpill);
  font-size:12.5px;
  font-weight:800;
  letter-spacing:.3px;
  transition:all .15s ease;
}
.pc-btn-main{background:var(--az);color:#fff}
.pc-btn-main:hover{background:var(--az-d)}
.pc-btn-out{background:transparent;color:var(--az);border:1px solid var(--gr-b)}
.pc-btn-out:hover{background:var(--gr-l);border-color:var(--az)}
.pc-extra{
  margin-top:22px;
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  padding:20px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

/* ---------- PATOLOGÍAS ---------- */
.pat-intro{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  margin-bottom:54px;
  align-items:end;
}
.pat-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.pat-item{
  background:var(--gr-l);
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  padding:30px 26px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  position:relative;
}
.pat-item:hover{
  background:#fff;
  border-color:var(--tq);
  transform:translateY(-3px);
  box-shadow:var(--sh2);
}
.pat-n{
  font-size:12px;
  font-weight:800;
  color:var(--tq-d);
  letter-spacing:1.5px;
  margin-bottom:10px;
}
.pat-t{
  font-size:19px;
  font-weight:800;
  letter-spacing:-.3px;
  color:var(--txt);
  margin-bottom:8px;
}
.pat-d{font-size:13.5px;line-height:1.6;color:var(--txt2);margin-bottom:14px}
.pat-lnk{
  font-size:12px;
  font-weight:700;
  color:var(--az);
  text-transform:uppercase;
  letter-spacing:.6px;
  transition:color .15s ease;
}
.pat-lnk:hover{color:var(--tq-d)}

/* ---------- PROCESO ---------- */
.proceso-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin:42px 0 32px;
}
.paso{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  padding:24px 22px;
  position:relative;
  transition:all .2s ease;
}
.paso:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.paso.active{
  background:var(--az);
  color:#fff;
  border-color:var(--az);
  box-shadow:var(--sh2);
}
.paso-n{
  font-size:34px;
  font-weight:900;
  color:var(--tq);
  letter-spacing:-1.2px;
  line-height:1;
  margin-bottom:14px;
}
.paso-t{
  font-size:17px;
  font-weight:800;
  letter-spacing:-.3px;
  color:var(--txt);
  margin-bottom:8px;
}
.paso.active .paso-t{color:#fff}
.paso-d{font-size:13px;color:var(--txt2);line-height:1.55;margin-bottom:14px}
.paso.active .paso-d{color:rgba(255,255,255,.78)}
.paso-tag{
  display:inline-block;
  font-size:10.5px;
  font-weight:700;
  background:var(--gr-l);
  color:var(--txt3);
  padding:4px 10px;
  border-radius:var(--rpill);
  letter-spacing:.4px;
}
.paso.active .paso-tag{background:rgba(255,255,255,.12);color:var(--tq)}
.proceso-img{
  height:340px;
  border-radius:var(--r20);
  overflow:hidden;
}
.proceso-img img{width:100%;height:100%;object-fit:cover}

/* ---------- SOBRE MÍ ---------- */
.sm-grid{
  display:grid;
  grid-template-columns:1fr 1.25fr;
  gap:64px;
  align-items:center;
}
.sm-img-wrap{position:relative}
.sm-img{
  border-radius:var(--r20);
  overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:var(--sh3);
}
.sm-img img{width:100%;height:100%;object-fit:cover}
.sm-badge{
  position:absolute;
  bottom:-14px;
  left:50%;
  transform:translateX(-50%);
  background:var(--tq);
  color:var(--az);
  font-size:11px;
  font-weight:800;
  padding:9px 18px;
  border-radius:var(--rpill);
  white-space:nowrap;
  letter-spacing:.3px;
  box-shadow:var(--sh2);
}
.sm-eyebrow{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--tq);
  margin-bottom:16px;
}
.sm-h2{
  font-size:clamp(34px,4.2vw,52px);
  font-weight:900;
  letter-spacing:-1.4px;
  line-height:1.05;
  color:#fff;
  margin-bottom:20px;
}
.sm-h2 em{color:var(--tq);font-style:italic}
.sm-lead{font-size:15px;line-height:1.7;color:rgba(255,255,255,.78);margin-bottom:24px;max-width:580px}
.creds{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}
.cred{display:flex;align-items:flex-start;gap:11px}
.cred-dot{
  width:7px;height:7px;
  border-radius:50%;
  background:var(--tq);
  flex-shrink:0;
  margin-top:7px;
}
.cred p{font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.8);margin:0}
.sm-quote{
  background:rgba(255,255,255,.06);
  border-left:3px solid var(--tq);
  padding:18px 22px;
  border-radius:0 var(--r12) var(--r12) 0;
  margin-bottom:26px;
}
.sm-quote p{font-size:15px;font-style:italic;line-height:1.6;color:#fff;margin:0 0 10px 0}
.sm-quote cite{font-size:11.5px;color:var(--tq);font-style:normal;font-weight:700;letter-spacing:.3px}

/* ---------- TESTIMONIOS ---------- */
.test-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:40px;
  flex-wrap:wrap;
  gap:20px;
}
.test-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.t-card{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  padding:24px;
  transition:all .2s ease;
  position:relative;
}
.t-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.t-card.feat{
  border:2px solid var(--tq);
  background:linear-gradient(180deg, var(--tq-l) 0%, #fff 30%);
}
.t-result{
  display:inline-block;
  font-size:10.5px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.7px;
  color:var(--tq-d);
  background:var(--tq-l);
  padding:5px 11px;
  border-radius:var(--rpill);
  margin-bottom:14px;
}
.t-stars{display:flex;gap:1px;color:var(--warn);font-size:14px;margin-bottom:14px}
.t-txt{font-size:14px;line-height:1.6;color:var(--txt2);margin-bottom:18px}
.t-author{display:flex;align-items:center;gap:11px}
.t-av{
  width:38px;height:38px;
  border-radius:50%;
  background:var(--az);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;
  flex-shrink:0;
}
.t-name{font-size:13.5px;font-weight:800;color:var(--txt);margin-bottom:1px}
.t-cond{font-size:11px;color:var(--txt3)}

/* ---------- CTA BAND ---------- */
.cta-band{
  position:relative;
  background:var(--az);
  color:#fff;
  padding:100px 28px;
  overflow:hidden;
}
.cta-bg{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(18,199,217,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(18,199,217,.06) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%, #000 0%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%, #000 0%, transparent 80%);
  pointer-events:none;
}
.cta-inner{
  max-width:780px;
  margin:0 auto;
  text-align:center;
  position:relative;
}
.cta-eyebrow{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--tq);
  padding:6px 14px;
  background:rgba(18,199,217,.1);
  border-radius:var(--rpill);
  margin-bottom:20px;
}
.cta-h2{
  font-size:clamp(38px,5vw,64px);
  font-weight:900;
  letter-spacing:-1.8px;
  line-height:1.05;
  color:#fff;
  margin-bottom:18px;
  text-wrap:balance;
}
.cta-h2 em{color:var(--tq);font-style:italic;font-weight:700}
.cta-p{font-size:16px;line-height:1.65;color:rgba(255,255,255,.78);margin-bottom:32px;max-width:620px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.cta-note{font-size:12px;color:rgba(255,255,255,.5)}

/* ---------- SEO LOCAL ---------- */
.seo-wrap{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:54px;
  align-items:start;
}
.seo-info h3{font-size:28px;font-weight:900;letter-spacing:-.8px;color:var(--txt);margin-bottom:14px;line-height:1.15}
.seo-info p{font-size:14.5px;line-height:1.7;color:var(--txt2);margin-bottom:14px}
.seo-info strong{color:var(--az)}
.seo-dato{
  display:flex;
  align-items:center;
  gap:11px;
  padding:11px 0;
  border-bottom:1px solid var(--gr-b);
}
.seo-dato-lbl{font-size:13.5px;color:var(--txt2);font-weight:500}
.google-mock{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  overflow:hidden;
  box-shadow:var(--sh1);
}
.gm-bar{
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 16px;
  background:var(--gr-l);
  border-bottom:1px solid var(--gr-b);
}
.gm-dots{display:flex;gap:6px}
.gm-dot{width:10px;height:10px;border-radius:50%}
.gm-r{background:#ff5f57}
.gm-y{background:#febc2e}
.gm-g{background:#28c840}
.gm-url{font-size:11.5px;color:var(--txt3);font-family:'SF Mono',Menlo,monospace}
.gm-body{padding:20px}
.gm-result{padding:14px 0;border-bottom:1px solid var(--gr);position:relative}
.gm-result:last-child{border-bottom:none}
.gm-domain{font-size:11.5px;color:var(--txt3);margin-bottom:3px}
.gm-title{font-size:16px;font-weight:600;color:#1a0dab;margin-bottom:4px;letter-spacing:-.2px}
.gm-desc{font-size:12.5px;line-height:1.5;color:var(--txt2)}
.gm-badge{
  display:inline-block;
  margin-top:8px;
  font-size:10px;
  font-weight:700;
  color:var(--tq-d);
  background:var(--tq-l);
  padding:3px 9px;
  border-radius:var(--rpill);
  letter-spacing:.4px;
  text-transform:uppercase;
}

/* ---------- CUESTIONARIO PREVIO ---------- */
.qf-wrap{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:56px;
  align-items:start;
}
.qf-side{position:sticky;top:90px;align-self:start}
.qf-bullets{display:flex;flex-direction:column;gap:14px;margin:24px 0 28px}
.qf-bullets li{display:flex;gap:12px;font-size:14px;color:var(--txt2);line-height:1.55}
.qf-bullets strong{color:var(--txt)}
.qf-b-dot{
  width:8px;height:8px;border-radius:50%;background:var(--tq);
  flex-shrink:0;margin-top:7px;
}
.qf-help{
  border-top:1px solid var(--gr-b);
  padding-top:22px;
  display:flex;align-items:center;gap:16px;
  flex-wrap:wrap;
}
.qf-help p{font-size:13px;color:var(--txt3);margin:0}

.qf-form{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r20);
  overflow:hidden;
  box-shadow:var(--sh2);
}
.qf-head{
  background:linear-gradient(120deg, var(--az), var(--az-d));
  color:#fff;
  padding:22px 28px 18px;
}
.qf-brand{font-size:13px;font-weight:800;letter-spacing:.6px;color:#fff}
.qf-brand span{color:var(--tq)}
.qf-progress{
  height:5px;background:rgba(255,255,255,.16);border-radius:5px;
  margin-top:14px;overflow:hidden;
}
.qf-progress i{display:block;height:100%;width:20%;background:var(--tq);transition:width .35s ease;border-radius:5px}
.qf-step-of{font-size:11px;color:rgba(255,255,255,.6);margin-top:8px;letter-spacing:.4px;font-weight:600}

.qf-content{padding:26px 28px 28px}
.qf-step{display:none;animation:qfFade .3s ease}
.qf-step.active{display:block}
@keyframes qfFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.qf-seclabel{
  font-size:11px;text-transform:uppercase;letter-spacing:1.2px;
  color:var(--tq-d);font-weight:800;margin-bottom:18px;
}
.qf-q{margin-bottom:20px}
.qf-qt{display:block;font-weight:700;font-size:14px;margin-bottom:9px;color:var(--txt)}
.qf-req{color:#dc4b4b}
.qf-why{font-size:12px;color:var(--txt3);margin-top:6px;line-height:1.5}

.qf-form input[type=text],
.qf-form input[type=tel],
.qf-form input[type=email],
.qf-form input[type=number],
.qf-form textarea,
.qf-form select{
  width:100%;
  border:1.5px solid var(--gr-b);
  border-radius:10px;
  padding:11px 13px;
  font-size:14.5px;
  font-family:inherit;
  color:var(--txt);
  background:#fff;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.qf-form input:focus,
.qf-form textarea:focus,
.qf-form select:focus{
  outline:none;
  border-color:var(--tq);
  box-shadow:0 0 0 3px rgba(18,199,217,.12);
}
.qf-form textarea{min-height:80px;resize:vertical}
.qf-form input[aria-invalid="true"],
.qf-form textarea[aria-invalid="true"]{border-color:#dc4b4b}

.qf-opt{
  display:flex;align-items:center;
  border:1.5px solid var(--gr-b);
  border-radius:10px;
  padding:11px 13px;
  margin-bottom:8px;
  cursor:pointer;
  font-size:13.5px;
  color:var(--txt);
  transition:border-color .15s ease, background .15s ease;
}
.qf-opt:hover{border-color:var(--tq);background:var(--tq-l)}
.qf-opt input{margin-right:11px;accent-color:var(--tq-d);width:17px;height:17px;flex-shrink:0}
.qf-opt.qf-sel{border-color:var(--tq);background:var(--tq-l);font-weight:600}

.qf-scale{display:flex;gap:5px;flex-wrap:wrap}
.qf-scale button{
  flex:1;min-width:34px;
  border:1.5px solid var(--gr-b);background:#fff;
  border-radius:9px;padding:9px 0;
  font-size:13.5px;font-weight:700;
  color:var(--txt);cursor:pointer;font-family:inherit;
  transition:all .12s ease;
}
.qf-scale button:hover{border-color:var(--tq)}
.qf-scale button.qf-sel{background:var(--tq);border-color:var(--tq);color:var(--az)}
.qf-scale-ends{display:flex;justify-content:space-between;font-size:11px;color:var(--txt3);margin-top:6px}

.qf-flag{
  background:#fff5f3;border:1px solid #f4cdc6;border-radius:10px;
  padding:11px 13px;font-size:12.5px;color:#9a3326;margin-top:6px;line-height:1.5;
}

.qf-consent{margin-top:6px;margin-bottom:8px}
.qf-consent .qf-opt{font-size:12.5px;color:var(--txt2);line-height:1.5;align-items:flex-start}
.qf-consent .qf-opt input{margin-top:2px}

.qf-nav{display:flex;gap:10px;margin-top:24px}
.qf-btn{
  flex:1;
  padding:13px 18px;
  border-radius:10px;
  font-size:14px;font-weight:800;
  cursor:pointer;border:none;
  font-family:inherit;letter-spacing:.2px;
  transition:transform .12s ease, background .15s ease, color .15s ease;
}
.qf-btn-next,.qf-btn-send{background:var(--tq);color:var(--az)}
.qf-btn-next:hover,.qf-btn-send:hover{background:#0fb8c9;transform:translateY(-1px)}
.qf-btn-back{
  flex:0 0 100px;
  background:#fff;color:var(--txt2);
  border:1.5px solid var(--gr-b);
}
.qf-btn-back:hover{border-color:var(--az);color:var(--az)}
.qf-btn-send:disabled{opacity:.6;cursor:wait;transform:none}

.qf-status{
  margin-top:14px;
  padding:10px 13px;
  border-radius:10px;
  font-size:12.5px;
  display:none;
  line-height:1.5;
}
.qf-status.err{display:block;background:#fff5f3;border:1px solid #f4cdc6;color:#9a3326}
.qf-status.warn{display:block;background:#fff8e6;border:1px solid #f3dca6;color:#8a6a16}

.qf-done{text-align:center;padding:22px 6px 6px}
.qf-done-ico{
  width:64px;height:64px;border-radius:50%;
  background:var(--tq);color:var(--az);
  font-size:32px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
}
.qf-done h3{font-size:22px;font-weight:900;letter-spacing:-.5px;color:var(--txt);margin-bottom:10px}
.qf-done p{font-size:14px;color:var(--txt2);line-height:1.6;max-width:380px;margin:0 auto}
.qf-done-resumen{
  margin-top:20px;background:var(--gr-l);border:1px solid var(--gr-b);
  border-radius:10px;padding:14px 16px;font-size:12.5px;color:var(--txt2);
  text-align:left;line-height:1.65;
}
.qf-done-resumen b{color:var(--az)}

@media (max-width: 1080px){
  .qf-wrap{grid-template-columns:1fr;gap:36px}
  .qf-side{position:static}
}
@media (max-width: 680px){
  .qf-head{padding:18px 20px 16px}
  .qf-content{padding:22px 20px}
  .qf-btn-back{flex:0 0 84px;font-size:13px}
}

/* ---------- BLOG ---------- */
.blog-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:20px;
  margin-top:42px;
}
.blog-grid-4{grid-template-columns:repeat(4, 1fr)}
.bl-card{
  background:#fff;
  border:1px solid var(--gr-b);
  border-radius:var(--r12);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
  display:flex;
  flex-direction:column;
}
.bl-card:hover{transform:translateY(-3px);box-shadow:var(--sh2)}
.bl-img{
  background:linear-gradient(135deg, var(--az) 0%, var(--az-d) 100%);
  position:relative;
  display:flex;
  align-items:flex-end;
  padding:24px;
  overflow:hidden;
}
.bl-img::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 18px, rgba(18,199,217,.05) 18px 19px);
  pointer-events:none;
}
.bl-img-lg{height:300px}
.bl-img-sm{height:200px}
.bl-hook{
  position:relative;
  font-size:16px;
  font-weight:800;
  color:var(--tq);
  letter-spacing:-.3px;
  line-height:1.3;
}
.bl-img-lg .bl-hook{font-size:22px}
.bl-body{padding:20px 22px 22px}
.bl-cat{
  font-size:10.5px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.2px;
  color:var(--tq-d);
  margin-bottom:8px;
}
.bl-title{font-size:16px;font-weight:800;letter-spacing:-.3px;color:var(--txt);line-height:1.3;margin-bottom:10px}
.bl-card.small .bl-title{font-size:14px}
.bl-excerpt{font-size:13px;color:var(--txt3);line-height:1.55;margin-bottom:12px}
.bl-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--txt3);font-weight:600}
.bl-dot{width:3px;height:3px;border-radius:50%;background:var(--txt3)}

/* ---------- FOOTER ---------- */
footer{
  background:var(--az-d);
  color:rgba(255,255,255,.7);
  padding:72px 28px 28px;
}
.ft-top{
  max-width:var(--maxw);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:42px;
  padding-bottom:42px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.ft-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.ft-logo img{width:38px;height:38px;border-radius:8px;background:var(--tq);object-fit:cover}
.ft-logo-txt{font-size:17px;font-weight:900;color:#fff;letter-spacing:-.3px}
.ft-logo-txt span{color:var(--tq)}
.ft-desc{font-size:13px;line-height:1.65;color:rgba(255,255,255,.55);margin-bottom:22px;max-width:340px}
.ft-contact{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.ft-ci{font-size:12.5px;color:rgba(255,255,255,.65)}
.ft-ci a{color:#fff;font-weight:600}
.ft-ci a:hover{color:var(--tq)}
.ft-rrss{display:flex;gap:10px}
.ft-rr{
  width:36px;height:36px;
  border-radius:50%;
  background:rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  transition:background .15s ease;
}
.ft-rr:hover{background:var(--tq)}
.ft-rr svg{width:16px;height:16px;stroke:#fff;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ft-col h4{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color:#fff;
  margin-bottom:14px;
}
.ft-col ul{display:flex;flex-direction:column;gap:8px}
.ft-col a{font-size:13px;color:rgba(255,255,255,.6);transition:color .15s ease}
.ft-col a:hover{color:var(--tq)}
.ft-bottom{
  max-width:var(--maxw);
  margin:0 auto;
  padding-top:28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
}
.ft-bottom p{font-size:11.5px;color:rgba(255,255,255,.4)}
.ft-badge{
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.6px;
  text-transform:uppercase;
  color:var(--tq);
  background:rgba(18,199,217,.1);
  padding:5px 12px;
  border-radius:var(--rpill);
}

/* ---------- WHATSAPP FLOAT ---------- */
.wa-float{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:90;
  width:58px;height:58px;
  border-radius:50%;
  background:var(--wa);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.45);
  transition:transform .2s ease, box-shadow .2s ease;
  animation:pulse 2.6s infinite;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 12px 36px rgba(37,211,102,.55)}
.wa-float svg{width:30px;height:30px;fill:#fff}
@keyframes pulse{
  0%,100%{box-shadow:0 8px 28px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,.5)}
  50%{box-shadow:0 8px 28px rgba(37,211,102,.45), 0 0 0 14px rgba(37,211,102,0)}
}

/* ---------- DIFERENCIADORES: foto auxiliar ---------- */
.diff-sticky .h2{font-size:clamp(32px,3.8vw,46px);margin-bottom:14px}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1080px){
  .nav-links{display:none}
  .hero{grid-template-columns:1fr;gap:42px;padding:40px 24px 64px}
  .hero-card{position:relative;left:0;bottom:0;width:auto;margin-top:18px}
  .diff-wrap{grid-template-columns:1fr;gap:32px}
  .diff-sticky{position:static}
  .diff-grid{grid-template-columns:1fr 1fr}
  .sv-grid{grid-template-columns:1fr;gap:18px}
  .pc-grid{grid-template-columns:1fr 1fr !important}
  .pat-intro{grid-template-columns:1fr;gap:28px}
  .pat-grid{grid-template-columns:1fr 1fr}
  .proceso-steps{grid-template-columns:1fr 1fr}
  .sm-grid{grid-template-columns:1fr;gap:48px}
  .test-grid,
  .test-header + .test-grid{grid-template-columns:1fr 1fr}
  .seo-wrap{grid-template-columns:1fr;gap:32px}
  .blog-grid{grid-template-columns:1fr 1fr}
  .blog-grid-4{grid-template-columns:1fr 1fr !important}
  .ft-top{grid-template-columns:1fr 1fr;gap:32px}
  .trust-i{justify-content:flex-start}
  .trust-sep{display:none}
}
@media (max-width: 680px){
  .sec{padding:64px 20px}
  .hero{padding:30px 20px 48px}
  .hero-stats{grid-template-columns:1fr;gap:16px}
  .hero-btns .btn{flex:1;justify-content:center}
  .nav-i{padding:12px 20px}
  .nav-i > div:last-child{gap:10px}
  .nav-phone{display:none}
  .announce{font-size:11px;padding:8px 14px}
  .diff-grid{grid-template-columns:1fr}
  .pc-grid{grid-template-columns:1fr !important}
  .pat-grid{grid-template-columns:1fr}
  .proceso-steps{grid-template-columns:1fr}
  .test-grid,
  .test-header + .test-grid,
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr !important}
  div[style*="grid-template-columns:1fr 1fr 1fr"],
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr 1fr !important}
  .blog-grid{grid-template-columns:1fr}
  .blog-grid-4{grid-template-columns:1fr !important}
  .ft-top{grid-template-columns:1fr 1fr;gap:24px}
  .cta-h2{font-size:36px}
  .precios-tabs{width:100%;justify-content:center}
}

/* ---------- PLACEHOLDER images ---------- */
img[data-ph]{
  background:linear-gradient(135deg, var(--az-l) 0%, var(--tq-l) 100%);
  object-fit:cover;
}
