/* ─── VARIABLES ─── */
:root {
  --naranja: #faa434;
  --rojo: #ea1a20;
  --gris: #5c5c5c;
  --gris-claro: #f7f7f7;
  --gris-linea: #e8e8e8;
  --gris-medio: #aaa;
  --blanco: #ffffff;
  --negro: #383838;
  --grad: linear-gradient(120deg, #faa434 0%, #ea1a20 100%);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Roboto',sans-serif; background:#fff; color:var(--negro); overflow-x:hidden; line-height:1.6; }

/* ─── CABECERA STICKY ─── */
.site-header {
  position: sticky; top:0; z-index:100;
  box-shadow: 0 2px 20px rgba(250,164,52,0.15);
}

/* ─── TOPBAR ─── */
.topbar {
  background: var(--grad);
  padding: 11px 40px;
  display: flex; align-items:center; justify-content:center; gap:32px;
}
.topbar p { font-size:13px; font-weight:500; color:#fff; }
.topbar strong { font-weight:700; }
.topbar-pill {
  background:rgba(255,255,255,0.18); border:1px solid rgba(255,255,255,0.45);
  color:#fff; font-size:11px; font-weight:700; letter-spacing:0.08em;
  padding:5px 14px; border-radius:100px; text-decoration:none; white-space:nowrap;
  transition:background 0.2s;
}
.topbar-pill:hover { background:rgba(255,255,255,0.32); }
/* en desktop el wrapper es transparente — solo agrupa para mobile */
.topbar-bottom { display:contents; }
.countdown { display:flex; align-items:center; gap:4px; }
.cd-block { display:flex; flex-direction:column; align-items:center; min-width:36px; }
.cd-num { font-size:18px; font-weight:900; color:#fff; line-height:1; font-variant-numeric:tabular-nums; }
.cd-lbl { font-size:8px; color:rgba(255,255,255,0.6); letter-spacing:0.1em; text-transform:uppercase; margin-top:1px; }
.cd-sep { font-size:16px; font-weight:700; color:rgba(255,255,255,0.5); margin-bottom:8px; }

/* ─── NAV ─── */
nav {
  background:#fff; border-bottom:1px solid var(--gris-linea);
  padding:14px 60px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { height:28px; display:block; }
.nav-right { display:flex; align-items:center; gap:24px; }
.nav-autor { font-size:13px; color:var(--gris); }
.nav-autor strong { color:var(--negro); font-weight:700; }
.btn-nav {
  background:var(--grad); color:#fff;
  font-size:13px; font-weight:700; padding:9px 22px;
  border-radius:4px; text-decoration:none;
  box-shadow:0 4px 14px rgba(250,164,52,0.25);
  transition:all 0.2s; letter-spacing:0.02em;
}
.btn-nav:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(250,164,52,0.35); }

/* ─── HERO ─── */
.hero {
  display:grid; grid-template-columns:1fr 400px;
  gap:72px; align-items:start;
  padding:80px 60px 80px; max-width:1180px; margin:0 auto;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:#fff8f0; border:1px solid #fde8c0;
  border-radius:100px; padding:6px 16px;
  font-size:11px; font-weight:700; color:var(--naranja);
  letter-spacing:0.1em; text-transform:uppercase;
  margin-bottom:28px;
}
.badge-dot {
  width:7px; height:7px; border-radius:50%; background:var(--naranja);
  animation:blink 2s infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.25} }

.hero h1 {
  font-size:clamp(38px,4.5vw,62px); font-weight:900;
  line-height:1.07; letter-spacing:-0.025em;
  color:var(--negro); margin-bottom:10px;
}
.hero h1 .accent {
  background:var(--grad); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-tagline {
  font-size:20px; font-weight:300; color:var(--gris);
  margin-bottom:32px; line-height:1.5;
}
.hero-copy {
  font-size:17px; line-height:1.85; color:#333;
  margin-bottom:36px; font-weight:400;
}
.hero-copy strong { font-weight:700; color:var(--negro); }

.hero-checks {
  display:flex; flex-direction:column; gap:10px; margin-bottom:40px;
}
.hcheck {
  display:flex; align-items:center; gap:12px;
  font-size:14px; color:var(--gris); font-weight:400;
}
.hcheck-icon { flex-shrink:0; }

.hero-btns { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.btn-main {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--grad); color:#fff;
  font-size:16px; font-weight:700; padding:17px 36px;
  border-radius:6px; text-decoration:none;
  box-shadow:0 6px 24px rgba(250,164,52,0.35);
  transition:all 0.25s; letter-spacing:0.02em;
}
.btn-main:hover { transform:translateY(-2px); box-shadow:0 10px 32px rgba(250,164,52,0.45); }
.btn-main--lg { font-size:16px; padding:18px 40px; }
.btn-ghost {
  font-size:14px; color:var(--gris); font-weight:400;
  text-decoration:underline; text-underline-offset:4px;
  cursor:pointer;
}

/* ─── HERO CARD ─── */
.hero-card {
  background:#3a3a3a; border-radius:14px;
  overflow:hidden; box-shadow:0 28px 72px rgba(0,0,0,0.14);
  position:sticky; top:120px;
}
.hcard-top { background:var(--grad); padding:28px 28px 22px; }
.hcard-pretitle { font-size:10px; font-weight:700; color:rgba(255,255,255,0.65); letter-spacing:0.18em; text-transform:uppercase; margin-bottom:6px; }
.hcard-title { font-size:26px; font-weight:900; color:#fff; letter-spacing:-0.01em; margin-bottom:4px; }
.hcard-sub { font-size:13px; color:rgba(255,255,255,0.72); font-weight:300; }

.hcard-body { padding:28px; }

.precio-bloque { margin-bottom:8px; }
.precio-valorado {
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--gris-medio); margin-bottom:4px;
}
.precio-tachado {
  font-size:22px; font-weight:300; color:var(--gris-medio);
  text-decoration:line-through; text-decoration-color:var(--naranja);
}
.precio-actual {
  display:flex; align-items:flex-end; gap:6px;
}
.precio-euro { font-size:24px; font-weight:300; color:#fff; line-height:1.6; }
.precio-num { font-size:56px; font-weight:900; color:#fff; line-height:1; }
.precio-desc { font-size:11px; color:var(--gris-medio); margin-bottom:16px; font-weight:300; }

.ahorro-tag {
  display:inline-block;
  background:rgba(250,164,52,0.12); border:1px solid rgba(250,164,52,0.35);
  color:var(--naranja); font-size:12px; font-weight:700;
  padding:4px 12px; border-radius:4px; margin-bottom:20px;
  letter-spacing:0.03em;
}

.plazas-wrap { margin-bottom:24px; }
.plazas-meta { display:flex; justify-content:space-between; margin-bottom:8px; }
.plazas-meta span { font-size:12px; color:var(--gris-medio); font-weight:300; }
.plazas-meta strong { font-size:12px; color:var(--naranja); font-weight:700; }
.plazas-bar { background:rgba(255,255,255,0.08); border-radius:100px; height:4px; overflow:hidden; }
.plazas-fill {
  height:100%; width:0; background:var(--grad); border-radius:100px;
  transition:width 1.2s cubic-bezier(0.4,0,0.2,1) 0.2s;
}
.plazas-fill.bar-animated { width:70%; }

.hcard-includes {
  list-style:none; border-top:1px solid rgba(255,255,255,0.07);
  padding-top:20px; margin-bottom:24px; display:flex; flex-direction:column; gap:10px;
}
.hcard-includes li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:rgba(255,255,255,0.7); font-weight:300; line-height:1.4;
}
.check-svg { flex-shrink:0; margin-top:1px; }

.btn-reserva {
  display:block; width:100%; text-align:center;
  background:var(--grad); color:#fff;
  font-size:15px; font-weight:700; padding:15px;
  border-radius:6px; text-decoration:none;
  box-shadow:0 4px 20px rgba(234,26,32,0.3);
  transition:all 0.2s; margin-bottom:10px; letter-spacing:0.02em;
}
.btn-reserva:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(234,26,32,0.45); }
.btn-incompany {
  display:block; width:100%; text-align:center;
  background:transparent; border:1px solid rgba(255,255,255,0.15);
  color:rgba(255,255,255,0.55); font-size:13px; font-weight:400;
  padding:12px; border-radius:6px; text-decoration:none;
  transition:all 0.2s;
}
.btn-incompany:hover { border-color:rgba(255,255,255,0.4); color:#fff; }

/* ─── SECCIÓN GENÉRICA ─── */
.seccion { padding:100px 60px; }
.seccion-sm { padding:72px 60px; }
.max { max-width:1060px; margin:0 auto; }

.sec-label {
  font-size:11px; font-weight:700; color:var(--naranja);
  letter-spacing:0.18em; text-transform:uppercase;
  display:flex; align-items:center; gap:10px; margin-bottom:16px;
}
.sec-label::before { content:''; display:block; width:28px; height:2px; background:var(--naranja); }

.sec-h2 {
  font-size:clamp(28px,3.5vw,46px); font-weight:900;
  line-height:1.1; letter-spacing:-0.02em;
  color:var(--negro); margin-bottom:18px;
}
.sec-h2 em { font-style:italic; color:var(--naranja); font-weight:900; }
.sec-lead { font-size:17px; color:var(--gris); font-weight:300; line-height:1.7; max-width:680px; }

/* ─── SECCIÓN DOLOR ─── */
.dolor { background:var(--blanco); }
.dolor-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; margin-top:60px; align-items:start; }

.pain-list { display:flex; flex-direction:column; gap:0; }
.pain-item {
  display:flex; gap:20px; align-items:flex-start;
  padding:28px 0; border-bottom:1px solid var(--gris-linea);
  opacity:0; transform:translateY(16px); transition:all 0.55s;
}
.pain-item.vis { opacity:1; transform:translateY(0); }
.pain-picto {
  width:44px; height:44px; flex-shrink:0;
  background:var(--gris-claro); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
}
.pain-text strong { display:block; font-size:15px; font-weight:700; color:var(--negro); margin-bottom:5px; line-height:1.3; }
.pain-text p { font-size:14px; color:var(--gris); line-height:1.65; font-weight:300; }

.dolor-right { display:flex; flex-direction:column; gap:20px; position:sticky; top:140px; }

.cita-bloque {
  background:#3a3a3a; border-radius:12px; padding:40px;
  position:relative; overflow:hidden;
}
.cita-bloque::before {
  content:'"'; font-family:'Georgia',serif; font-size:160px;
  color:rgba(255,255,255,0.04); position:absolute;
  top:-20px; left:16px; line-height:1; pointer-events:none;
}
.cita-text {
  font-size:19px; font-style:italic; font-weight:300;
  color:rgba(255,255,255,0.88); line-height:1.6; margin-bottom:20px;
  position:relative; z-index:1;
}
.cita-text strong { font-style:normal; font-weight:700; color:#fff; }
.cita-autor { font-size:12px; color:rgba(255,255,255,0.35); font-weight:300; position:relative; z-index:1; }

.metricas { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.metrica {
  background:var(--gris-claro); border-radius:8px;
  padding:20px 16px; text-align:center;
}
.metrica-val { font-size:30px; font-weight:900; color:var(--naranja); line-height:1; margin-bottom:6px; }
.metrica-label { font-size:12px; color:var(--gris); line-height:1.4; font-weight:300; }

/* ─── MÓDULOS ─── */
.modulos-sec { background:var(--gris-claro); }
.modulos-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:2px; margin-top:56px;
  background:var(--gris-linea); border-radius:12px; overflow:hidden;
}
.modulo {
  background:#fff; padding:36px 28px;
  transition:all 0.3s; cursor:default; position:relative;
}
.modulo:hover { background:#3a3a3a; }
.mod-num { font-size:10px; font-weight:700; color:var(--naranja); letter-spacing:0.18em; margin-bottom:16px; display:block; }
.mod-picto { margin-bottom:16px; display:block; }
.mod-title { font-size:18px; font-weight:700; color:var(--negro); margin-bottom:10px; line-height:1.25; transition:color 0.3s; }
.modulo:hover .mod-title { color:#fff; }
.mod-desc { font-size:13px; color:var(--gris); line-height:1.65; font-weight:300; transition:color 0.3s; }
.modulo:hover .mod-desc { color:rgba(255,255,255,0.55); }
.mod-tags { display:flex; flex-wrap:wrap; gap:5px; margin-top:14px; }
.mod-tag {
  font-size:10px; font-weight:500; letter-spacing:0.05em;
  background:var(--gris-claro); color:var(--gris);
  padding:3px 9px; border-radius:100px;
  transition:all 0.3s;
}
.modulo:hover .mod-tag { background:rgba(255,255,255,0.08); color:rgba(255,255,255,0.5); }

/* ─── ESTRUCTURA + PRECIO ─── */
.estructura-sec { background:#fff; }
.estructura-wrap { display:grid; grid-template-columns:1fr 380px; gap:72px; margin-top:60px; align-items:start; }

.sesiones { display:flex; flex-direction:column; }
.sesion {
  display:flex; gap:24px; padding:28px 0;
  border-bottom:1px solid var(--gris-linea);
  opacity:0; transform:translateX(-16px); transition:all 0.5s;
}
.sesion.vis { opacity:1; transform:translateX(0); }
.sesion-num {
  font-size:10px; font-weight:700; color:var(--naranja);
  letter-spacing:0.12em; flex-shrink:0; width:48px; padding-top:2px;
}
.sesion-info strong { display:block; font-size:15px; font-weight:700; color:var(--negro); margin-bottom:5px; }
.sesion-fecha { font-size:12px; color:var(--gris-medio); font-weight:300; margin-bottom:8px; }
.sesion-info p { font-size:13px; color:var(--gris); line-height:1.65; font-weight:300; }
.sesion-chips { display:flex; flex-wrap:wrap; gap:5px; margin-top:10px; }
.chip {
  font-size:10px; font-weight:500; background:var(--gris-claro);
  color:var(--gris); padding:3px 10px; border-radius:100px; letter-spacing:0.04em;
}

/* PRECIO CARD LATERAL */
.precio-card {
  background:#3a3a3a; border-radius:14px;
  overflow:hidden; position:sticky; top:120px;
  box-shadow:0 20px 60px rgba(0,0,0,0.12);
}
.pc-top { background:var(--grad); padding:24px 24px 20px; }
.pc-label { font-size:10px; font-weight:700; color:rgba(255,255,255,0.65); letter-spacing:0.18em; text-transform:uppercase; margin-bottom:6px; }
.pc-name { font-size:22px; font-weight:900; color:#fff; margin-bottom:3px; }
.pc-sub { font-size:12px; color:rgba(255,255,255,0.65); font-weight:300; }

.pc-body { padding:24px; }
.pc-valorado { font-size:12px; color:var(--gris-medio); margin-bottom:3px; font-weight:300; }
.pc-tachado { font-size:20px; color:var(--gris-medio); text-decoration:line-through; text-decoration-color:var(--naranja); font-weight:300; }
.pc-precio { font-size:52px; font-weight:900; color:#fff; line-height:1; margin-bottom:3px; }
.pc-precio sup { font-size:22px; font-weight:300; vertical-align:super; }
.pc-perpax { font-size:11px; color:var(--gris-medio); font-weight:300; margin-bottom:12px; }
.pc-ahorro {
  display:inline-block;
  background:rgba(250,164,52,0.12); border:1px solid rgba(250,164,52,0.3);
  color:var(--naranja); font-size:11px; font-weight:700;
  padding:3px 10px; border-radius:4px; margin-bottom:18px;
}
.pc-bar-wrap { margin-bottom:20px; }
.pc-bar-meta { display:flex; justify-content:space-between; margin-bottom:6px; }
.pc-bar-meta span { font-size:11px; color:var(--gris-medio); font-weight:300; }
.pc-bar-meta strong { font-size:11px; color:var(--naranja); font-weight:700; }
.pc-bar { background:rgba(255,255,255,0.08); border-radius:100px; height:4px; overflow:hidden; }
.pc-bar-fill {
  height:100%; width:0; background:var(--grad); border-radius:100px;
  transition:width 1.2s cubic-bezier(0.4,0,0.2,1) 0.2s;
}
.pc-bar-fill.bar-animated { width:70%; }

.pc-lista { list-style:none; border-top:1px solid rgba(255,255,255,0.07); padding-top:18px; margin-bottom:20px; display:flex; flex-direction:column; gap:9px; }
.pc-lista li { display:flex; gap:9px; align-items:flex-start; font-size:12px; color:rgba(255,255,255,0.65); font-weight:300; line-height:1.4; }

.pc-btn {
  display:block; width:100%; text-align:center;
  background:var(--grad); color:#fff;
  font-size:14px; font-weight:700; padding:14px;
  border-radius:5px; text-decoration:none;
  box-shadow:0 4px 18px rgba(250,164,52,0.3);
  transition:all 0.2s; margin-bottom:8px; letter-spacing:0.02em;
}
.pc-btn:hover { transform:translateY(-1px); }
.pc-btn-sec {
  display:block; width:100%; text-align:center;
  background:transparent; border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.45); font-size:12px; font-weight:300;
  padding:11px; border-radius:5px; text-decoration:none; transition:all 0.2s;
}
.pc-btn-sec:hover { border-color:rgba(255,255,255,0.35); color:#fff; }
.pc-nota { text-align:center; font-size:10px; color:rgba(255,255,255,0.2); margin-top:14px; letter-spacing:0.05em; font-weight:300; }

/* ─── SEGUIMIENTO ─── */
.seguimiento-sec { background:#404040; position:relative; overflow:hidden; }
.seguimiento-sec::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 50%, rgba(250,164,52,0.08) 0%, transparent 60%);
  pointer-events:none;
}
.seguimiento-sec .sec-label { color:rgba(250,164,52,0.8); }
.seguimiento-sec .sec-label::before { background:var(--naranja); }
.seguimiento-sec .sec-h2 { color:#fff; }
.seguimiento-sec .sec-h2 em { color:var(--naranja); }
.seguimiento-sec .sec-lead { color:rgba(255,255,255,0.5); }

.seg-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:56px; }
.seg-card {
  border:1px solid rgba(255,255,255,0.08); border-radius:10px;
  padding:32px 24px; background:rgba(255,255,255,0.03);
  transition:all 0.3s;
}
.seg-card:hover { border-color:rgba(250,164,52,0.4); background:rgba(250,164,52,0.05); transform:translateY(-3px); }
.seg-picto { margin-bottom:18px; display:block; }
.seg-title { font-size:18px; font-weight:700; color:#fff; margin-bottom:8px; }
.seg-desc { font-size:13px; color:rgba(255,255,255,0.48); line-height:1.65; font-weight:300; }

/* ─── ROGER ─── */
.roger-sec { background:#fff; }
.roger-grid { display:grid; grid-template-columns:420px 1fr; gap:64px; margin-top:60px; align-items:start; }
.roger-photo-col { position:sticky; top:120px; }
.roger-photo-wrap {
  border-radius:16px; overflow:hidden;
  box-shadow:0 20px 56px rgba(0,0,0,0.16);
  aspect-ratio:2/3;
  background:#f0f0f0;
}
.roger-photo { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
.roger-content-col { display:flex; flex-direction:column; gap:32px; }

.roger-quote-bloque {
  background:var(--gris-claro); border-radius:12px;
  padding:40px 44px;
}
.roger-quote-bloque blockquote {
  font-size:19px; font-style:italic; font-weight:300;
  color:var(--negro); line-height:1.7; margin-bottom:20px;
}
.roger-quote-bloque cite {
  font-size:13px; color:var(--gris-medio); font-style:normal;
  display:flex; align-items:center; gap:10px;
}
.roger-quote-bloque cite::before { content:''; display:block; width:24px; height:1px; background:var(--naranja); }
.roger-sobre {
  font-size:14px; color:var(--gris); line-height:1.75; font-weight:300;
  margin-top:24px; padding-top:20px; border-top:1px solid var(--gris-linea);
}

.roger-creds { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.cred {
  display:flex; flex-direction:column; gap:10px;
  padding:20px 22px; background:var(--gris-claro); border-radius:10px;
  opacity:0; transform:translateY(12px); transition:all 0.5s;
}
.cred.vis { opacity:1; transform:translateY(0); }
.cred-picto { flex-shrink:0; }
.cred-text strong { display:block; font-size:13px; font-weight:700; color:var(--negro); margin-bottom:4px; }
.cred-text p { font-size:12px; color:var(--gris); font-weight:300; line-height:1.55; }

/* ─── TESTIMONIOS ─── */
.testi-sec { background:var(--gris-claro); }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:56px; }
.testi {
  background:#fff; border-radius:10px; padding:32px 24px;
  box-shadow:0 2px 16px rgba(0,0,0,0.05);
}
.testi-estrellas { display:flex; gap:3px; margin-bottom:16px; }
.testi-text {
  font-size:15px; font-style:italic; font-weight:300;
  color:var(--negro); line-height:1.7; margin-bottom:20px;
}
.testi-autor { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:42px; height:42px; border-radius:50%;
  background:var(--grad); display:flex; align-items:center;
  justify-content:center; font-weight:700; color:#fff; font-size:16px;
}
.testi-nombre { font-size:14px; font-weight:700; color:var(--negro); }
.testi-cargo { font-size:12px; color:var(--gris-medio); font-weight:300; }

/* ─── FAQ ─── */
.faq-sec { background:#fff; }
.faq-grid {
  display:flex; flex-direction:column;
  margin-top:56px;
  border-top:1px solid var(--gris-linea);
}
.faq-item {
  border-bottom:1px solid var(--gris-linea);
  transition:background 0.2s;
}
.faq-item[open] { background:#fffaf5; }

.faq-q {
  display:flex; align-items:center; gap:18px;
  width:100%; text-align:left; cursor:pointer;
  padding:28px 0; list-style:none;
  font-size:17px; font-weight:600; color:var(--negro); line-height:1.35;
  transition:color 0.2s;
  user-select:none;
}
.faq-q::-webkit-details-marker { display:none; }
.faq-item[open] > .faq-q { color:var(--negro); }

.faq-icon {
  flex-shrink:0; color:#d4d4d4;
  transition:color 0.25s, transform 0.25s;
}
.faq-item[open] .faq-icon { color:var(--naranja); }

.faq-chevron {
  margin-left:auto; flex-shrink:0;
  color:#c8c8c8;
  transition:transform 0.3s cubic-bezier(0.4,0,0.2,1), color 0.25s;
}
.faq-item[open] .faq-chevron { transform:rotate(180deg); color:var(--naranja); }

.faq-body { padding:0 0 28px 38px; }
.faq-a {
  font-size:15px; color:var(--gris); line-height:1.8; font-weight:300;
  max-width:780px;
  animation:fadeDown 0.22s ease;
}
@keyframes fadeDown {
  from { opacity:0; transform:translateY(-5px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ─── CTA FINAL ─── */
.cta-final {
  background:#3d3d3d; text-align:center;
  padding:120px 60px; position:relative; overflow:hidden;
}
.cta-final::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 70% at 50% 50%, rgba(234,26,32,0.12) 0%, transparent 60%);
  pointer-events:none;
}
.cta-final .sec-label { justify-content:center; color:rgba(250,164,52,0.8); }
.cta-final .sec-label::before { background:var(--naranja); }
.cta-final .sec-h2 { color:#fff; max-width:700px; margin:0 auto 20px; }
.cta-final .sec-h2 em { color:var(--naranja); }
.cta-final .sec-lead { color:rgba(255,255,255,0.45); max-width:540px; margin:0 auto 48px; }

.cta-fechas {
  display:flex; justify-content:center; gap:0;
  background:rgba(255,255,255,0.05); border-radius:8px;
  max-width:600px; margin:0 auto 48px; overflow:hidden;
}
.fecha-item {
  flex:1; padding:18px 12px; text-align:center;
  border-right:1px solid rgba(255,255,255,0.06);
}
.fecha-item:last-child { border-right:none; }
.fecha-val { font-size:17px; font-weight:700; color:#fff; margin-bottom:4px; }
.fecha-lbl { font-size:10px; color:rgba(255,255,255,0.3); letter-spacing:0.12em; text-transform:uppercase; font-weight:400; }

.cta-btns { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:24px; }
.btn-blanco {
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:var(--negro);
  font-size:15px; font-weight:700; padding:16px 32px;
  border-radius:5px; text-decoration:none;
  transition:all 0.2s;
}
.btn-blanco:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,0.3); }
.cta-nota { font-size:12px; color:rgba(255,255,255,0.25); font-weight:300; }

/* ─── FOOTER ─── */
footer {
  background:#1e1e1e;
  border-top:1px solid rgba(255,255,255,0.07);
}
.footer-inner {
  max-width:1100px; margin:0 auto;
  padding:56px 60px 48px;
  display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:48px;
  align-items:start;
}
.footer-col--brand { padding-right:24px; }
.footer-logo { height:22px; opacity:0.35; display:block; margin-bottom:20px; }
.footer-tagline { font-size:13px; line-height:1.7; color:rgba(255,255,255,0.35); font-weight:300; margin:0 0 16px; }
.footer-email { font-size:13px; color:rgba(255,255,255,0.4); text-decoration:none; transition:color 0.2s; }
.footer-email:hover { color:rgba(255,255,255,0.8); }
.footer-col { text-align:left; }
.footer-col-title { font-size:11px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:rgba(255,255,255,0.25); margin:0 0 16px; text-align:left; }
footer nav.footer-nav {
  background:transparent; border:none; padding:0;
  display:flex; flex-direction:column; gap:10px; align-items:flex-start;
}
footer nav.footer-nav a { font-size:13px; color:rgba(255,255,255,0.4); text-decoration:none; font-weight:300; transition:color 0.2s; text-align:left; }
footer nav.footer-nav a:hover { color:rgba(255,255,255,0.85); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.05);
  padding:18px 60px;
}
.footer-bottom span { font-size:11px; color:rgba(255,255,255,0.2); font-weight:300; }

/* ─── DIVISOR ─── */
.divisor { height:1px; background:var(--gris-linea); margin:0 60px; }

/* ═══════════════════════════════════════════════
   PÁGINAS LEGALES
   ═══════════════════════════════════════════════ */

/* NAV */
.l-nav {
  background:#fff; border-bottom:1px solid var(--gris-linea);
  padding:0 60px; height:64px;
  display:flex; align-items:center; justify-content:space-between;
  position:sticky; top:0; z-index:100;
  box-shadow:0 1px 12px rgba(0,0,0,0.06);
}
.l-nav-brand {
  display:flex; align-items:center; gap:10px;
  text-decoration:none;
}
.l-nav-dot {
  width:28px; height:28px; border-radius:7px; flex-shrink:0;
  background:var(--grad);
  display:flex; align-items:center; justify-content:center;
}
.l-nav-dot svg { display:block; }
.l-nav-name { font-size:14px; font-weight:700; color:var(--negro); }
.l-nav-name span { font-weight:300; color:var(--gris); }
.l-nav-back {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:500; color:var(--gris);
  text-decoration:none; transition:color 0.2s;
  padding:8px 16px; border:1px solid var(--gris-linea);
  border-radius:5px; transition:all 0.2s;
}
.l-nav-back:hover { color:var(--naranja); border-color:var(--naranja); }

/* HERO */
.l-hero {
  background:#1a1a1a; position:relative; overflow:hidden;
  padding:72px 60px 64px;
  border-bottom:3px solid transparent;
  border-image:var(--grad) 1;
}
.l-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 100% at 10% 50%, rgba(250,164,52,0.08) 0%, transparent 60%);
  pointer-events:none;
}
.l-hero-inner { max-width:760px; margin:0 auto; position:relative; }
.l-hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(250,164,52,0.12); border:1px solid rgba(250,164,52,0.25);
  color:var(--naranja); font-size:10px; font-weight:700;
  letter-spacing:0.16em; text-transform:uppercase;
  padding:5px 14px; border-radius:100px; margin-bottom:22px;
}
.l-hero h1 {
  font-size:clamp(32px,4vw,52px); font-weight:900; color:#fff;
  line-height:1.07; letter-spacing:-0.025em; margin-bottom:16px;
}
.l-hero-meta {
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  margin-top:24px;
}
.l-hero-date { font-size:12px; color:rgba(255,255,255,0.3); font-weight:300; }
.l-hero-sep { width:1px; height:12px; background:rgba(255,255,255,0.1); }
.l-hero-company { font-size:12px; color:rgba(255,255,255,0.3); font-weight:300; }

/* CONTENIDO */
.l-content { max-width:760px; margin:0 auto; padding:64px 60px 100px; }

/* Secciones numeradas */
.l-section { margin-bottom:56px; }
.l-section-head {
  display:flex; align-items:baseline; gap:16px;
  margin-bottom:20px; padding-bottom:16px;
  border-bottom:1px solid var(--gris-linea);
}
.l-section-num {
  font-size:11px; font-weight:700; color:var(--naranja);
  letter-spacing:0.12em; flex-shrink:0;
}
.l-section-title {
  font-size:19px; font-weight:700; color:var(--negro);
  line-height:1.2; letter-spacing:-0.01em;
}
.l-section h3 {
  font-size:14px; font-weight:700; color:var(--negro);
  margin:24px 0 10px;
}
.l-section p {
  font-size:14px; color:var(--gris); line-height:1.85;
  margin-bottom:14px; font-weight:300;
}
.l-section ul {
  padding-left:0; margin-bottom:20px;
  list-style:none; display:flex; flex-direction:column; gap:8px;
}
.l-section ul li {
  font-size:14px; color:var(--gris); line-height:1.7;
  font-weight:300; padding-left:20px; position:relative;
}
.l-section ul li::before {
  content:''; position:absolute; left:0; top:10px;
  width:5px; height:5px; border-radius:50%;
  background:var(--naranja);
}
.l-section strong { color:var(--negro); font-weight:700; }
.l-section a { color:var(--naranja); text-decoration:underline; text-underline-offset:3px; }
.l-section a:hover { color:var(--rojo); }

/* Card info empresa / aviso importante */
.l-card {
  background:#f7f7f7; border-radius:10px;
  border-left:3px solid var(--naranja);
  padding:24px 28px; margin:20px 0 24px;
}
.l-card p { margin-bottom:6px; font-size:14px; }
.l-card p:last-child { margin-bottom:0; }
.l-card-label {
  font-size:10px; font-weight:700; color:var(--naranja);
  letter-spacing:0.14em; text-transform:uppercase;
  margin-bottom:12px; display:block;
}

/* Grid de derechos RGPD */
.l-rights {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:12px; margin:20px 0;
}
.l-right {
  background:#f7f7f7; border-radius:8px; padding:18px 16px;
  transition:background 0.2s;
}
.l-right:hover { background:#fff0e6; }
.l-right-icon { font-size:20px; display:block; margin-bottom:8px; }
.l-right strong { display:block; font-size:13px; font-weight:700; color:var(--negro); margin-bottom:4px; }
.l-right p { font-size:12px; color:var(--gris); line-height:1.5; margin-bottom:0; font-weight:300; }

/* Tablas */
.l-table-wrap { overflow-x:auto; margin:20px 0 28px; border-radius:8px; border:1px solid var(--gris-linea); }
.l-table { width:100%; border-collapse:collapse; font-size:13px; }
.l-table thead tr { background:#f7f7f7; }
.l-table th {
  padding:13px 16px; text-align:left;
  font-weight:700; color:var(--negro); font-size:12px;
  letter-spacing:0.03em; border-bottom:1px solid var(--gris-linea);
}
.l-table td {
  padding:13px 16px; color:var(--gris); font-weight:300;
  line-height:1.55; vertical-align:top;
  border-bottom:1px solid var(--gris-linea);
}
.l-table tr:last-child td { border-bottom:none; }
.l-table-badge {
  display:inline-block; font-size:10px; font-weight:700;
  padding:2px 8px; border-radius:100px; letter-spacing:0.06em;
}
.l-table-badge--green { background:#e8f5e9; color:#388e3c; }
.l-table-badge--orange { background:#fff3e0; color:#e65100; }
.l-table-badge--blue { background:#e3f2fd; color:#1565c0; }
.l-table-badge--gray { background:#f5f5f5; color:#757575; }

/* Estado pendiente */
.l-pending {
  background:#fffbf2; border:1px dashed rgba(250,164,52,0.4);
  border-radius:8px; padding:16px 20px; margin:16px 0;
  font-size:13px; color:var(--gris); font-weight:300; line-height:1.6;
}
.l-pending strong { color:var(--naranja); }

/* Botón gestión cookies */
.l-cookie-reset {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Roboto',sans-serif; font-size:13px; font-weight:700;
  cursor:pointer; background:#fff; color:var(--negro);
  border:1px solid var(--gris-linea); padding:11px 22px;
  border-radius:6px; transition:all 0.2s; margin-top:8px;
}
.l-cookie-reset:hover { border-color:var(--naranja); color:var(--naranja); }

/* Links navegadores */
.l-browser-links { display:flex; flex-wrap:wrap; gap:10px; margin:12px 0; }
.l-browser-links a {
  font-size:13px; color:var(--gris); font-weight:400;
  text-decoration:none; padding:7px 16px;
  border:1px solid var(--gris-linea); border-radius:5px;
  transition:all 0.2s;
}
.l-browser-links a:hover { border-color:var(--naranja); color:var(--naranja); }

/* FOOTER */
.l-footer {
  background:#1e1e1e; padding:24px 60px;
  display:flex; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(255,255,255,0.07);
}
.l-footer-left { display:flex; flex-direction:column; gap:4px; }
.l-footer-brand { font-size:13px; font-weight:600; color:rgba(255,255,255,0.4); }
.l-footer-copy { font-size:11px; color:rgba(255,255,255,0.2); font-weight:300; }
nav.l-footer-links {
  background:transparent; border:none; padding:0;
  display:flex; gap:24px;
}
nav.l-footer-links a {
  font-size:12px; color:rgba(255,255,255,0.35); font-weight:300;
  text-decoration:none; transition:color 0.2s;
}
nav.l-footer-links a:hover { color:#fff; }
nav.l-footer-links a.active { color:rgba(255,255,255,0.7); font-weight:500; }

/* RESPONSIVE */
@media (max-width:960px) {
  .l-nav { padding:0 20px; height:56px; }
  .l-nav-back span { display:none; }
  .l-hero { padding:48px 20px 44px; }
  .l-content { padding:40px 20px 72px; }
  .l-rights { grid-template-columns:1fr 1fr; }
  .l-footer { flex-direction:column; gap:16px; text-align:center; padding:24px 20px; }
  .l-footer-links { justify-content:center; }
}
@media (max-width:480px) {
  .l-hero { padding:36px 16px 36px; }
  .l-content { padding:32px 16px 60px; }
  .l-rights { grid-template-columns:1fr; }
  .l-table th, .l-table td { padding:10px 12px; font-size:12px; }
}

/* ─── BANNER DE COOKIES ─── */
.cookie-banner {
  position:fixed; bottom:24px; right:24px; z-index:500;
  background:#1e1e1e;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;
  padding:20px 22px;
  max-width:320px; width:calc(100% - 32px);
  box-shadow:0 8px 32px rgba(0,0,0,0.4);
  opacity:0; pointer-events:none;
  transform:translateY(12px);
  transition:opacity 0.35s ease, transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.cookie-banner.cb-visible {
  opacity:1; pointer-events:all;
  transform:translateY(0);
}
.cookie-banner__title {
  font-size:13px; font-weight:700; color:#fff;
  margin:0 0 6px;
}
.cookie-banner__text {
  font-size:12px; color:rgba(255,255,255,0.45);
  line-height:1.6; font-weight:300; margin:0 0 16px;
}
.cookie-banner__text a { color:rgba(255,255,255,0.4); text-decoration:underline; text-underline-offset:3px; }
.cookie-banner__text a:hover { color:#fff; }
.cookie-banner__btns { display:flex; gap:8px; }
.cookie-banner__btn {
  font-family:'Roboto',sans-serif; font-size:12px; font-weight:700;
  padding:9px 14px; border-radius:6px; cursor:pointer;
  transition:all 0.2s; letter-spacing:0.02em; flex:1; text-align:center;
}
.cookie-banner__btn--accept {
  background:var(--grad); border:none; color:#fff;
  box-shadow:0 3px 10px rgba(250,164,52,0.3);
}
.cookie-banner__btn--accept:hover { box-shadow:0 5px 16px rgba(250,164,52,0.45); }
.cookie-banner__btn--ghost {
  background:transparent; border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.4);
}
.cookie-banner__btn--ghost:hover { border-color:rgba(255,255,255,0.3); color:rgba(255,255,255,0.75); }

@media (max-width:480px) {
  .cookie-banner { bottom:16px; right:16px; max-width:calc(100% - 32px); }
}

/* ─── RESPONSIVE ─── */
@media (max-width:960px) {

  /* Espacio inferior para el FAB */
  body { padding-bottom:80px; }

  /* TOPBAR: 2 filas — texto arriba / countdown + botón abajo */
  .topbar {
    flex-direction:column; gap:8px;
    padding:10px 16px; text-align:center;
  }
  .topbar p { font-size:12px; }
  .topbar-bottom {
    display:flex; align-items:center;
    justify-content:center; gap:12px;
  }
  .topbar-pill {
    font-size:12px; padding:7px 18px;
    background:rgba(255,255,255,0.22);
    border-color:rgba(255,255,255,0.55);
  }

  /* NAV: ocultar texto autor y botón (FAB los reemplaza) */
  nav { padding:10px 20px; }
  .nav-autor { display:none; }
  .btn-nav { display:none; }

  /* HERO */
  .hero {
    grid-template-columns:1fr; gap:32px;
    padding:40px 20px 48px;
  }
  .hero-badge { font-size:10px; padding:5px 12px; }
  .hero h1 { font-size:clamp(32px,8vw,44px); }
  .hero-tagline { font-size:17px; margin-bottom:24px; }
  .hero-copy { font-size:15px; line-height:1.75; margin-bottom:28px; }
  .hero-btns { flex-direction:column; gap:12px; }
  .btn-main { justify-content:center; width:100%; }

  /* Hero card: estática, sin sticky */
  .hero-card { position:relative; top:0; }
  .hcard-body { padding:20px; }
  .hcard-top { padding:20px 20px 16px; }
  .precio-num { font-size:46px; }

  /* SECCIONES */
  .seccion { padding:48px 20px; }
  .seccion-sm { padding:36px 20px; }
  .sec-h2 { font-size:clamp(24px,6.5vw,36px); }
  .sec-lead { font-size:15px; }
  .divisor { margin:0 20px; }

  /* DOLOR */
  .dolor-grid { grid-template-columns:1fr; gap:40px; }
  .dolor-right { position:relative; top:0; }
  .cita-bloque { padding:28px 24px; }
  .cita-text { font-size:17px; }
  .metricas { gap:10px; }
  .metrica { padding:16px 12px; }
  .metrica-val { font-size:26px; }

  /* MÓDULOS */
  .modulos-grid { grid-template-columns:1fr; }
  .modulo { padding:24px 20px; }

  /* ESTRUCTURA + PRECIO */
  .estructura-wrap { grid-template-columns:1fr; gap:40px; }
  .precio-card { position:relative; top:0; }
  .pc-precio { font-size:42px; }
  .pc-body { padding:20px; }
  .pc-top { padding:18px 20px 14px; }

  /* SEGUIMIENTO */
  .seg-grid { grid-template-columns:1fr; }

  /* ROGER */
  .roger-grid { grid-template-columns:1fr; gap:32px; }
  .roger-photo-col { position:static; }
  .roger-photo-wrap { aspect-ratio:3/2; max-height:340px; }
  .roger-photo { object-position:center 15%; }
  .roger-quote-bloque { padding:28px 24px; }
  .roger-quote-bloque blockquote { font-size:17px; }
  .roger-creds { grid-template-columns:1fr 1fr; }

  /* TESTIMONIOS */
  .testi-grid { grid-template-columns:1fr; }

  /* FAQ */
  .faq-q { font-size:15px; padding:22px 0; gap:14px; }
  .faq-body { padding:0 0 22px 34px; }
  .faq-a { font-size:14px; max-width:100%; }

  /* CTA FINAL */
  .cta-final { padding:72px 20px; }
  .cta-fechas {
    flex-direction:column; max-width:100%;
    border-radius:8px;
  }
  .fecha-item { border-right:none; border-bottom:1px solid rgba(255,255,255,0.06); padding:14px 12px; }
  .fecha-item:last-child { border-bottom:none; }
  .cta-btns { flex-direction:column; align-items:center; }
  .btn-main--lg { width:100%; justify-content:center; }
  .btn-blanco { width:100%; justify-content:center; }

  /* FOOTER */
  .footer-inner { grid-template-columns:1fr; gap:32px; padding:40px 20px 32px; }
  .footer-col--brand { padding-right:0; }
  .footer-bottom { padding:16px 20px; }
}

/* ─── RESPONSIVE XS (≤480px) ─── */
@media (max-width:480px) {
  .topbar p { font-size:11px; }
  .countdown { gap:3px; }
  .cd-num { font-size:16px; }
  .cd-block { min-width:30px; }

  nav { padding:10px 16px; }
  .nav-logo { height:22px; }

  .hero { padding:32px 16px 40px; }
  .hero h1 { font-size:clamp(28px,8.5vw,38px); }
  .hero-tagline { font-size:15px; }

  .seccion { padding:40px 16px; }
  .seccion-sm { padding:28px 16px; }
  .divisor { margin:0 16px; }

  .cita-bloque { padding:22px 18px; }
  .metricas { grid-template-columns:1fr 1fr; }

  .faq-q { font-size:14px; padding:18px 0; gap:12px; }
  .faq-body { padding:0 0 18px 30px; }
  .cta-final { padding:56px 16px; }
  .footer-inner { padding:32px 16px 24px; }
  .footer-bottom { padding:14px 16px; }
}

/* ─── FAB (botón flotante mobile) ─── */
.fab {
  display: none; /* oculto por defecto en desktop */
}
@media (max-width:960px) {
  .fab {
    display: flex; align-items:center; justify-content:center;
    position: fixed; bottom:16px; left:16px; right:16px;
    background: var(--grad);
    color: #fff; font-size:14px; font-weight:700;
    padding:16px 24px; border-radius:8px; text-decoration:none;
    box-shadow: 0 6px 24px rgba(234,26,32,0.35);
    z-index:200;
    opacity:0; transform:translateY(80px);
    transition:opacity 0.3s ease, transform 0.3s ease;
    pointer-events:none;
  }
  .fab--visible {
    opacity:1; transform:translateY(0);
    pointer-events:auto;
  }
}

/* ─── ANIMACIONES ─── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to { opacity:1; transform:translateY(0); }
}
.hero > * { animation:fadeUp 0.7s ease forwards; opacity:0; }
.hero-badge { animation-delay:0.05s; }
.hero h1 { animation-delay:0.15s; }
.hero-tagline { animation-delay:0.22s; }
.hero-copy { animation-delay:0.28s; }
.hero-checks { animation-delay:0.33s; }
.hero-btns { animation-delay:0.38s; }
.hero-card { animation-delay:0.2s; }
