/* mapa-estelar.css — "el mapa estelar." El ecosistema como carta de navegación:
   un fly-through HORIZONTAL por 4 sistemas (un servicio cada uno) sobre un plano
   orbital inclinado. Siempre oscuro (como el hero/footer); los planetas son ASCII
   (ascii-planet.js), el HUD vive en el DOM. Cada sistema tiene su propio sol en su
   color de categoría; el color sólo florece en el sistema enfocado (lock 85/15).
   Lenguaje de la casa: anillos punteados, crosshair de puntos, Cera Pro tabular. */

.mapa {
  position: relative;
  height: calc(var(--mapa-largo, 4) * 100vh);
  background: transparent;
  /* se solapa con la salida del manifiesto: el mapa se fija casi al instante en
     que el punto llega al centro — elimina el scroll muerto entre los dos puntos. */
  margin-top: -92vh;
}
.mapa.static { margin-top: 0; }
/* (sin puente ni campo propio: el fondo único es .galaxy-bg, fijo detrás de
   TODO el flujo — manifiesto, galaxia y secciones comparten una sola atmósfera) */
.mapa::before { display: none; }
.mapa-sticky {
  position: sticky; top: 0; height: 100vh; height: 100svh;
  overflow: hidden;
  background: transparent;
  color: #e8e4d8;
  -webkit-font-smoothing: antialiased;
}

/* ── starfield de puntos en parallax (canvas) ─────────────────────────────── */
.mapa-stars { position: absolute; inset: 0; z-index: 0; pointer-events: none; }

/* ── WARP de entrada (hiperespacio + iris) — primera fase del MISMO scroll ── */
.mapa-warp-layer { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.mapa-warp { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.mapa-warp-cue {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, calc(-50% - 7vh));
  display: flex; flex-direction: column; align-items: center; gap: 13px;
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(11px, 1.1vw, 13px); letter-spacing: 0.34em; text-transform: uppercase;
  color: color-mix(in srgb, #f5f4ef 78%, transparent);
  opacity: 0; text-align: center; white-space: nowrap; text-shadow: 0 1px 18px rgba(0,0,0,.6);
}
.mapa-warp-sub { color: var(--cat-sienna, #BA6849); letter-spacing: 0.22em; }
/* incentivo de scroll: un punto sienna que viaja hacia abajo (hermano del hero) */
.mapa-warp-ar { width: 1px; height: 30px; position: relative; background: color-mix(in srgb, #f5f4ef 20%, transparent); }
.mapa-warp-ar::after {
  content: ""; position: absolute; left: 50%; top: 0; width: 5px; height: 5px; margin-left: -2.5px;
  border-radius: 50%; background: var(--cat-sienna, #BA6849);
  animation: warpScrollDot 1.9s var(--ease-out, ease-out) infinite;
}
@keyframes warpScrollDot {
  0% { transform: translateY(-8px); opacity: 0; }
  30% { opacity: 1; }
  75% { opacity: 1; }
  100% { transform: translateY(30px); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) { .mapa-warp-ar::after { animation: none; opacity: 1; } }
.mapa.static .mapa-warp-layer { display: none; }

/* el chrome de la carta (título, esquinas, riel) se desvanece durante el warp y
   aparece con la galaxia. La PISTA de scroll queda visible siempre — incentiva
   al usuario a seguir bajando durante el hiperespacio. */
.mapa:not(.static) .mapa-titleblock,
.mapa:not(.static) .mapa-corner { opacity: var(--mapa-chrome, 1); }
.mapa:not(.static) .mapa-warp-layer { opacity: var(--mapa-chrome, 1); }
.mapa:not(.static) .mapa-hud { opacity: var(--mapa-chrome, 1); }

/* ── chrome de carta (esquinas fijas) ─────────────────────────────────────── */
.mapa-corner {
  position: absolute; z-index: 6;
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(9px, 0.85vw, 11px); letter-spacing: 0.16em; text-transform: uppercase;
  color: #6f6a60; user-select: none; pointer-events: none;
  display: inline-flex; align-items: center; gap: .6em;
}
.mapa-corner .cdot { width: 4px; height: 4px; border-radius: 50%; background: var(--sys-cat, #BA6849); flex: none; transition: background .5s var(--ease-out); }
.mapa-corner.tl { top: clamp(16px, 3vh, 30px); left: clamp(16px, 3vw, 36px); }
.mapa-corner.tr { top: clamp(16px, 3vh, 30px); right: clamp(16px, 3vw, 36px); color: #8a857a; }
.mapa-corner.bl { bottom: clamp(16px, 3vh, 30px); left: clamp(16px, 3vw, 36px); }
.mapa-corner .tnum { font-variant-numeric: tabular-nums; color: #b8b2a6; }

/* título de sección (centrado arriba — encabezado discreto; el protagonista es
   el servicio enfocado, no el título) */
.mapa-titleblock { position: absolute; z-index: 6; top: clamp(88px, 13vh, 132px); left: 50%; transform: translateX(-50%); text-align: center; max-width: min(92vw, 680px); pointer-events: none; }
.mapa-eyebrow {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: #8a857a;
  display: inline-flex; align-items: center; gap: .7em; margin: 0;
}
.mapa-eyebrow .pip { width: 5px; height: 5px; border-radius: 50%; background: var(--cat-sienna); flex: none; }
.mapa-title {
  font-family: var(--type-family-workhorse); font-weight: 800;
  font-size: clamp(19px, 2.3vw, 32px); line-height: 1; letter-spacing: -0.025em;
  color: #e8e4d8; margin: 0; white-space: nowrap;
}
.mapa-title .dot { color: var(--cat-sienna); }
/* lead explícito: deja claro que cada planeta = un servicio */
.mapa-lead {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(13px, 1.2vw, 15.5px); line-height: 1.4;
  color: #9a948a; margin: .7em auto 0; max-width: 42ch; text-wrap: pretty;
}
.mapa-lead b { color: #cfc9bd; font-weight: 700; }

/* ── el escenario (cámara) ────────────────────────────────────────────────── */
.mapa-stage { position: absolute; inset: 0; z-index: 2; overflow: hidden; }
.mapa-plane { position: absolute; inset: 0; }
/* evita el flash de los 4 sistemas apilados antes de que el JS los coloque */
.mapa:not(.static) .sys, .mapa:not(.static) .mapa-hud { opacity: 0; }

/* ── un sistema (posición/escala 3D las pone el JS por frame) ─────────────── */
.sys {
  position: absolute; top: 0; left: 0;
  display: grid; place-items: center;
  transform-origin: 50% 50%;
  will-change: transform, opacity;
}

/* plano orbital inclinado: una elipse de PUNTOS (el plano del sistema) */
.sys-orbit, .sys-orbit-2 {
  position: absolute; left: 50%; top: 50%;
  border-radius: 50%; pointer-events: none;
  transform: translate(-50%, -50%) rotateX(67deg) rotate(-8deg);
  background:
    radial-gradient(circle, var(--edge) 1px, transparent 1.7px) 0 0 / 10px 10px;
  -webkit-mask: radial-gradient(circle, transparent calc(50% - 1.4px), #000 calc(50% - 1.4px), #000 50%, transparent 50%);
          mask: radial-gradient(circle, transparent calc(50% - 1.4px), #000 calc(50% - 1.4px), #000 50%, transparent 50%);
  --edge: color-mix(in srgb, var(--sys-c, #888) 44%, transparent);
  opacity: .62; transition: opacity .5s var(--ease-out);
}
.sys-orbit   { width: 116%; height: 116%; transform: translate(-50%, -50%) rotateX(67deg) rotate(-8deg); }
.sys-orbit-2 { width: 154%; height: 154%; transform: translate(-50%, -50%) rotateX(67deg) rotate(-8deg); --edge: color-mix(in srgb, var(--sys-c, #888) 24%, transparent); }
.sys.is-focus .sys-orbit, .sys.is-focus .sys-orbit-2 { opacity: 1; }

/* el sol del sistema (su color de categoría), con corona de puntos */
.sys-sun {
  position: absolute; left: var(--sun-left, 76%); top: var(--sun-top, 28%); z-index: 1;
  width: 13px; height: 13px; border-radius: 50%;
  transform: translate(-50%, -50%);
  background: var(--sys-c);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--sys-c) 40%, transparent),
    0 0 22px 4px color-mix(in srgb, var(--sys-c) 70%, transparent);
}
@media (prefers-reduced-motion: no-preference) {
  .sys.is-focus .sys-sun { animation: sunPulse 4.5s var(--ease-out, ease-in-out) infinite; }
}
@keyframes sunPulse { 0%,100% { transform: translate(-50%,-50%) scale(1); } 50% { transform: translate(-50%,-50%) scale(1.22); } }

/* el planeta ASCII */
.sys-planet { position: relative; z-index: 2; display: block; }

/* glow de categoría DETRÁS del orbe — hace que el planeta enfocado resalte */
.sys-glow {
  position: absolute; left: 50%; top: 50%; width: 128%; height: 128%; z-index: 0;
  transform: translate(-50%, -50%); border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle,
    color-mix(in srgb, var(--sys-c) 58%, transparent) 0%,
    color-mix(in srgb, var(--sys-c) 24%, transparent) 34%,
    transparent 68%);
  filter: blur(20px); opacity: .18;
  transition: opacity .6s var(--ease-out);
}
.sys.is-focus .sys-glow { opacity: .72; }
@media (prefers-reduced-motion: no-preference) {
  .sys.is-focus .sys-glow { animation: glowBreathe 5s var(--ease-out, ease-in-out) infinite; }
}
@keyframes glowBreathe {
  0%, 100% { opacity: .58; transform: translate(-50%, -50%) scale(1); }
  50% { opacity: .82; transform: translate(-50%, -50%) scale(1.09); }
}

/* ── vibe único por servicio: cada planeta tiene su propia firma alrededor ──
   web = radar/escaneo · e-commerce = satélite en órbita ·
   brand = constelación que titila · continuo = anillos de Saturno. */
.sys-vibe { position: absolute; left: 50%; top: 50%; width: 100%; height: 100%; transform: translate(-50%, -50%); z-index: 1; pointer-events: none; opacity: 0; transition: opacity .6s var(--ease-out); }
.sys.is-focus .sys-vibe { opacity: .92; }
@keyframes vibeSpin { to { transform: translate(-50%, -50%) rotate(360deg); } }
@keyframes vibeTwinkle { 0%, 100% { opacity: .28; } 50% { opacity: 1; } }

/* web · anillo punteado que gira (radar / escaneo) */
.sys--web .sys-vibe { width: 152%; height: 152%; }
.sys--web.is-focus .sys-vibe { animation: vibeSpin 18s linear infinite; }
.sys--web .sys-vibe::before {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  border: 1px dashed color-mix(in srgb, var(--sys-c) 42%, transparent);
}

/* e-commerce · satélite que orbita un anillo tenue */
.sys--ecommerce .sys-vibe { width: 162%; height: 162%; }
.sys--ecommerce.is-focus .sys-vibe { animation: vibeSpin 11s linear infinite; }
.sys--ecommerce .sys-vibe::before {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--sys-c) 22%, transparent);
}
.sys--ecommerce .sys-vibe::after {
  content: ""; position: absolute; left: 50%; top: -5px; width: 9px; height: 9px; margin-left: -4.5px;
  border-radius: 50%; background: var(--sys-c);
  box-shadow: 0 0 12px 1px color-mix(in srgb, var(--sys-c) 72%, transparent);
}

/* brand · constelación de chispas que titilan (acento de la casa) */
.sys--brand .sys-vibe::before {
  content: ""; position: absolute; left: 50%; top: 50%; width: 3px; height: 3px; border-radius: 50%;
  background: var(--sys-c);
  box-shadow:
    -118px -64px 0 0 var(--sys-c), 104px -86px 0 0 color-mix(in srgb, var(--sys-c) 70%, transparent),
    138px 60px 0 0 var(--sys-c), -92px 96px 0 0 color-mix(in srgb, var(--sys-c) 65%, transparent),
    16px -132px 0 0 color-mix(in srgb, var(--sys-c) 80%, transparent), -150px 24px 0 0 var(--sys-c);
  animation: vibeTwinkle 3.2s var(--ease-out, ease-in-out) infinite;
}

/* continuo · anillos de Saturno (doble elipse inclinada) */
.sys--continuo .sys-vibe { width: 174%; height: 174%; }
.sys--continuo .sys-vibe::before, .sys--continuo .sys-vibe::after {
  content: ""; position: absolute; left: 50%; top: 50%; border-radius: 50%;
  transform: translate(-50%, -50%) rotateX(73deg) rotate(-15deg);
}
.sys--continuo .sys-vibe::before { width: 100%; height: 100%; border: 2px solid color-mix(in srgb, var(--sys-c) 58%, transparent); }
.sys--continuo .sys-vibe::after { width: 82%; height: 82%; border: 1px solid color-mix(in srgb, var(--sys-c) 40%, transparent); }

@media (prefers-reduced-motion: reduce) {
  .sys--web.is-focus .sys-vibe, .sys--ecommerce.is-focus .sys-vibe { animation: none; }
  .sys--brand .sys-vibe::before { animation: none; opacity: .8; }
}

/* crosshair de puntos que se fija en el planeta enfocado */
.sys-cross { position: absolute; z-index: 3; left: 50%; top: 50%; width: 78%; height: 78%; transform: translate(-50%, -50%); pointer-events: none; opacity: 0; transition: opacity .45s var(--ease-out); }
.sys.is-focus .sys-cross { opacity: 1; }

/* ── aura: chips de herramientas/marcas relacionadas alrededor del planeta ──
   Texto (no logos): cada servicio gana su identidad — las marcas con las que
   trabajamos. Aparecen al enfocar el sistema, en el color de la categoría. */
.sys-aura { position: absolute; z-index: 4; inset: -6%; pointer-events: none; }
.aura-chip {
  position: absolute; transform: translate(-50%, -50%) scale(.6);
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--type-family-workhorse); font-weight: 600;
  font-size: 12px; letter-spacing: 0.04em; text-transform: lowercase; white-space: nowrap;
  color: color-mix(in srgb, var(--sys-c) 78%, #e8e4d8);
  text-shadow: 0 1px 10px rgba(0,0,0,.7);
  opacity: 0; transition: opacity .5s var(--ease-out) var(--d, 0s), transform .6s var(--ease-stand, ease-out) var(--d, 0s);
}
.aura-chip .aura-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--sys-c); flex: none;
  box-shadow: 0 0 9px 1px color-mix(in srgb, var(--sys-c) 65%, transparent);
}
.sys.is-focus .sys-aura .aura-chip { opacity: .92; transform: translate(-50%, -50%) scale(1); }
.sys-cross i {
  position: absolute; background: var(--sys-c);
}
/* las 4 marcas de esquina (ticks) del crosshair */
.sys-cross .tk { width: 1px; height: 14px; }
.sys-cross .tk.h { width: 14px; height: 1px; }
.sys-cross .tk-t { top: -4px; left: 50%; transform: translateX(-50%); }
.sys-cross .tk-b { bottom: -4px; left: 50%; transform: translateX(-50%); }
.sys-cross .tk-l { left: -4px; top: 50%; transform: translateY(-50%); }
.sys-cross .tk-r { right: -4px; top: 50%; transform: translateY(-50%); }
.sys-cross .cdot { left: 50%; top: 50%; width: 4px; height: 4px; border-radius: 50%; transform: translate(-50%,-50%); }

/* ── HUD fijo (fly-through): tipografía GRANDE, sigue al sistema enfocado ─── */
.mapa-hud {
  position: absolute; z-index: 5;
  right: clamp(20px, 4.5vw, 92px); top: 50%; transform: translateY(-50%);
  width: clamp(300px, 47vw, 820px);
  font-family: var(--type-family-workhorse);
  will-change: opacity; pointer-events: none;
}
.mapa-hud a { pointer-events: auto; }
.mh-idx { font-weight: 600; font-size: clamp(12px, 1.1vw, 15px); letter-spacing: 0.2em; text-transform: uppercase; color: #8a857a; font-variant-numeric: tabular-nums; margin: 0; }
.mh-idx .desig { color: var(--sys-c); }
.mh-name {
  font-weight: 900; font-size: clamp(46px, 8vw, 112px); line-height: .88; letter-spacing: -0.045em;
  color: var(--sys-c); margin: .12em 0 0; display: flex; align-items: baseline; gap: .03em;
  white-space: nowrap;
  background-image: linear-gradient(100deg,
    var(--sys-c) 0%, var(--sys-c) 42%,
    color-mix(in srgb, var(--sys-c) 42%, #fff) 50%,
    var(--sys-c) 58%, var(--sys-c) 100%);
  background-size: 250% 100%; background-position: 135% 0;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 4px 34px color-mix(in srgb, var(--sys-c) 42%, transparent));
}
@media (prefers-reduced-motion: no-preference) {
  .mh-name { animation: nameSheen 5.5s var(--ease-out, ease-in-out) infinite; }
}
@keyframes nameSheen { 0% { background-position: 135% 0; } 55%, 100% { background-position: -35% 0; } }
.mh-name .dot { width: .12em; height: .12em; border-radius: 50%; background: currentColor; align-self: flex-end; margin-bottom: .12em; flex: none; }
.mh-rule {
  height: 8px; margin: clamp(14px, 2vh, 22px) 0; max-width: 460px;
  background: radial-gradient(circle, color-mix(in srgb, #e8e4d8 50%, transparent) 1px, transparent 1.7px) 0 50% / 9px 9px repeat-x;
  -webkit-mask: linear-gradient(90deg, #000, #000 72%, transparent);
          mask: linear-gradient(90deg, #000, #000 72%, transparent);
}
.mh-coords { font-weight: 500; font-size: clamp(13px, 1.2vw, 15px); letter-spacing: 0.06em; color: #9a948a; font-variant-numeric: tabular-nums; margin: 0; }
.mh-solves { font-weight: 500; font-size: clamp(18px, 2vw, 27px); line-height: 1.32; color: #d8d2c6; margin: clamp(14px, 2vh, 20px) 0 0; max-width: 32ch; }
.mh-scan { display: flex; align-items: center; gap: 12px; margin: clamp(18px, 2.6vh, 28px) 0 0; max-width: 460px; font-weight: 600; font-size: clamp(11px, 1vw, 13px); letter-spacing: 0.16em; text-transform: uppercase; color: #8a857a; }
.mh-scan .bar { flex: 1; height: 2px; background: color-mix(in srgb, #e8e4d8 14%, transparent); position: relative; overflow: hidden; }
.mh-scan .bar i { position: absolute; inset: 0 auto 0 0; width: var(--scan, 0%); background: var(--sys-c); }
.mh-scan .pct { color: var(--sys-c); font-variant-numeric: tabular-nums; min-width: 4ch; text-align: right; }
.mh-cta { margin-top: clamp(22px, 3.2vh, 34px); }
.mh-cta a {
  display: inline-flex; align-items: center; gap: .7em;
  font-weight: 700; font-size: clamp(13px, 1.2vw, 16px); letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--sys-c); text-decoration: none;
  padding: 11px 20px; border-radius: 999px;
  background: color-mix(in srgb, var(--sys-c) 13%, transparent);
  border: 1px solid color-mix(in srgb, var(--sys-c) 36%, transparent);
  box-shadow: inset 0 0 18px -8px color-mix(in srgb, var(--sys-c) 60%, transparent);
  transition: background .2s var(--ease-out), border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
.mh-cta a .arr { display: inline-grid; grid-template-columns: repeat(3, 3px); gap: 3px; }
.mh-cta a .arr i { width: 3px; height: 3px; border-radius: 50%; background: var(--sys-c); }
.mh-cta a:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--sys-c) 22%, transparent);
  border-color: color-mix(in srgb, var(--sys-c) 60%, transparent);
  box-shadow: inset 0 0 22px -6px color-mix(in srgb, var(--sys-c) 80%, transparent);
}

/* HUD inline (sólo modo estático) */
.sys-hud-static { display: none; }

/* ── rieles / progreso (4 sistemas) ──────────────────────────────────────── */
/* ── estela de luz: incita a hacer scroll (sin aglomerar información) ───────
   Un haz vertical tenue centrado abajo, con una luz que cae por él en el color
   del servicio enfocado — sustituye al riel de 4 botones. */
.mapa-trail {
  position: fixed; z-index: 100; left: 50%; bottom: clamp(20px, 4vh, 42px);
  transform: translateX(-50%); pointer-events: none;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  --beam-h: clamp(50px, 8.5vh, 88px);
}
.mt-beam {
  position: relative; width: 1px; height: var(--beam-h);
  background: linear-gradient(180deg,
    transparent 0%,
    color-mix(in srgb, var(--sys-c, #BA6849) 12%, transparent) 35%,
    color-mix(in srgb, var(--sys-c, #BA6849) 38%, transparent) 100%);
}
.mt-bead {
  position: absolute; left: 50%; top: 0; width: 5px; height: 5px; margin-left: -2.5px;
  border-radius: 50%; background: var(--sys-c, #BA6849);
  box-shadow: 0 0 13px 2px color-mix(in srgb, var(--sys-c, #BA6849) 70%, transparent);
  animation: estelaFall 2.1s var(--ease-out, ease-out) infinite;
}
@keyframes estelaFall {
  0% { transform: translateY(-7px); opacity: 0; }
  22% { opacity: 1; }
  78% { opacity: 1; }
  100% { transform: translateY(var(--beam-h)); opacity: 0; }
}
.mt-lbl {
  font-family: var(--type-family-workhorse); font-weight: 600; font-size: 10px;
  letter-spacing: 0.32em; text-transform: uppercase; color: #6f6a60;
}
@media (prefers-reduced-motion: reduce) { .mt-bead { animation: none; opacity: 1; top: 50%; } }

/* ── modo estático (reduced-motion): sistemas apilados ───────────────────── */
.mapa.static { height: auto; }
.mapa.static .mapa-sticky { position: relative; height: auto; padding: clamp(60px, 10vh, 120px) 0 clamp(48px, 8vh, 90px); }
.mapa.static .mapa-stage { position: relative; inset: auto; overflow: visible; }
.mapa.static .mapa-plane { position: relative; inset: auto; transform: none !important; display: flex; flex-direction: column; gap: clamp(56px, 9vh, 120px); }
.mapa.static .sys { position: relative; top: auto; left: auto; transform: none !important; opacity: 1 !important;
  display: flex; flex-direction: column; align-items: center; width: auto !important; height: auto !important; margin: 0 auto; }
.mapa.static .sys-orbit, .mapa.static .sys-orbit-2, .mapa.static .sys-cross, .mapa.static .sys-sun { display: none; }
.mapa.static .sys-planet { position: relative; }
.mapa.static .sys-hud-static { display: block; text-align: center; width: min(86vw, 440px); margin: clamp(18px, 3vh, 32px) auto 0; }
.mapa.static .sys-hud-static .mh-name { justify-content: center; font-size: clamp(38px, 11vw, 72px); }
.mapa.static .sys-hud-static .mh-cta { display: flex; justify-content: center; }
.mapa.static .mapa-titleblock { position: relative; top: auto; left: auto; margin: 0 auto clamp(30px, 5vh, 56px); text-align: center; padding: 0 20px; max-width: none; }
.mapa.static .mapa-eyebrow, .mapa.static .mapa-titleblock { justify-content: center; }

/* ── móvil en fly-through (.mapa--narrow): sistema centrado, HUD abajo ────── */
.mapa--narrow .mapa-hud {
  right: auto; left: 50%; top: auto; bottom: clamp(92px, 19vh, 178px);
  transform: translateX(-50%); width: min(92vw, 540px); text-align: center;
}
.mapa--narrow .mh-name { justify-content: center; font-size: clamp(34px, 12vw, 62px); }
.mapa--narrow .mh-idx, .mapa--narrow .mh-coords { letter-spacing: 0.12em; }
.mapa--narrow .mh-rule { display: none; }
.mapa--narrow .mh-solves { margin-left: auto; margin-right: auto; max-width: 26ch; font-size: clamp(16px, 4.4vw, 20px); }
.mapa--narrow .mh-scan { margin-left: auto; margin-right: auto; max-width: 320px; }
.mapa--narrow .mh-cta { display: flex; justify-content: center; }
.mapa--narrow .mapa-titleblock { top: clamp(26px, 6vh, 60px); left: 50%; transform: translateX(-50%); text-align: center; max-width: 88vw; }
.mapa--narrow .mapa-eyebrow { justify-content: center; }
.mapa--narrow .mapa-lead { display: none; }
.mapa--narrow .mapa-corner.tr, .mapa--narrow .mapa-corner.bl { display: none; }
