/* =========================================================================
   DSAYN — Hoja de estilos · Apple-style
   Inter sola. Tipografías monumentales. Secciones full-bleed alternadas.
   Mobile-first. Sin frameworks. Custom properties + grid.
   ========================================================================= */

/* -------------------- Variables -------------------- */
:root {
  /* Color */
  --color-blue: #0066ff;
  --color-blue-light: #00d2ff;
  --color-blue-dark: #003ad6;
  --color-gradient: linear-gradient(135deg, #0066ff 0%, #00d2ff 100%);
  --color-gradient-dark: linear-gradient(135deg, #001a4d 0%, #0044cc 100%);
  --color-ink: #06070A;          /* casi negro */
  --color-text: #1d1d1f;         /* Apple ink */
  --color-text-soft: #424245;
  --color-muted: #6e6e73;        /* Apple secondary */
  --color-line: #d2d2d7;         /* Apple divider */
  --color-line-soft: #e8e8ed;
  --color-bg: #ffffff;
  --color-bg-soft: #fbfbfd;      /* Apple secondary bg */
  --color-bg-cream: #f5f5f7;     /* Apple bento bg */
  --color-bg-dark: #06070A;      /* casi negro Apple */
  --color-bg-mid: #1d1d1f;

  /* Tipografía */
  --font-display: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, sans-serif;

  /* Escala tipográfica fluida — controlada, peso por contraste no por tamaño */
  --fs-xs: 0.8125rem;
  --fs-sm: 0.9375rem;
  --fs-base: 1.0625rem;
  --fs-md: 1.25rem;
  --fs-lg: 1.5rem;
  --fs-xl: clamp(1.5rem, 1.3rem + 1vw, 2rem);            /* 24→32 */
  --fs-2xl: clamp(2rem, 1.5rem + 2.5vw, 3.25rem);        /* 32→52 */
  --fs-3xl: clamp(2.5rem, 1.8rem + 3.5vw, 4.25rem);      /* 40→68 */
  --fs-4xl: clamp(2.75rem, 1.8rem + 4.5vw, 5.25rem);     /* 44→84 — hero */

  /* Espaciado */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4rem;
  --space-9: 6rem;
  --space-10: 8rem;
  --space-11: 12rem;

  /* Radios y sombras */
  --radius-sm: 8px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --radius-xl: 40px;
  --radius-pill: 999px;
  --shadow-sm: 0 1px 3px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 12px 32px rgba(15, 23, 42, 0.06);
  --shadow-lg: 0 32px 64px rgba(15, 23, 42, 0.10);
  --shadow-blue: 0 24px 48px rgba(0, 102, 255, 0.22);

  /* Layout */
  --container: 1240px;
  --container-narrow: 920px;
  --transition: 320ms cubic-bezier(0.2, 0.8, 0.2, 1);
  --transition-slow: 600ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* -------------------- Reset minimalista -------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
}
img, svg, video { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: 0; }
a { color: var(--color-blue); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-blue-dark); }
ul { list-style: none; }
:focus-visible { outline: 3px solid var(--color-blue-light); outline-offset: 3px; border-radius: 4px; }

/* -------------------- Tipografía Apple-grade -------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--color-ink);
  line-height: 1.05;
}
h1 {
  font-size: var(--fs-4xl);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1.02;
}
h2 {
  font-size: var(--fs-3xl);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
}
h3 {
  font-size: var(--fs-xl);
  font-weight: 600;
  letter-spacing: -0.02em;
}
h4 {
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: -0.01em;
}

p { max-width: 70ch; }
p + p { margin-top: var(--space-4); }
strong { font-weight: 600; color: var(--color-ink); }
em { font-style: italic; }

/* -------------------- Layout -------------------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--space-5);
}
.container-narrow {
  width: 100%;
  max-width: var(--container-narrow);
  margin: 0 auto;
  padding-inline: var(--space-5);
}
.container-wide {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding-inline: var(--space-5);
}
@media (min-width: 720px) {
  .container-wide { padding-inline: var(--space-7); }
}
@media (min-width: 720px) {
  .container, .container-narrow { padding-inline: var(--space-7); }
}

section { padding-block: var(--space-10); }
@media (max-width: 720px) {
  section { padding-block: var(--space-8); }
}

.section-head {
  max-width: 1100px;
  margin-bottom: var(--space-9);
}
.section-head h2 {
  /* Tamaño un poco menor para que los titulares clave entren en una línea en desktop */
  font-size: clamp(2rem, 1.5rem + 2.5vw, 3rem);
  letter-spacing: -0.025em;
}
.section-head .kicker {
  display: inline-block;
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-blue);
  margin-bottom: var(--space-5);
  padding: 6px 14px;
  background: rgba(0, 102, 255, 0.08);
  border-radius: var(--radius-pill);
}
.atmosphere-dark .section-head .kicker {
  background: rgba(0, 210, 255, 0.10);
  color: var(--color-blue-light);
}
.atmosphere-blue .section-head .kicker {
  background: rgba(255, 255, 255, 0.18);
  color: white;
}
.section-head h2 + p {
  margin-top: var(--space-5);
  color: var(--color-muted);
  font-size: var(--fs-md);
  max-width: 1100px;
  line-height: 1.55;
  text-align: justify;
  text-wrap: pretty;
}
.section-head.text-center h2 + p {
  text-align: center;
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--color-ink);
  color: white;
  padding: var(--space-3) var(--space-4);
  z-index: 1000;
}
.skip-link:focus { left: var(--space-3); top: var(--space-3); }

/* Atmosferas full-bleed estilo Apple */
.atmosphere-cream { background: var(--color-bg-cream); }
.atmosphere-soft  { background: var(--color-bg-soft); }
.atmosphere-dark  { background: var(--color-bg-dark); color: #f5f5f7; }
.atmosphere-dark h1, .atmosphere-dark h2, .atmosphere-dark h3, .atmosphere-dark h4 { color: #fff; }
.atmosphere-dark .section-head .kicker { color: var(--color-blue-light); }
.atmosphere-dark .section-head h2 + p,
.atmosphere-dark p { color: rgba(245, 245, 247, 0.72); }

.atmosphere-blue {
  background: var(--color-gradient);
  color: white;
  position: relative;
  overflow: hidden;
}
.atmosphere-blue::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(40% 60% at 0% 0%, rgba(255, 255, 255, 0.18) 0%, transparent 60%),
    radial-gradient(40% 60% at 100% 100%, rgba(0, 0, 0, 0.18) 0%, transparent 60%);
  pointer-events: none;
}
.atmosphere-blue > * { position: relative; }
.atmosphere-blue h1, .atmosphere-blue h2, .atmosphere-blue h3 { color: white; }
.atmosphere-blue p { color: rgba(255, 255, 255, 0.92); }
.atmosphere-blue .section-head .kicker { color: rgba(255, 255, 255, 0.85); }

/* -------------------- Header / Nav -------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition), background var(--transition);
}
.site-header.is-scrolled {
  border-bottom-color: var(--color-line-soft);
  background: rgba(255, 255, 255, 0.92);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--space-4);
  gap: var(--space-5);
}
.nav-logo {
  display: inline-flex;
  align-items: center;
}
.nav-logo img {
  height: 56px;
  width: auto;
  transition: height var(--transition);
}
.site-header.is-scrolled .nav-logo img { height: 44px; }
@media (max-width: 720px) { .nav-logo img { height: 42px; } }

.nav-menu {
  display: flex;
  align-items: center;
  gap: var(--space-7);
}
.nav-menu a {
  color: var(--color-text);
  font-size: var(--fs-sm);
  font-weight: 500;
}
.nav-menu a:hover, .nav-menu a.is-active { color: var(--color-blue); }

.nav-toggle {
  display: none;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-ink);
  border-radius: 2px;
  position: relative;
  transition: background var(--transition);
}
.nav-toggle span::before, .nav-toggle span::after {
  content: "";
  position: absolute;
  left: 0;
  width: 22px;
  height: 2px;
  background: var(--color-ink);
  border-radius: 2px;
  transition: transform var(--transition);
}
.nav-toggle span::before { top: -7px; }
.nav-toggle span::after { top: 7px; }
.nav-toggle.is-open span { background: transparent; }
.nav-toggle.is-open span::before { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span::after  { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 880px) {
  .nav-toggle { display: inline-flex; }
  .nav-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: saturate(180%) blur(20px);
    border-bottom: 1px solid var(--color-line-soft);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition), transform var(--transition);
    padding: var(--space-4) var(--space-5);
  }
  .nav-menu.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }
  .nav-menu a { padding-block: var(--space-3); border-bottom: 1px solid var(--color-line-soft); }
  .nav-menu a:last-child { border-bottom: 0; }
  .nav-menu .btn { margin-top: var(--space-3); text-align: center; }
}

/* -------------------- Buttons Apple-style -------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.95rem 1.75rem;
  border-radius: var(--radius-pill);
  font-weight: 500;
  font-size: var(--fs-base);
  letter-spacing: -0.005em;
  transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  border: 0;
}
.btn-primary {
  background: var(--color-blue);
  color: white;
  box-shadow: var(--shadow-blue);
}
.btn-primary:hover {
  transform: translateY(-1px);
  background: var(--color-blue-dark);
  color: white;
  box-shadow: 0 28px 48px rgba(0, 102, 255, 0.32);
}
.btn-ghost {
  background: rgba(0, 102, 255, 0.06);
  color: var(--color-blue);
}
.btn-ghost:hover {
  background: rgba(0, 102, 255, 0.12);
  color: var(--color-blue-dark);
}
.btn-light {
  background: white;
  color: var(--color-blue);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.18);
}
.btn-light:hover {
  transform: translateY(-1px);
  box-shadow: 0 24px 40px rgba(0, 0, 0, 0.24);
  color: var(--color-blue-dark);
}
.btn-outline-light {
  background: transparent;
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.4);
}
.btn-outline-light:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: white;
  color: white;
}
.btn-link {
  color: var(--color-blue);
  font-weight: 500;
  font-size: var(--fs-base);
}
.btn-link::after { content: " →"; transition: transform var(--transition); display: inline-block; margin-left: 4px; }
.btn-link:hover::after { transform: translateX(6px); }

/* -------------------- Hero — dos columnas, controlado -------------------- */
.hero {
  position: relative;
  padding-block: clamp(4rem, 8vw, 7rem) clamp(3rem, 6vw, 5rem);
  overflow: hidden;
  background: var(--color-bg);
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(50% 50% at 85% 10%, rgba(0, 210, 255, 0.16) 0%, transparent 60%),
    radial-gradient(45% 55% at 5% 95%, rgba(0, 102, 255, 0.10) 0%, transparent 60%);
  pointer-events: none;
}
.hero .container { position: relative; }
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 980px) {
  .hero-grid { grid-template-columns: 70% 30%; gap: var(--space-7); }
}
.hero-kicker {
  display: inline-block;
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-blue);
  margin-bottom: var(--space-5);
  padding: 6px 14px;
  background: rgba(0, 102, 255, 0.08);
  border-radius: var(--radius-pill);
}
.hero h1 {
  margin-bottom: var(--space-6);
  max-width: 18ch;
}
.hero h1 .accent {
  background: var(--color-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 800;
}
.hero-sub {
  font-size: clamp(1.05rem, 0.85rem + 0.5vw, 1.25rem);
  color: var(--color-muted);
  margin-bottom: var(--space-7);
  max-width: 56ch;
  line-height: 1.55;
  font-weight: 400;
}
.hero-cta {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  align-items: center;
}
.hero-trust {
  margin-top: var(--space-7);
  font-size: var(--fs-xs);
  color: var(--color-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
}

/* Mockup compacto a la derecha — altura libre para no cortar el chart */
.hero-visual {
  position: relative;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(0, 102, 255, 0.05), rgba(0, 210, 255, 0.05)),
    var(--color-bg-cream);
  border: 1px solid var(--color-line-soft);
  padding: var(--space-5);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.hv-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--fs-xs);
  color: var(--color-muted);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.hv-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-blue); box-shadow: 0 0 12px rgba(0, 102, 255, 0.5); }
.hv-kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
.hv-kpi {
  background: white;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-line-soft);
}
.hv-kpi .label { font-size: 0.72rem; color: var(--color-muted); letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600; }
.hv-kpi .value {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: 4px;
  letter-spacing: -0.025em;
  line-height: 1;
}
.hv-kpi .value.up { color: var(--color-blue); }
.hv-kpi .delta { font-size: 0.72rem; color: var(--color-blue); font-weight: 600; margin-top: 4px; }
.hv-kpi .delta.down { color: #b00020; }
.hv-chart {
  background: white;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-line-soft);
  padding: var(--space-3);
  display: flex;
  align-items: end;
  gap: 6px;
  height: 110px;
  flex-shrink: 0;
}
.hv-chart .bar {
  flex: 1;
  background: var(--color-gradient);
  border-radius: 3px 3px 0 0;
  opacity: 0.9;
}

/* -------------------- Tres mundos como tarjetones -------------------- */
.pillars-intro { text-align: center; margin-inline: auto; margin-bottom: var(--space-9); }
.pillars-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 880px) {
  .pillars-grid { grid-template-columns: repeat(3, 1fr); }
}
.pillar {
  text-align: center;
  padding: var(--space-8) var(--space-6);
  border-radius: var(--radius-lg);
  background: var(--color-bg-cream);
  position: relative;
  overflow: hidden;
  min-height: 340px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: transform var(--transition), box-shadow var(--transition);
}
.pillar:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.pillar:nth-child(1) { background: linear-gradient(165deg, #f5f5f7 0%, #e0e9ff 100%); }
.pillar:nth-child(2) { background: linear-gradient(165deg, #06070A 0%, #1d2c4d 100%); color: #f5f5f7; }
.pillar:nth-child(2) h3 { color: white; }
.pillar:nth-child(2) p { color: rgba(255, 255, 255, 0.72); }
.pillar:nth-child(3) { background: linear-gradient(165deg, #0066ff 0%, #00a8ff 100%); color: white; }
.pillar:nth-child(3) h3 { color: white; }
.pillar:nth-child(3) p { color: rgba(255, 255, 255, 0.92); }

.pillar-icon {
  width: 64px;
  height: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(0, 102, 255, 0.10);
  color: var(--color-blue);
  margin-bottom: var(--space-5);
}
.pillar:nth-child(2) .pillar-icon { background: rgba(255, 255, 255, 0.12); color: var(--color-blue-light); }
.pillar:nth-child(3) .pillar-icon { background: rgba(255, 255, 255, 0.18); color: white; }
.pillar-icon svg { width: 30px; height: 30px; }
.pillar h3 {
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
  font-weight: 700;
  margin-bottom: var(--space-3);
  text-align: center;
}
.pillar p {
  font-size: var(--fs-base);
  max-width: 30ch;
  margin-inline: auto;
  text-align: center;
}

/* -------------------- Service Showcase (cada servicio = una pantalla) -------------------- */
.showcase {
  padding-block: clamp(4rem, 8vw, 8rem);
  position: relative;
  overflow: hidden;
}
.showcase-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
}
@media (min-width: 960px) {
  /* Default: texto 60%, mockup 40% */
  .showcase-grid { grid-template-columns: 58% 42%; gap: var(--space-8); }
  /* Reverse: mockup 40% izquierda, texto 60% derecha */
  .showcase-grid.reverse { grid-template-columns: 42% 58%; gap: var(--space-8); }
}

.showcase .num-tag {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: var(--space-5);
  color: var(--color-blue);
}
.atmosphere-dark .showcase .num-tag,
.atmosphere-blue .showcase .num-tag { color: rgba(255, 255, 255, 0.85); }

.showcase h2 {
  font-size: clamp(2.25rem, 1.6rem + 3vw, 4rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-5);
  max-width: 16ch;
}
.showcase .lead {
  font-size: clamp(1.1rem, 0.9rem + 0.5vw, 1.35rem);
  color: var(--color-muted);
  margin-bottom: var(--space-7);
  max-width: 50ch;
  line-height: 1.5;
}
.atmosphere-dark .showcase .lead { color: rgba(245, 245, 247, 0.92); }
.atmosphere-blue .showcase .lead { color: #ffffff; font-weight: 500; }

.showcase .features {
  margin-bottom: var(--space-7);
  display: grid;
  gap: var(--space-3);
}
.showcase .features li {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  font-size: var(--fs-base);
}
.showcase .features li::before {
  content: "→";
  color: var(--color-blue);
  font-weight: 700;
  flex-shrink: 0;
}
.atmosphere-dark .showcase .features li::before,
.atmosphere-blue .showcase .features li::before { color: var(--color-blue-light); }

/* Visual genérico para showcases — caja con mockup */
.showcase-visual {
  width: 100%;
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.atmosphere-cream .showcase-visual,
.atmosphere-soft .showcase-visual { background: white; border: 1px solid var(--color-line-soft); }
.atmosphere-dark .showcase-visual { background: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 255, 255, 0.08); }
.atmosphere-blue .showcase-visual { background: rgba(255, 255, 255, 0.10); border: 1px solid rgba(255, 255, 255, 0.18); backdrop-filter: blur(12px); }

/* ========= Visual 1: cuadro de mando — KPIs + chart de tendencia ========= */
.viz-board { gap: var(--space-4); }
.viz-board .chip {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--color-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.atmosphere-dark .viz-board .chip,
.atmosphere-blue .viz-board .chip { color: rgba(255, 255, 255, 0.7); }

.viz-board .kpi-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
}
.viz-board .kpi {
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  padding: var(--space-3);
}
.atmosphere-dark .viz-board .kpi { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.08); }
.atmosphere-blue .viz-board .kpi { background: rgba(255, 255, 255, 0.10); border-color: rgba(255, 255, 255, 0.18); }
.viz-board .kpi .lbl { font-size: 0.7rem; color: var(--color-muted); letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600; }
.atmosphere-dark .viz-board .kpi .lbl,
.atmosphere-blue .viz-board .kpi .lbl { color: rgba(255, 255, 255, 0.7); }
.viz-board .kpi .val {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-top: 4px;
  color: var(--color-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.atmosphere-dark .viz-board .kpi .val,
.atmosphere-blue .viz-board .kpi .val { color: white; }
.viz-board .kpi .delta { font-size: 0.7rem; color: var(--color-blue); font-weight: 600; margin-top: 2px; }
.atmosphere-dark .viz-board .kpi .delta,
.atmosphere-blue .viz-board .kpi .delta { color: var(--color-blue-light); }

.viz-board .trend {
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  display: flex;
  align-items: end;
  gap: 5px;
  height: 80px;
}
.atmosphere-dark .viz-board .trend { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.08); }
.atmosphere-blue .viz-board .trend { background: rgba(255, 255, 255, 0.10); border-color: rgba(255, 255, 255, 0.18); }
.viz-board .trend .bar {
  flex: 1;
  background: var(--color-gradient);
  border-radius: 3px 3px 0 0;
  opacity: 0.85;
  min-height: 8%;
}
.atmosphere-dark .viz-board .trend .bar,
.atmosphere-blue .viz-board .trend .bar { background: linear-gradient(180deg, var(--color-blue-light), rgba(0, 210, 255, 0.4)); }

/* ========= Visual 1B: ranking por segmentos — Cuadro de mando (distinto del hero) ========= */
.viz-segments { gap: var(--space-4); }
.viz-segments .chip {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--color-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.viz-segments .seg-list { display: grid; gap: var(--space-3); }
.viz-segments .seg {
  display: grid;
  grid-template-columns: 110px 1fr 50px;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--fs-sm);
}
.viz-segments .seg .name { color: var(--color-text); font-weight: 500; font-size: 0.85rem; }
.viz-segments .seg .pct {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--color-blue);
  text-align: right;
  font-size: 0.95rem;
  letter-spacing: -0.01em;
}
.viz-segments .seg .bar-wrap {
  background: rgba(0, 102, 255, 0.08);
  border-radius: var(--radius-pill);
  height: 10px;
  overflow: hidden;
}
.viz-segments .seg .bar-fill {
  height: 100%;
  background: var(--color-gradient);
  border-radius: var(--radius-pill);
}
.viz-segments .seg-footer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  padding-top: var(--space-3);
  margin-top: var(--space-3);
  border-top: 1px solid var(--color-line-soft);
}
.viz-segments .seg-footer .lbl {
  display: block;
  font-size: 0.7rem;
  color: var(--color-muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 2px;
}
.viz-segments .seg-footer .val {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-ink);
}
.viz-segments .seg-footer .val.up { color: var(--color-blue); }

/* ========= Visual 2: KPIs financieros — para Análisis financiero ========= */
.viz-fin { gap: var(--space-3); }
.viz-fin .chip {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.78);
}
.viz-fin .grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
.viz-fin .card {
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}
.atmosphere-cream .viz-fin .card,
.atmosphere-soft .viz-fin .card {
  background: white;
  border-color: var(--color-line-soft);
}
.viz-fin .card .lbl {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.7);
}
.atmosphere-cream .viz-fin .card .lbl,
.atmosphere-soft .viz-fin .card .lbl { color: var(--color-muted); }
.viz-fin .card .val {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-top: 6px;
  color: white;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.atmosphere-cream .viz-fin .card .val,
.atmosphere-soft .viz-fin .card .val { color: var(--color-ink); }
.viz-fin .card .spark {
  display: flex;
  align-items: end;
  gap: 2px;
  height: 22px;
  margin-top: 6px;
}
.viz-fin .card .spark span {
  flex: 1;
  background: var(--color-blue-light);
  border-radius: 1px;
  opacity: 0.9;
  min-height: 12%;
}
.atmosphere-cream .viz-fin .card .spark span,
.atmosphere-soft .viz-fin .card .spark span { background: var(--color-blue); }
.viz-fin .card .delta {
  font-size: 0.7rem;
  font-weight: 600;
  margin-top: 4px;
  color: var(--color-blue-light);
}
.atmosphere-cream .viz-fin .card .delta,
.atmosphere-soft .viz-fin .card .delta { color: var(--color-blue); }

/* ========= Visual 3: antes / después — números compactos, sin desbordar ========= */
.viz-vs {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-3);
  align-items: stretch;
}
.viz-vs > .arrow-vs {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--color-blue-light);
  font-weight: 700;
}
.viz-vs > .before,
.viz-vs > .after {
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 0;
}
.viz-vs .before {
  background: rgba(176, 0, 32, 0.08);
  border: 1px solid rgba(176, 0, 32, 0.18);
}
.viz-vs .after {
  background: rgba(0, 102, 255, 0.10);
  border: 1px solid rgba(0, 102, 255, 0.22);
}
.atmosphere-dark .viz-vs .before { background: rgba(255, 100, 100, 0.08); border-color: rgba(255, 100, 100, 0.20); }
.atmosphere-dark .viz-vs .after { background: rgba(0, 210, 255, 0.10); border-color: rgba(0, 210, 255, 0.24); }
.viz-vs .label { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 4px; }
.viz-vs .before .label { color: #b00020; }
.viz-vs .after .label  { color: var(--color-blue); }
.atmosphere-dark .viz-vs .before .label { color: #ff8a8a; }
.atmosphere-dark .viz-vs .after  .label { color: var(--color-blue-light); }
.viz-vs .num {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 1.6rem + 3vw, 4.5rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-block: 6px 10px;
}
.viz-vs .desc { font-size: 0.85rem; color: rgba(255, 255, 255, 0.78); line-height: 1.45; }

/* -------------------- Stack tecnológico (logos reales) -------------------- */
.stack-section {
  padding-block: var(--space-8);
  border-top: 1px solid var(--color-line-soft);
  border-bottom: 1px solid var(--color-line-soft);
  background: var(--color-bg);
}
.stack-head {
  text-align: center;
  margin-bottom: var(--space-7);
}
.stack-head .kicker {
  display: inline-block;
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-blue);
  padding: 6px 14px;
  background: rgba(0, 102, 255, 0.08);
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-3);
}
.stack-head p {
  font-size: var(--fs-md);
  color: var(--color-muted);
  margin: var(--space-3) auto 0;
  max-width: 56ch;
}
.stack-head h3 {
  font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--color-ink);
}

.stack-logos {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5) var(--space-6);
  align-items: center;
  justify-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
@media (min-width: 720px) { .stack-logos { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1080px) { .stack-logos { grid-template-columns: repeat(6, 1fr); } }
.stack-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  filter: grayscale(20%);
  opacity: 0.85;
  transition: filter var(--transition), opacity var(--transition), transform var(--transition);
}
.stack-item:hover {
  filter: grayscale(0%);
  opacity: 1;
  transform: translateY(-3px);
}
.stack-item svg { width: 44px; height: 44px; }
.stack-item .name {
  font-size: var(--fs-xs);
  color: var(--color-muted);
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* -------------------- Bloque "qué cambia" — conceptos -------------------- */
.benefit-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 880px) { .benefit-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-5); } }

.benefit-card {
  background: white;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6);
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  position: relative;
  overflow: hidden;
}
.benefit-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--color-gradient);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 400ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
.benefit-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: transparent;
}
.benefit-card:hover::before { transform: scaleX(1); }

.benefit-card .icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: rgba(0, 102, 255, 0.08);
  color: var(--color-blue);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-5);
}
.benefit-card .icon svg { width: 26px; height: 26px; }
.benefit-card h3 {
  font-size: clamp(1.75rem, 1.4rem + 1.2vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  margin-bottom: var(--space-3);
  color: var(--color-ink);
}
.benefit-card p {
  font-size: var(--fs-base);
  color: var(--color-muted);
  line-height: 1.55;
  margin: 0;
}

/* -------------------- Sobre -------------------- */
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 880px) {
  .about-grid { grid-template-columns: 70% 30%; gap: var(--space-7); align-items: center; }
}
.about-text h2 {
  font-size: clamp(2rem, 1.4rem + 2.5vw, 3.5rem);
  margin-bottom: var(--space-5);
  max-width: 18ch;
}
.about-text p { font-size: var(--fs-md); color: var(--color-text-soft); margin-bottom: var(--space-5); max-width: 56ch; }
.about-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-8);
  margin-top: var(--space-7);
  padding-top: var(--space-7);
  border-top: 1px solid var(--color-line);
  text-align: center;
}
.about-stats .stat { min-width: 110px; }
.stat .num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 2vw, 3rem);
  font-weight: 800;
  color: var(--color-blue);
  letter-spacing: -0.03em;
  line-height: 1;
}
.stat .label {
  display: block;
  font-size: var(--fs-xs);
  color: var(--color-muted);
  margin-top: var(--space-2);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
}
.about-photo {
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  aspect-ratio: 1 / 1;
  box-shadow: var(--shadow-lg);
  background: var(--color-bg-cream);
  max-width: 220px;
  margin-inline: auto;
  width: 100%;
}
.about-photo picture, .about-photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 28%;
}
.about-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  box-shadow: inset 0 0 0 4px white, inset 0 0 0 5px rgba(0, 102, 255, 0.18);
  pointer-events: none;
}
@media (max-width: 720px) { .about-photo { max-width: 180px; } }

/* -------------------- Cómo trabajamos / principios -------------------- */
.principles-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
}
@media (min-width: 880px) { .principles-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); } }
@media (min-width: 1200px) { .principles-grid { grid-template-columns: repeat(4, 1fr); } }
.principle {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: white;
  border: 1px solid var(--color-line-soft);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
  position: relative;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
@media (min-width: 1200px) {
  .principle {
    grid-template-columns: 1fr;
    text-align: left;
  }
  /* Conector de proceso entre pasos */
  .principle::after {
    content: "";
    position: absolute;
    top: 50%;
    right: calc(var(--space-3) * -1);
    width: var(--space-5);
    height: 2px;
    background: linear-gradient(90deg, rgba(0, 102, 255, 0.3), transparent);
    transform: translateY(-50%);
    pointer-events: none;
  }
  .principle:last-child::after { display: none; }
}
.principle:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(0, 102, 255, 0.3);
}

/* Stagger MÁS lento y dramático específicamente para procesos */
.principles-grid.stagger.is-visible > *:nth-child(1) { transition-delay: 100ms; }
.principles-grid.stagger.is-visible > *:nth-child(2) { transition-delay: 350ms; }
.principles-grid.stagger.is-visible > *:nth-child(3) { transition-delay: 600ms; }
.principles-grid.stagger.is-visible > *:nth-child(4) { transition-delay: 850ms; }
.principle .num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 2vw, 3rem);
  font-weight: 800;
  background: var(--color-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.03em;
  line-height: 1;
}
.principle h3 { font-size: var(--fs-lg); font-weight: 600; margin-bottom: var(--space-3); }
.principle p { font-size: var(--fs-base); color: var(--color-muted); }

/* -------------------- ICP / Para quién -------------------- */
.fit-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 880px) { .fit-grid { grid-template-columns: repeat(2, 1fr); } }
.fit-card {
  padding: var(--space-7);
  border-radius: var(--radius-lg);
  background: white;
  border: 1px solid var(--color-line-soft);
  transition: transform var(--transition), box-shadow var(--transition);
}
.fit-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.fit-card.yes { border-top: 4px solid var(--color-blue); }
.fit-card.no  { border-top: 4px solid var(--color-line); }
.fit-card h3 { font-size: var(--fs-lg); font-weight: 600; margin-bottom: var(--space-4); }
.fit-card .label {
  display: inline-block;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-4);
}
.fit-card.yes .label { background: rgba(0, 102, 255, 0.10); color: var(--color-blue); }
.fit-card.no .label  { background: var(--color-bg-cream); color: var(--color-muted); }

/* -------------------- CTA final monumental -------------------- */
.cta-final {
  padding-block: clamp(5rem, 10vw, 9rem);
  text-align: center;
}
.cta-final h2 {
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 3.25rem);
  margin-bottom: var(--space-6);
  max-width: none;
  margin-inline: auto;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
}
.cta-final p { font-size: var(--fs-md); margin: 0 auto var(--space-7); max-width: none; }
.cta-final .btn { font-size: var(--fs-md); padding: 1.05rem 2rem; }
.cta-meta {
  margin-top: var(--space-9);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.cta-meta .btn-meta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.7rem 1.25rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: white;
  font-weight: 500;
  font-size: var(--fs-sm);
  text-decoration: none;
  transition: background var(--transition), transform var(--transition);
  backdrop-filter: blur(8px);
}
.cta-meta .btn-meta:hover {
  background: rgba(255, 255, 255, 0.20);
  color: white;
  transform: translateY(-1px);
}
.cta-meta .btn-meta svg { width: 18px; height: 18px; }

/* -------------------- Bullet list -------------------- */
.bullet-list { display: grid; gap: var(--space-3); margin-top: var(--space-3); }
.bullet-list li {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  font-size: var(--fs-base);
  color: var(--color-text);
  line-height: 1.55;
}
.bullet-list li::before {
  content: "";
  flex-shrink: 0;
  width: 6px; height: 6px;
  margin-top: 0.65em;
  border-radius: 50%;
  background: var(--color-blue);
}

/* -------------------- Contacto (página) -------------------- */
.contact {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 880px) { .contact { grid-template-columns: 0.9fr 1.1fr; gap: var(--space-9); } }
.contact-info > p { font-size: var(--fs-md); color: var(--color-muted); margin-bottom: var(--space-7); max-width: 50ch; }
.contact-list { display: grid; gap: var(--space-5); margin-top: var(--space-7); }
.contact-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-3) 0;
}
.contact-item .value {
  font-size: var(--fs-md);
  color: var(--color-ink);
  font-weight: 500;
}
.contact-item .value a { color: var(--color-ink); }
.contact-item .value a:hover { color: var(--color-blue); }

.conversation-card {
  margin-top: var(--space-6);
  padding: var(--space-5) var(--space-5);
  background: rgba(0, 102, 255, 0.05);
  border: 1px solid rgba(0, 102, 255, 0.14);
  border-radius: var(--radius-md);
}
.conversation-card .kicker-pill {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-blue);
  margin-bottom: var(--space-3);
  background: white;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
}
.conversation-card .bullet-list { gap: var(--space-2); }
.conversation-card .bullet-list li {
  font-size: var(--fs-sm);
  color: var(--color-text);
  font-weight: 400;
  line-height: 1.5;
}
.conversation-card .bullet-list li::before {
  background: var(--color-blue);
  width: 5px; height: 5px;
}
.contact-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: rgba(0, 102, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-blue);
}
.contact-icon svg { width: 18px; height: 18px; }
.contact-item .label { font-size: var(--fs-xs); color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.contact-item .value { font-size: var(--fs-base); color: var(--color-ink); font-weight: 500; }
.contact-item .value a { color: var(--color-ink); }
.contact-item .value a:hover { color: var(--color-blue); }

.contact-form {
  background: var(--color-bg-cream);
  padding: var(--space-8) var(--space-7);
  border-radius: var(--radius-lg);
}
.field { margin-bottom: var(--space-5); }
.field label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.field input,
.field textarea,
.field select {
  width: 100%;
  padding: 0.95rem 1.15rem;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: white;
  font-size: var(--fs-base);
  color: var(--color-ink);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: var(--color-blue);
  box-shadow: 0 0 0 4px rgba(0, 102, 255, 0.10);
  outline: none;
}
.field textarea { min-height: 160px; resize: vertical; }
.field-check { display: flex; gap: var(--space-3); align-items: flex-start; font-size: var(--fs-sm); color: var(--color-muted); }
.field-check input { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; }
.field-check a { color: var(--color-blue); text-decoration: underline; text-underline-offset: 3px; }
.form-note { font-size: var(--fs-xs); color: var(--color-muted); margin-top: var(--space-4); }

/* -------------------- Páginas legales -------------------- */
.legal-page {
  padding-block: var(--space-9) var(--space-10);
  background: var(--color-bg);
}
.legal-page h1 { margin-bottom: var(--space-5); font-size: var(--fs-2xl); }
.legal-page h2 {
  font-size: var(--fs-lg);
  font-weight: 600;
  margin-top: var(--space-8);
  margin-bottom: var(--space-4);
  color: var(--color-ink);
  letter-spacing: -0.01em;
}
.legal-page p, .legal-page li { color: var(--color-text); margin-bottom: var(--space-3); font-size: var(--fs-sm); line-height: 1.7; }
.legal-page ul { padding-left: var(--space-5); list-style: disc; }
.legal-page ul li::marker { color: var(--color-blue); }
.legal-page table { width: 100%; border-collapse: collapse; margin-block: var(--space-5); font-size: var(--fs-sm); }
.legal-page th, .legal-page td { text-align: left; padding: var(--space-3); border-bottom: 1px solid var(--color-line-soft); vertical-align: top; }
.legal-page th { background: var(--color-bg-cream); font-weight: 600; color: var(--color-ink); }
.legal-page .updated { color: var(--color-muted); font-size: var(--fs-xs); margin-top: var(--space-8); padding-top: var(--space-5); border-top: 1px solid var(--color-line-soft); }

/* -------------------- Footer -------------------- */
.site-footer {
  background: var(--color-bg-dark);
  color: rgba(245, 245, 247, 0.7);
  padding-block: var(--space-8) var(--space-5);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-7);
}
@media (min-width: 720px) {
  .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-7); }
}
.footer-brand img { height: 48px; width: auto; margin-bottom: var(--space-5); filter: brightness(0) invert(1); }
.footer-brand p { font-size: var(--fs-sm); max-width: 36ch; }
.site-footer h4 {
  color: white;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.footer-list li { margin-bottom: var(--space-2); }
.footer-list a { color: rgba(245, 245, 247, 0.7); font-size: var(--fs-sm); }
.footer-list a:hover { color: var(--color-blue-light); }
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: var(--space-5);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  font-size: var(--fs-xs);
  color: rgba(245, 245, 247, 0.5);
}

/* -------------------- Página servicios (cajas dinámicas) -------------------- */
.service-detail {
  padding-block: clamp(4rem, 8vw, 8rem);
  position: relative;
}
.service-detail-head {
  text-align: left;
  margin-bottom: var(--space-9);
  max-width: 1100px;
}
.service-detail-head h2 {
  font-size: clamp(1.75rem, 1.2rem + 2.5vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-5);
  max-width: none;
  text-wrap: balance;
}
.service-detail-head .promise {
  font-size: clamp(1.05rem, 0.9rem + 0.4vw, 1.25rem);
  color: var(--color-text-soft);
  font-weight: 500;
  line-height: 1.6;
  margin: 0;
  max-width: 1100px;
  text-align: justify;
  text-wrap: pretty;
}
.atmosphere-cream .service-detail-head .promise,
.atmosphere-soft .service-detail-head .promise { color: var(--color-text); }
.atmosphere-dark .service-detail-head .promise { color: rgba(245,245,247,0.85); }
.atmosphere-blue .service-detail-head .promise { color: rgba(255,255,255,0.92); }

.service-detail-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 720px) { .service-detail-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); } }
@media (min-width: 1080px) { .service-detail-grid { grid-template-columns: repeat(3, 1fr); } }

.detail-card {
  background: white;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.atmosphere-cream .detail-card { background: white; }
.atmosphere-dark .detail-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.10); }
.atmosphere-blue .detail-card { background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.20); backdrop-filter: blur(8px); }

.detail-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(0, 102, 255, 0.30);
}
.detail-card .heading {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.detail-card .heading .icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(0,102,255,0.10);
  color: var(--color-blue);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.atmosphere-dark .detail-card .heading .icon,
.atmosphere-blue .detail-card .heading .icon { background: rgba(255,255,255,0.14); color: var(--color-blue-light); }
.detail-card .heading .icon svg { width: 18px; height: 18px; }
.detail-card .heading h4 {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--color-ink);
  margin: 0;
}
.atmosphere-dark .detail-card .heading h4,
.atmosphere-blue .detail-card .heading h4 { color: white; }
.detail-card ul, .detail-card ol { display: grid; gap: var(--space-2); margin: 0; }
.detail-card li {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--color-text);
}
.atmosphere-dark .detail-card li { color: rgba(245,245,247,0.85); }
.atmosphere-blue .detail-card li { color: rgba(255,255,255,0.95); }
.detail-card li::before {
  content: "";
  flex-shrink: 0;
  width: 5px; height: 5px;
  margin-top: 0.65em;
  border-radius: 50%;
  background: var(--color-blue);
}
.atmosphere-dark .detail-card li::before,
.atmosphere-blue .detail-card li::before { background: var(--color-blue-light); }
.detail-card code {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: 0.86em;
  background: rgba(0, 102, 255, 0.10);
  color: var(--color-blue);
  padding: 1px 6px;
  border-radius: 6px;
  word-break: break-word;
}
/* Flow list — alineación tabular del verbo inicial */
.detail-card ul.flow-list li strong {
  display: inline-block;
  min-width: 5.5em;
  color: var(--color-ink);
  font-weight: 700;
}

/* Énfasis en el "NO" — decir NO rápido es parte del servicio */
.emph-no {
  display: inline-block;
  font-weight: 800;
  color: var(--color-blue);
  background: rgba(0, 102, 255, 0.10);
  padding: 0 8px;
  border-radius: 6px;
  letter-spacing: 0.02em;
  font-size: 1.05em;
}
.atmosphere-blue .emph-no {
  background: rgba(255, 255, 255, 0.22);
  color: white;
}
.atmosphere-dark .emph-no {
  background: rgba(0, 210, 255, 0.18);
  color: var(--color-blue-light);
}
.atmosphere-dark .detail-card ul.flow-list li strong,
.atmosphere-blue .detail-card ul.flow-list li strong { color: white; }
.atmosphere-dark .detail-card code,
.atmosphere-blue .detail-card code {
  background: rgba(0, 210, 255, 0.18);
  color: var(--color-blue-light);
}

.timeline-tag {
  display: inline-flex;
  align-items: center;
  padding: 12px 22px;
  background: rgba(0, 102, 255, 0.08);
  color: var(--color-blue);
  border: 1px solid rgba(0, 102, 255, 0.20);
  border-radius: var(--radius-pill);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: -0.005em;
  margin: var(--space-2);
  transition: transform var(--transition), background var(--transition);
}
.timeline-tag:hover {
  transform: translateY(-2px);
  background: rgba(0, 102, 255, 0.14);
}
.atmosphere-dark .timeline-tag {
  background: rgba(0, 210, 255, 0.10);
  border-color: rgba(0, 210, 255, 0.32);
  color: var(--color-blue-light);
}
.atmosphere-dark .timeline-tag:hover { background: rgba(0, 210, 255, 0.18); }
.atmosphere-blue .timeline-tag {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.32);
  color: white;
}
.atmosphere-blue .timeline-tag:hover { background: rgba(255, 255, 255, 0.26); }

.service-cta {
  margin-top: var(--space-9);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}
.service-cta .timeline-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  margin-bottom: var(--space-5);
}

/* -------------------- Helpers -------------------- */
.text-center { text-align: center; }
.muted { color: var(--color-muted); }

/* -------------------- Animaciones -------------------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal, .reveal-up, .reveal-left, .reveal-right, .reveal-zoom, .fade-up {
    opacity: 0;
    transition:
      opacity 1100ms cubic-bezier(0.2, 0.7, 0.2, 1),
      transform 1200ms cubic-bezier(0.2, 0.7, 0.2, 1);
    will-change: opacity, transform;
  }
  .reveal-up, .fade-up   { transform: translateY(60px); }
  .reveal-left           { transform: translateX(-80px); }
  .reveal-right          { transform: translateX(80px); }
  .reveal-zoom           { transform: scale(0.92); }

  .reveal.is-visible,
  .reveal-up.is-visible,
  .reveal-left.is-visible,
  .reveal-right.is-visible,
  .reveal-zoom.is-visible,
  .fade-up.is-visible { opacity: 1; transform: none; }

  .stagger > * {
    opacity: 0;
    transform: translateY(32px);
    transition:
      opacity 800ms cubic-bezier(0.2, 0.7, 0.2, 1),
      transform 900ms cubic-bezier(0.2, 0.7, 0.2, 1);
  }
  .stagger.is-visible > *           { opacity: 1; transform: none; }
  .stagger.is-visible > *:nth-child(1) { transition-delay: 80ms; }
  .stagger.is-visible > *:nth-child(2) { transition-delay: 200ms; }
  .stagger.is-visible > *:nth-child(3) { transition-delay: 320ms; }
  .stagger.is-visible > *:nth-child(4) { transition-delay: 440ms; }
  .stagger.is-visible > *:nth-child(5) { transition-delay: 560ms; }
  .stagger.is-visible > *:nth-child(6) { transition-delay: 680ms; }
  .stagger.is-visible > *:nth-child(7) { transition-delay: 800ms; }
  .stagger.is-visible > *:nth-child(8) { transition-delay: 920ms; }
}

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-up, .reveal-left, .reveal-right, .reveal-zoom, .fade-up,
  .stagger > * { opacity: 1 !important; transform: none !important; }
}
