/* ==========================================================
   francescXavier · Informe Geniotipo
   Hoja de estilos plana — sin frameworks
   ========================================================== */

:root {
  /* Paleta oficial — francescXavier v5 */
  --teal: #084650;
  --naranja: #D47B61;
  --salvia: #C9D4CC;
  --marfil: #F9F7F2;
  --gris: #898A8D;

  /* Variantes con alpha (convención v5: teal/marfil + % alpha) */
  --teal-04: rgba(8,70,80,0.04);
  --teal-08: rgba(8,70,80,0.08);
  --teal-10: rgba(8,70,80,0.10);
  --teal-12: rgba(8,70,80,0.12);
  --teal-15: rgba(8,70,80,0.15);
  --teal-18: rgba(8,70,80,0.18);
  --teal-25: rgba(8,70,80,0.25);
  --marfil-18: rgba(249,247,242,0.18);
  --marfil-20: rgba(249,247,242,0.20);
  --marfil-85: rgba(249,247,242,0.85);

  /* (alias eliminados — paleta estricta) */

  /* Aliases legacy */
  --hair: var(--teal-18);
  --hair-soft: var(--teal-10);
}

* { box-sizing: border-box; }
html {
  scroll-padding-top: 72px;
  scroll-behavior: smooth;
}
html, body {
  margin: 0; padding: 0;
  background: var(--marfil);
  color: var(--teal);
  font-family: 'Noto Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
h1, h2, h3 { margin: 0; font-weight: 400; letter-spacing: -0.025em; text-wrap: balance; }
h1 strong, h2 strong, h3 strong { font-weight: 700; }
p { margin: 0; }

/* ── Kickers / labels ── */
.kicker {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; color: var(--gris); display: inline-block;
}
.kicker-orange { color: var(--naranja); }
.kicker-salvia { color: var(--salvia); }
.kicker-on-orange { color: var(--marfil); font-weight: 700; opacity: 0.85; }
.tag-orange {
  font-size: 11px; color: var(--naranja); letter-spacing: 0.22em;
  text-transform: uppercase; font-weight: 700; display: inline-block;
}

/* ── Botones ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: inherit; font-size: 12px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.12em;
  padding: 14px 28px; border: none; cursor: pointer;
  text-decoration: none; transition: filter 180ms cubic-bezier(.2,.6,.2,1);
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(8, 70, 80, 0.10);
}
.btn:hover { filter: brightness(0.92); }
.btn-primario { background: var(--naranja); color: var(--marfil); font-weight: 700; }
.btn-dark { background: var(--teal); color: var(--marfil); font-weight: 700; }
.btn-outline { background: transparent; color: var(--teal); border: 1.5px solid var(--teal); padding: 12.5px 26.5px; }
.btn-outline-marfil { background: transparent; color: var(--marfil); border: 1.5px solid var(--marfil); padding: 12.5px 26.5px; }
.btn-full { width: 100%; }

/* ── NAV ── */
.nav {
  padding: 20px 96px;
  display: flex; justify-content: space-between; align-items: center;
  background: var(--marfil);
  border-bottom: 0.5px solid var(--hair-soft);
  position: sticky; top: 0; z-index: 20;
}
.logo {
  font-size: 20px; line-height: 1; letter-spacing: -0.025em;
  text-decoration: none; white-space: nowrap;
}
.logo-fr { font-weight: 400; color: var(--teal); }
.logo-xv { font-weight: 700; color: var(--naranja); margin-left: 0.07em; }
.nav-links { display: flex; gap: 28px; align-items: center; font-size: 12px; }
.nav-links a { color: var(--teal); text-decoration: none; }
.nav-links a:hover { opacity: 0.7; }
.nav-links .btn-primario { color: var(--marfil); }
.lang-switch {
  display: inline-flex; border: 0.5px solid var(--teal); padding: 2px;
}
.lang-btn {
  font-family: inherit; font-size: 10px; font-weight: 700;
  padding: 4px 8px; background: transparent; color: var(--teal);
  border: none; cursor: pointer; letter-spacing: 0.12em;
}
.lang-btn.is-active { background: var(--teal); color: var(--marfil); }

/* ── HERO ── */
.hero { padding: 30px 96px 80px; }
.hero-grid {
  display: grid; grid-template-columns: 1fr 2fr; gap: 64px;
  align-items: center;
}
.hero-numero {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 20px;
}
.huge-num {
  font-size: 220px; font-weight: 500; line-height: 0.85;
  letter-spacing: -0.05em; color: var(--naranja);
  font-variant-numeric: tabular-nums; text-align: center;
}
.hero-numero-meta {
  font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gris); font-weight: 500;
  max-width: 280px; line-height: 1.45; text-align: center;
}
.hero-copy h1 {
  margin-top: 28px; font-size: 72px; line-height: 1.0;
  letter-spacing: -0.035em; color: var(--teal);
}
.hero-copy .lead {
  margin-top: 32px; font-size: 17px; line-height: 1.65;
  max-width: 560px; color: var(--teal);
}
.hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }

/* ── DECLARACIÓN ── */
.declaracion {
  padding: 0 96px;
  background: var(--salvia);
}
.declaracion-grid {
  display: grid; grid-template-columns: 1fr 2fr 1fr; gap: 32px;
  align-items: start;
}
.declaracion-meta { padding-top: 0; }
.declaracion-card {
  background: var(--marfil); padding: 56px 64px;
  border-top: 3px solid var(--naranja);
  border-bottom: 3px solid var(--naranja);
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
  border-radius: 6px;
}
.declaracion-card > .kicker { display: block; margin-bottom: 20px; }
.declaracion-card p {
  font-size: 17px; line-height: 1.65; color: var(--teal);
  letter-spacing: -0.005em;
}
.declaracion-card p + p { margin-top: 24px; }

/* ── INTRO ── */
.intro { padding: 64px 96px; }
.intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.intro-card {
  background: var(--marfil); padding: 48px 40px;
  border: 1px solid var(--teal-25);
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
}
.intro-card-salvia { background: var(--salvia); border: none; }
.intro-card .big-num {
  font-size: 56px; color: var(--naranja); font-weight: 400;
  line-height: 1; letter-spacing: -0.04em; display: inline-block;
}
.intro-card h2 {
  margin-top: 24px; font-size: 28px; font-weight: 400;
  color: var(--teal); letter-spacing: -0.02em; line-height: 1.2;
}
.intro-card p { margin-top: 14px; font-size: 15px; line-height: 1.7; color: var(--teal); }
.intro-card p:nth-of-type(1) { margin-top: 20px; }

/* ── PARA QUIÉN ── */
.para-quien {
  padding: 48px 96px; background: var(--teal); color: var(--marfil);
}
.para-quien-grid {
  display: grid; grid-template-columns: 1fr 1.6fr; gap: 64px; align-items: flex-start;
}
.para-quien h2 {
  margin-top: 24px; font-size: 56px; line-height: 1.05;
  letter-spacing: -0.03em; color: var(--marfil);
}
.para-quien h2 strong { color: var(--naranja); }
.para-quien-num {
  margin-top: 48px; font-size: 280px; font-weight: 500;
  line-height: 0.85; letter-spacing: -0.05em;
  color: var(--salvia); opacity: 0.18; font-variant-numeric: tabular-nums;
}
.para-quien-list { list-style: none; padding: 0; margin: 0; }
.para-quien-list li {
  display: grid; grid-template-columns: 60px 1fr; gap: 20px;
  padding: 28px 0; border-bottom: 0.5px solid var(--marfil-18);
  align-items: baseline;
}
.para-quien-list li:first-child { border-top: none; }
.para-quien-list li:last-child { border-bottom: none; }
.para-quien-list .li-num {
  font-size: 32px; color: var(--naranja); font-weight: 400;
  letter-spacing: -0.02em; line-height: 1;
}
.para-quien-list p { font-size: 17px; line-height: 1.55; color: var(--marfil); }

/* ── DELIVERABLES ── */
.deliverables { padding: 64px 96px; }
.deliverables-head {
  display: grid; grid-template-columns: 1fr 2fr; gap: 32px;
  align-items: flex-start; margin-bottom: 56px;
}
.deliverables-head h2 {
  font-size: 48px; line-height: 1.1; color: var(--teal);
}
.deliverables-head h2 strong { color: var(--naranja); }
.deliverables-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.deliverables-card {
  background: var(--marfil); padding: 48px 40px;
  border: 1px solid var(--teal-25);
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
}
.deliverables-card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
}
.big-num-salvia {
  font-size: 64px; color: var(--salvia); font-weight: 400;
  letter-spacing: -0.03em; line-height: 0.9;
}
.num-spacer {
  display: inline-block;
  width: 0.15em;
}
.deliverables-card h3 {
  margin-top: 24px; font-size: 24px; font-weight: 700;
  color: var(--teal); letter-spacing: -0.015em;
}
.deliverables-card p {
  margin-top: 16px; font-size: 14px; line-height: 1.7; color: var(--teal);
}

/* ── MI INFORME ── */
.mi-informe { padding: 48px 96px; background: var(--salvia); }
.mi-informe-grid {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px;
  align-items: center;
}
.mi-informe-mockup-wrap {
  position: relative; display: flex; justify-content: flex-end;
  padding-right: 24px;
}
.mi-informe-img {
  width: 100%; max-width: 360px; display: block;
  transform: rotate(-3deg);
}

.pdf-mockup {
  width: 100%; max-width: 360px; aspect-ratio: 3/4;
  background: var(--marfil); padding: 32px 28px;
  box-shadow: 0 24px 64px -16px var(--teal-25),
              0 8px 24px -8px var(--teal-15);
  transform: rotate(-3deg);
}
.pdf-mockup-bar { height: 24px; background: var(--naranja); margin-bottom: 24px; }
.pdf-mockup-eyebrow { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gris); }
.pdf-mockup-title { margin-top: 8px; font-size: 14px; font-weight: 700; color: var(--teal); letter-spacing: -0.01em; line-height: 1.2; }
.pdf-mockup-lines {
  margin-top: 24px; display: flex; flex-direction: column; gap: 6px;
}
.pdf-mockup-lines::before, .pdf-mockup-lines::after {
  content: ""; height: 3px; background: var(--teal); opacity: 0.15;
}
/* Render fake lines via repeated linear gradients */
.pdf-mockup-lines {
  background-image: repeating-linear-gradient(
    to bottom,
    var(--teal-15) 0, var(--teal-15) 3px,
    transparent 3px, transparent 9px
  );
  height: 90px;
}
.pdf-mockup-lines-short { height: 54px; }
.pdf-stamp {
  position: absolute; top: 48px; right: 24px;
  width: 96px; height: 96px; border-radius: 50%;
  border: 1.5px solid var(--naranja); color: var(--naranja);
  display: flex; align-items: center; justify-content: center;
  transform: rotate(8deg); background: var(--marfil-85);
  font-size: 9px; letter-spacing: 0.15em; text-transform: uppercase;
  font-weight: 700; text-align: center; line-height: 1.3; padding: 12px;
}
.mi-informe h2 {
  margin-top: 24px; font-size: 48px; line-height: 1.1;
  color: var(--teal);
}
.mi-informe h2 strong { color: var(--naranja); }
.mi-informe p {
  margin-top: 24px; font-size: 16px; line-height: 1.7;
  color: var(--teal); max-width: 520px;
}
.mi-informe .btn { margin-top: 32px; }
.mi-informe-note {
  margin-top: 24px !important; font-size: 13px !important;
  color: var(--teal); opacity: 0.75; font-style: italic; max-width: 460px;
}

/* ── TRES CAPAS ── */
.capas { padding: 64px 96px; }
.capas-head {
  display: grid; grid-template-columns: 2fr 1fr; gap: 32px;
  align-items: flex-end; margin-bottom: 56px;
}
.capas-head h2 {
  font-size: 56px; line-height: 1.05; color: var(--teal);
}
.capas-grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 24px;
}
.capa-card {
  background: var(--marfil); padding: 40px 32px; min-height: 380px;
  display: flex; flex-direction: column; justify-content: space-between;
  color: var(--teal);
  border: 1px solid var(--teal-25);
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
}
.capa-card-dark { background: var(--teal); color: var(--marfil); border: none; }
.capa-eyebrow {
  font-size: 11px; color: var(--naranja); letter-spacing: 0.22em;
  text-transform: uppercase; font-weight: 700;
}
.capa-card h3 {
  margin-top: 16px; font-size: 28px; font-weight: 700;
  letter-spacing: -0.02em;
}
.capa-card-dark h3 { color: var(--marfil); }
.capa-card p { margin-top: 20px; font-size: 14px; line-height: 1.65; }
.capa-card-dark p { color: var(--salvia); }
.capa-tag-wrap {
  margin-top: 32px; padding-top: 16px;
  border-top: 0.5px solid var(--hair-soft);
}
.capa-card-dark .capa-tag-wrap { border-top-color: var(--marfil-20); }
.capa-tag {
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gris); font-weight: 500;
}
.capa-card-dark .capa-tag { color: var(--salvia); }

/* ── TESTIMONIOS / CARRUSEL ── */
.testimonios { padding: 64px 96px; background: var(--marfil); }
.testimonios-head {
  display: grid; grid-template-columns: 1fr 2fr; gap: 64px;
  margin-bottom: 48px; align-items: flex-end;
}
.testimonios-head h2 {
  font-size: 48px; line-height: 1.1; color: var(--teal);
}
.testimonios-head h2 strong { color: var(--naranja); }
.carousel {
  display: flex; align-items: center; gap: 20px;
}
.carousel-arrow {
  width: 31px; height: 31px; border-radius: 50%;
  border: 0.5px solid var(--hair); background: var(--marfil);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: rgba(8, 70, 80, 0.45);
  font-size: 36px; line-height: 1; padding: 0 0 5px 0;
  flex-shrink: 0; transition: background 0.2s, color 0.2s;
  font-family: inherit;
}
.carousel-arrow:hover:not(:disabled) { background: var(--salvia); color: rgba(8, 70, 80, 0.75); }
.carousel-arrow:disabled { opacity: 0.3; cursor: not-allowed; }
.carousel-viewport { flex: 1; overflow: hidden; }
.carousel-track {
  display: grid; grid-auto-flow: column;
  grid-auto-columns: calc((100% - 48px) / 3);
  gap: 24px;
  transition: transform 0.6s cubic-bezier(0.65, 0, 0.35, 1);
}
.carousel-track.pos-0 { transform: translateX(0); }
.carousel-track.pos-1 { transform: translateX(calc(-33.3333% - 24px)); }
.carousel-track.pos-2 { transform: translateX(calc(-66.6667% - 48px)); }
.carousel-track.pos-3 { transform: translateX(calc(-100% - 72px)); }
.carousel-track.pos-4 { transform: translateX(calc(-133.3333% - 96px)); }
.carousel-track.pos-5 { transform: translateX(calc(-166.6667% - 120px)); }
.testimonio {
  background: var(--marfil); padding: 40px 32px;
  border: 1.5px solid rgba(212, 123, 97, 0.5);
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
}
.testimonio-q {
  font-size: 56px; color: var(--naranja); font-weight: 400;
  line-height: 0.6; letter-spacing: -0.04em;
}
.testimonio p {
  margin-top: 8px; font-size: 15px; line-height: 1.6;
  color: var(--teal); font-style: italic;
}
.testimonio-a {
  margin-top: 32px !important; font-size: 11px !important;
  letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 700; color: var(--teal); font-style: normal !important;
  padding-top: 16px; border-top: 0.5px solid var(--hair-soft);
}
.carousel-dots {
  display: flex; justify-content: center; gap: 8px; margin-top: 32px;
}
.carousel-dot {
  width: 8px; height: 4px; background: var(--hair);
  border: none; padding: 0; cursor: pointer; transition: all 0.3s;
}
.carousel-dot.is-active { width: 24px; background: var(--naranja); }

/* ── SIGUIENTES ── */
.siguientes { padding: 64px 96px; }
.siguientes-head { margin-bottom: 56px; }
.siguientes-head .kicker-orange { color: var(--naranja); }
.siguientes-head h2 {
  margin-top: 24px; font-size: 56px; line-height: 1.05;
  color: var(--teal); max-width: 820px;
}
.siguientes-head h2 strong { color: var(--naranja); }
.siguientes-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.siguientes-card {
  background: var(--marfil); padding: 40px 32px;
  color: var(--teal);
  border: 1px solid var(--teal-25);
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
}
.siguientes-card h3 {
  margin-top: 16px; font-size: 22px; font-weight: 700;
  color: var(--teal); letter-spacing: -0.015em;
}
.siguientes-card p { margin-top: 16px; font-size: 14px; line-height: 1.7; color: var(--teal); }
.siguientes-note {
  margin-top: 24px !important; font-size: 11px !important;
  color: var(--gris); letter-spacing: 0.1em; text-transform: uppercase;
  font-weight: 500;
  padding-top: 16px; border-top: 0.5px solid var(--teal-10);
}

/* ── PRECIO ── */
.precio {
  padding: 64px 96px; background: var(--salvia);
}
.precio-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  align-items: flex-end; margin-bottom: 56px;
}
.precio .kicker-on-orange { color: var(--naranja); opacity: 1; }
.precio-head h2 {
  margin-top: 24px; font-size: 56px; line-height: 1.05;
  color: var(--teal);
}
.precio-head h2 strong { color: var(--naranja); }
.precio-sub { font-size: 17px; line-height: 1.65; color: var(--teal); opacity: 0.85; max-width: 480px; }
.precio-grid {
  display: grid; grid-template-columns: 1.25fr 1fr 1fr; gap: 24px; align-items: stretch;
}
@media (max-width: 1100px) {
  .precio-grid { grid-template-columns: 1fr 1fr; }
  .precio-grid > .precio-card:first-child { grid-column: span 2; }
}
.precio-card {
  background: var(--marfil); padding: 48px 36px; position: relative;
  border: 1px solid var(--teal-25);
  box-shadow: 0 1px 3px rgba(8, 70, 80, 0.07);
  border-radius: 6px;
  display: flex; flex-direction: column;
}
.precio-card .btn-full { margin-top: auto; }
.precio-card-dark { background: var(--teal); color: var(--marfil); }
.precio-card h3 {
  margin-top: 16px; font-size: 26px; font-weight: 700;
  color: var(--teal); letter-spacing: -0.015em;
}
.precio-card-dark h3 { color: var(--marfil); }
.precio-card > p:nth-of-type(1) {
  margin-top: 14px; font-size: 14px; line-height: 1.65; color: var(--teal);
}
.precio-card-dark > p:nth-of-type(1) { color: var(--salvia); }
.precio-amount {
  margin-top: 32px; display: flex; flex-direction: column;
  align-items: flex-start; gap: 6px;
}
.precio-num {
  font-size: 48px; font-weight: 500; color: var(--naranja);
  letter-spacing: -0.025em; line-height: 1;
}
.precio-num-marfil { color: var(--marfil); font-size: 40px; }
.precio-num-teal { color: var(--teal); font-size: 36px; }
.precio-note { font-size: 13px; color: var(--gris); }
.precio-note-salvia { color: var(--salvia); font-size: 12px; }
.hr-soft {
  border: none; border-top: 0.5px solid var(--hair-soft); margin: 32px 0;
}
.hr-on-dark { border-top-color: var(--marfil-18); }
.precio-list { list-style: none; padding: 0; margin: 16px 0 32px; }
.precio-list li {
  display: grid; grid-template-columns: 20px 1fr; gap: 8px;
  padding: 8px 0; font-size: 14px;
}
.precio-card-dark .precio-list li { color: var(--marfil); }
.bullet { color: var(--naranja); font-weight: 700; }
.precio-context {
  margin-top: 20px; font-size: 12px; line-height: 1.6;
  color: var(--gris); font-style: italic;
}
.precio-reduction-note {
  max-width: 860px;
  margin: 30px auto 0;
  font-size: 14px;
  line-height: 1.7;
  color: var(--teal);
  text-align: center;
}
.precio-reduction-note a {
  color: var(--naranja);
  text-decoration: none;
  border-bottom: 1px solid rgba(212, 123, 97, 0.45);
  font-weight: 700;
}
.precio-reduction-note a:hover { border-bottom-color: var(--naranja); }
.precio-context-wide {
  max-width: 720px;
  margin: 28px auto 0;
  text-align: center;
}
.inline-link {
  color: inherit;
  text-decoration: underline;
}


/* ── AUTOR ── */
.autor { padding: 64px 96px; background: var(--salvia); }
.autor-grid {
  display: grid; grid-template-columns: 1fr 2fr; gap: 64px; align-items: flex-start;
}
.autor-meta { align-self: end; }
.autor-meta .kicker { margin-top: 20px; }
.autor-sig { margin-top: 8px; font-size: 18px; font-weight: 700; color: var(--teal); letter-spacing: -0.01em; }
.autor h2 {
  margin-top: 20px; font-size: 40px; line-height: 1.15;
  color: var(--teal);
}
.autor h2 strong { color: var(--naranja); }
.autor p { margin-top: 16px; font-size: 15px; line-height: 1.7; color: var(--teal); }
.autor p:nth-of-type(1) { margin-top: 28px; }

/* ── TRANSPARENCIA ── */
.transparencia { padding: 64px 96px; background: var(--marfil); }
.transparencia .kicker { font-weight: 700; }
.transparencia-grid { display: grid; grid-template-columns: 1fr 2fr; gap: 64px; }
.transparencia p { font-size: 13px; line-height: 1.7; color: var(--gris); }
.transparencia p + p { margin-top: 14px; }
.transparencia > .transparencia-grid > div { max-width: 720px; }

/* ── CIERRE ── */
.cierre {
  padding: 64px 96px; background: var(--naranja); color: var(--marfil);
  position: relative; overflow: hidden;
}
.cierre-inner { position: relative; max-width: 880px; }
.cierre h2 {
  margin-top: 24px; font-size: 64px; line-height: 1.05; color: var(--marfil);
}
.cierre p {
  margin-top: 28px; font-size: 16px; line-height: 1.65;
  color: var(--marfil); opacity: 0.92; max-width: 600px;
}
.cierre .btn { margin-top: 40px; }

/* ── FOOTER ── */
.footer {
  padding: 24px 96px; background: var(--teal); color: var(--marfil);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500;
}
.footer-left { display: flex; align-items: center; gap: 16px; }
.footer-mono {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--marfil); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.footer span { color: var(--salvia); }
.footer a { color: var(--salvia); text-decoration: none; }

/* ── MODAL CONTACTO ── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(8,70,80,0.55);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s;
}
.modal-overlay.is-open {
  opacity: 1; pointer-events: all;
}
.modal-box {
  background: var(--marfil);
  border-radius: 6px;
  padding: 48px;
  width: calc(100% - 48px); max-width: 520px;
  position: relative;
  max-height: 90vh; overflow-y: auto;
}
.modal-close {
  position: absolute; top: 16px; right: 20px;
  background: none; border: none; cursor: pointer;
  font-size: 26px; line-height: 1; color: var(--teal);
  opacity: 0.5; transition: opacity 0.15s;
}
.modal-close:hover { opacity: 1; }
.modal-title { font-size: 22px; margin-bottom: 28px; }
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
.form-group label { font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gris); }
.form-group input,
.form-group textarea {
  border: 1px solid var(--teal-18);
  background: #fff;
  padding: 10px 14px;
  font-size: 15px;
  color: var(--teal);
  font-family: inherit;
  border-radius: 6px;
  outline: none;
  transition: border-color 0.15s;
  resize: vertical;
}
.form-group input:focus,
.form-group textarea:focus { border-color: var(--teal); }
.modal-submit { width: 100%; justify-content: center; margin-top: 4px; }
.form-status { margin-top: 14px; font-size: 14px; text-align: center; min-height: 20px; }
.form-status.ok { color: #2a7a4f; }
.form-status.err { color: var(--naranja); }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .nav { padding: 12px 20px 12px 12px; }
  .nav-links { gap: 8px; }
  .nav-links a:not(.btn) { display: none; }
  .lang-btn { font-size: 9px; padding: 3px 6px; }
  .lang-switch { padding: 1px; }
  .nav-links .btn-primario { font-size: 9px; padding: 6px 10px; letter-spacing: 0.06em; }
  .hero, .intro, .para-quien, .deliverables,
  .mi-informe, .capas, .testimonios, .siguientes, .precio,
  .autor, .transparencia, .cierre { padding-left: 25px; padding-right: 25px; }

  /* Padding vertical de cada apartado reducido a la mitad en móvil */
  .hero          { padding-top: 16px; padding-bottom: 40px; }
  .intro         { padding-top: 32px; padding-bottom: 32px; }
  .para-quien    { padding-top: 24px; padding-bottom: 24px; }
  .deliverables  { padding-top: 32px; padding-bottom: 32px; }
  .mi-informe    { padding-top: 24px; padding-bottom: 24px; }
  .capas         { padding-top: 32px; padding-bottom: 32px; }
  .testimonios   { padding-top: 32px; padding-bottom: 32px; }
  .siguientes    { padding-top: 32px; padding-bottom: 32px; }
  .precio        { padding-top: 32px; padding-bottom: 32px; }
  .autor         { padding-top: 32px; padding-bottom: 32px; }
  .transparencia { padding-top: 32px; padding-bottom: 32px; }
  .cierre        { padding-top: 32px; padding-bottom: 32px; }

  /* "Una nota personal" sin padding vertical, lateral igual que el resto */
  .declaracion { padding: 0 25px; }
  .hero-grid, .declaracion-grid, .intro-grid, .para-quien-grid,
  .deliverables-head, .deliverables-grid, .mi-informe-grid,
  .capas-head, .capas-grid, .testimonios-head, .siguientes-grid,
  .precio-head, .precio-grid, .autor-grid,
  .transparencia-grid {
    grid-template-columns: 1fr; gap: 32px;
  }
  .precio-grid > .precio-card:first-child { grid-column: auto; }
  .hero-copy h1 { font-size: 44px; }
  .para-quien h2, .siguientes-head h2, .capas-head h2,
  .precio-head h2 { font-size: 36px; }
  .deliverables-head h2, .testimonios-head h2, .mi-informe h2 { font-size: 32px; }
  .cierre h2 { font-size: 40px; }
  .huge-num { font-size: 160px; }
  .para-quien-num { font-size: 200px; }
  .carousel-track { grid-auto-columns: 100%; }
  .declaracion-meta { padding-top: 0; }
  .autor-meta { order: 2; }
  .para-quien-list li { grid-template-columns: 40px 1fr; gap: 10px; }
  .para-quien-list .li-num { text-align: right; }
  .footer { flex-direction: column; gap: 12px; text-align: center; }

  /* Padding intern de cards a la meitat */
  .declaracion-card   { padding: 28px 32px; }
  .declaracion-grid   { gap: 0; }
  .intro-card         { padding: 24px 20px; }
  .deliverables-card  { padding: 24px 20px; }
  .capa-card          { padding: 20px 16px; min-height: 0; }
  .testimonio         { padding: 20px 16px; }
  .siguientes-card    { padding: 20px 16px; }
  .precio-card        { padding: 28px 24px; }
  .modal-box {
    width: calc(100vw - 32px);
    padding: 32px 24px;
  }
}
