/* ============================================================
   Tukan Landing — Design Tokens & Base Styles
   Source: Tukan Design System (IBM Plex Sans/Mono, BlueDark scale)
   ============================================================ */

:root {
  /* ---- Primary · BlueDark ---- */
  --primary-950: #133247;
  --primary-900: #1c455e;
  --primary-800: #1b5171;
  --primary-700: #1c6088;
  --primary-600: #2277a7;
  --primary-500: #3195c6;
  --primary-400: #57aed9;
  --primary-300: #91cae8;
  --primary-200: #c5e2f2;
  --primary-100: #e5f1f9;
  --primary-50:  #f0f4fa;

  /* ---- Accents ---- */
  --green-600: #68a60a;
  --green-500: #87d012;
  --green-300: #c1f561;
  --green-200: #d3fa86;
  --melon-600: #e03e22;
  --melon-500: #f25b41;
  /* Guinda (gob. de México) — usado en la parte "sucia" del slider */
  --guinda-500: #9b2247;
  --guinda-600: #611232;
  --guinda-700: #3a0b1e;

  /* ---- Text ---- */
  --text-heading: #1b3a4b;
  --text-body:    #3a5a6b;
  --text-muted:   #6b8494;
  --text-faint:   #8899a4;
  --text-overline:#2b4c5b;

  /* ---- Surfaces & borders ---- */
  --surface:        #ffffff;
  --surface-soft:   #f6f7f9;
  --surface-tint:   #f0f4fa;
  --border:         #eceff2;
  --border-strong:  #d6dae1;
  --border-subtle:  #e4e8ec;

  /* ---- Type scale (px / line-height) ---- */
  --fs-h1: 55px;  --lh-h1: 1.0;
  --fs-h2: 50px;  --lh-h2: 1.0;
  --fs-h3: 36px;  --lh-h3: 1.1;
  --fs-h4: 28px;  --lh-h4: 1.2;
  --fs-h5: 22px;  --lh-h5: 1.3;
  --fs-desc: 20px;
  --fs-body: 16px;
  --fs-body2: 14px;
  --fs-caption: 12px;
  --fs-overline: 11px;

  /* ---- Fonts ---- */
  --font-sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, monospace;

  /* ---- Radius & shadow ---- */
  --radius: 6px;
  --radius-lg: 12px;
  --shadow-card: 0 1px 4px rgba(0, 0, 0, 0.06), 0 8px 24px rgba(0, 0, 0, 0.04);
  --shadow-btn-hover: 0 4px 12px rgba(28, 96, 136, 0.35);

  /* ---- Layout ---- */
  --container: 1160px;
  --gutter: 24px;
  --nav-h: 64px;
}

/* ============================ Reset ============================ */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: calc(var(--nav-h) + 16px); }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.5;
  color: var(--text-body);
  background: var(--surface);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5 { margin: 0; color: var(--text-heading); font-weight: 600; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
img, svg { display: block; max-width: 100%; }

/* ========================= Utilities ========================== */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.overline {
  font-size: var(--fs-overline);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-overline);
}

/* ========================== Buttons =========================== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 40px;
  padding: 0 20px;
  border: none;
  border-radius: var(--radius);
  font-family: var(--font-sans);
  font-size: var(--fs-body2);
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
  white-space: nowrap;
}
.btn--sm { height: 32px; padding: 0 16px; font-size: 13px; }
.btn--lg { height: 42px; padding: 0 22px; font-size: var(--fs-body2); }

.btn:focus-visible { outline: 3px solid var(--primary-400); outline-offset: 2px; }

/* Primary */
.btn--primary { background: var(--primary-700); color: #fff; }
.btn--primary:hover { background: var(--primary-800); box-shadow: var(--shadow-btn-hover); }
.btn--primary:active { background: var(--primary-950); box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.25); }

/* Default / outlined */
.btn--default { background: transparent; color: var(--primary-700); box-shadow: inset 0 0 0 1.5px var(--primary-700); }
.btn--default:hover { background: var(--primary-50); box-shadow: inset 0 0 0 1.5px var(--primary-800), 0 4px 12px rgba(28, 96, 136, 0.2); color: var(--primary-800); }

/* Link */
.btn--link {
  height: auto; padding: 0; gap: 4px;
  background: none; color: var(--primary-600);
  text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px;
}
.btn--link:hover { color: var(--primary-800); }

/* Ghost on dark surfaces */
.btn--ghost-light { background: transparent; color: #fff; box-shadow: inset 0 0 0 1.5px rgba(255, 255, 255, 0.4); }
.btn--ghost-light:hover { background: rgba(255, 255, 255, 0.1); box-shadow: inset 0 0 0 1.5px rgba(255, 255, 255, 0.7); }

/* ===================== Nav (floating pills) =================== */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 14px 0; }
.nav__inner { max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); display: flex; align-items: center; gap: 16px; }

.nav__pill {
  display: flex; align-items: center;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(19, 50, 71, 0.16);
}
.nav__pill--main { gap: 26px; padding: 9px 22px; }
.nav__pill--actions { gap: 14px; padding: 8px 8px 8px 18px; margin-left: auto; }

.nav__brand { display: flex; align-items: center; }
.nav__logo { height: 30px; width: auto; display: block; }

.nav__links { display: flex; gap: 24px; }
.nav__links a { font-size: var(--fs-body2); color: var(--text-body); font-weight: 500; }
.nav__links a:hover { color: var(--primary-700); }

.nav__signin { font-size: var(--fs-body2); font-weight: 500; color: var(--text-body); }
.nav__signin:hover { color: var(--primary-700); }
.nav__login {
  display: inline-flex; align-items: center; height: 34px; padding: 0 16px;
  border-radius: 8px; background: var(--primary-700); color: #fff;
  font-size: var(--fs-body2); font-weight: 600;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}
.nav__login:hover { background: var(--primary-800); box-shadow: var(--shadow-btn-hover); }

.nav__toggle { display: none; flex-direction: column; justify-content: center; align-items: center; gap: 5px; width: 46px; height: 46px; margin-left: auto; padding: 0; background: var(--surface); border: 1px solid var(--border-strong); border-radius: 13px; box-shadow: 0 10px 30px rgba(19, 50, 71, 0.16); cursor: pointer; }
.nav__toggle span { height: 2px; width: 20px; background: var(--text-heading); border-radius: 2px; transition: transform 0.25s ease, opacity 0.2s ease; }
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile drawer is hidden on desktop (only opens via hamburger on mobile) */
.nav__menu { display: none; }

/* ============================= Hero =========================== */
.hero { position: relative; overflow: hidden; min-height:100vh; display: flex; flex-direction: column; justify-content: center; padding: 120px 0 48px; text-align: center; background: linear-gradient(180deg, var(--surface) 0%, var(--primary-50) 100%); }
.hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }

/* Side tiles: Mexican states (exa-style rails) */
.hero__rail {
  position: absolute; top: 0; bottom: 0; z-index: 0;
  display: flex; align-items: center; gap: 16px;
  pointer-events: none;
}
.hero__rail--left { left: -28px; }
.hero__rail--right { right: -28px; }
/* Difuminado de los extremos con el color del fondo del hero (sin recortar
   sombras: solo pinta encima los cuadros de las orillas). */
.hero__rail::before, .hero__rail::after {
  content: ""; position: absolute; left: -20px; right: -20px; height: 120px;
  z-index: 2; pointer-events: none;
}
.hero__rail::before { top: 0; background: linear-gradient(180deg, var(--surface) 35%, transparent); }
.hero__rail::after  { bottom: 0; background: linear-gradient(0deg, var(--primary-50) 35%, transparent); }
.tile-col { display: flex; flex-direction: column; gap: 14px; }
.tile-link {
  display: block; border-radius: 14px; line-height: 0;
  pointer-events: auto; cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.tile-link:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 12px 26px rgba(19, 50, 71, 0.16);
  position: relative; z-index: 3;
}
.tile-link:focus-visible { outline: 3px solid var(--primary-400); outline-offset: 3px; }
.tile {
  width: 80px; height: 80px;
  border-radius: 14px; object-fit: cover;
  box-shadow: 0 6px 18px rgba(19, 50, 71, 0.09);
  background: var(--primary-50);
  /* Revealed smoothly, in a random order set by JS via --i */
  opacity: 0;
  animation: tile-in 0.6s ease both;
  animation-delay: calc(var(--i, 0) * 0.06s);
}
@keyframes tile-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .tile { opacity: 1; animation: none; }
}
/* Wiggle: un estado fijo (data-wiggle en el HTML) se sacude al cargar para
   invitar al click; lo dispara main.js agregando .is-wiggle al .tile-link tras
   la cascada. Va en el .tile-link (no en el .tile, que ya tiene tile-in) para no
   pisar esa animación. El glow azul (87,174,217 = --primary-400) imita el nodo
   que se "prende" en cta-graph.js. */
.tile-link.is-wiggle {
  animation: tile-wiggle 1.4s ease-in-out both;
  position: relative; z-index: 3;
  border-radius: 14px;
}
/* Cue sutil y profesional: un leve realce + halo azul que entra y sale, sin rotación. */
@keyframes tile-wiggle {
  0%   { transform: translateY(0) scale(1);       box-shadow: 0 6px 18px rgba(19,50,71,0.09), 0 0 0 0 rgba(87,174,217,0); }
  40%  { transform: translateY(-3px) scale(1.045); box-shadow: 0 14px 30px rgba(19,50,71,0.18), 0 0 0 4px rgba(87,174,217,0.20); }
  100% { transform: translateY(0) scale(1);       box-shadow: 0 6px 18px rgba(19,50,71,0.09), 0 0 0 0 rgba(87,174,217,0); }
}
@media (prefers-reduced-motion: reduce) {
  .tile-link.is-wiggle { animation: none; }
}
@media (max-width: 1200px) { .hero__rail { display: none; } }
.hero__inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; pointer-events: none; }
.hero__inner > * { pointer-events: auto; }
.hero__title { font-size: var(--fs-h1); line-height: var(--lh-h1); letter-spacing: -0.02em; }
.hero__rotate {
  display: inline-block;
  text-align: center;          /* word stays centered inside its fixed-width box */
  color: var(--primary-600);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.hero__rotate.is-out { opacity: 0; transform: translateY(0.25em); }
.hero__subtitle { max-width: 680px; margin-top: 16px; font-size: var(--fs-desc); line-height: 1.5; color: var(--text-body); }
.hero__place {
  position: relative;
  font-weight: 600;
  color: var(--text-heading);
  padding: 0 3px;
  /* Marker highlight that wipes in left → right when .is-lit is added (via JS) */
  background-image: linear-gradient(120deg, var(--primary-200) 0%, var(--primary-100) 100%);
  background-repeat: no-repeat;
  background-position: 0 88%;
  background-size: 0% 40%;
}
.hero__place.is-lit {
  animation: hero-highlight 0.85s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes hero-highlight {
  to { background-size: 100% 40%; }
}
@media (prefers-reduced-motion: reduce) {
  .hero__place { background-size: 100% 40%; }
  .hero__place.is-lit { animation: none; }
}
.hero__cta { display: flex; gap: 16px; margin-top: 24px; flex-wrap: wrap; justify-content: center; }
.hero__note { margin-top: 12px; font-size: var(--fs-body2); color: var(--text-muted); }

/* ===== Animated query demo (carousel) ===== */
.qdemo {
  width: 100%; max-width: 840px; margin: 28px auto 0; text-align: left;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-card);
  overflow: hidden;
  min-height: 380px; /* placeholder; JS sets the exact tallest-example height */
  opacity: 0; transition: opacity 0.5s ease;
}
.qdemo.is-ready { opacity: 1; }
/* Mac-style window title bar (blue tones) */
.qdemo__bar { display: flex; align-items: center; gap: 8px; padding: 11px 15px; background: var(--surface-soft); border-bottom: 1px solid var(--border); }
.qdemo__dot { width: 12px; height: 12px; border-radius: 50%; flex: none; }
.qdemo__dot--r { background: var(--primary-700); }
.qdemo__dot--y { background: var(--primary-500); }
.qdemo__dot--g { background: var(--primary-300); }
.qdemo__body { padding: 18px 20px 20px; }
.qdemo__q { display: flex; justify-content: flex-end; align-items: flex-start; gap: 10px; }
.qdemo__bubble {
  max-width: 82%; padding: 9px 13px; border-radius: 12px 12px 4px 12px;
  background: var(--primary-100); color: var(--text-heading);
  font-size: 12.5px; line-height: 1.45; min-height: 1.4em;
  opacity: 0; transition: opacity 0.3s ease;
}
.qdemo.q-ask .qdemo__bubble { opacity: 1; }
.qdemo__bubble::after { content: "▋"; margin-left: 1px; color: var(--primary-400); animation: qcaret 1s steps(1) infinite; }
.qdemo.typing-done .qdemo__bubble::after { content: ""; }
@keyframes qcaret { 50% { opacity: 0; } }
.qdemo__avatar { flex: none; width: 28px; height: 28px; border-radius: 50%; background: var(--primary-700); display: grid; place-items: center; opacity: 0; transition: opacity 0.3s ease; }
.qdemo.q-ask .qdemo__avatar { opacity: 1; }

/* La caja de respuesta aparece ya en q-thinking (Teo + puntitos), y su
   contenido (steps/intro/rule) se revela hasta q-answer. */
.qdemo__a { margin-top: 16px; opacity: 0; transition: opacity 0.4s ease; }
.qdemo.q-thinking .qdemo__a, .qdemo.q-answer .qdemo__a { opacity: 1; }
.qdemo__ahead { display: flex; align-items: center; gap: 10px; }
.qdemo__teo { flex: none; width: 32px; height: 32px; border-radius: 50%; background: var(--primary-100); display: grid; place-items: center; overflow: hidden; }
.qdemo__teo img { width: 24px; height: 24px; }
/* "Pensando": tres puntitos que rebotan mientras Teo procesa (q-thinking). */
.qdemo__thinking { display: none; align-items: center; gap: 5px; }
.qdemo.q-thinking .qdemo__thinking { display: inline-flex; }
.qdemo.q-answer .qdemo__thinking { display: none; }
.qdemo__thinking i { width: 6px; height: 6px; border-radius: 50%; background: var(--primary-400); animation: qthink 1.2s infinite ease-in-out; }
.qdemo__thinking i:nth-child(2) { animation-delay: 0.16s; }
.qdemo__thinking i:nth-child(3) { animation-delay: 0.32s; }
@keyframes qthink { 0%, 80%, 100% { transform: translateY(0); opacity: 0.35; } 40% { transform: translateY(-4px); opacity: 1; } }
.qdemo__steps { display: none; align-items: center; gap: 7px; color: var(--text-muted); font-size: 11.5px; }
.qdemo.q-answer .qdemo__steps { display: flex; }
.qdemo__atom { color: var(--primary-500); display: inline-flex; }
.qdemo__chev { color: var(--text-faint); }
.qdemo__intro { margin-top: 10px; color: var(--text-body); font-size: 13px; opacity: 0; transition: opacity 0.4s ease; }
.qdemo.q-answer .qdemo__intro { opacity: 1; }
.qdemo__rule { height: 1px; background: var(--border-strong); margin: 14px 0; opacity: 0; transition: opacity 0.4s ease; }
.qdemo.q-answer .qdemo__rule { opacity: 1; }

.qdemo__title, .qdemo__meta, .qdemo__table, .qdemo__expl {
  opacity: 0; transform: translateY(8px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}
.qdemo.q-result .qdemo__title { opacity: 1; transform: none; }
.qdemo.q-result .qdemo__meta  { opacity: 1; transform: none; transition-delay: 0.08s; }
.qdemo.q-result .qdemo__table { opacity: 1; transform: none; transition-delay: 0.16s; }
.qdemo.q-result .qdemo__expl  { opacity: 1; transform: none; transition-delay: 0.55s; }

.qdemo__title { font-size: 16px; color: var(--text-heading); }
.qdemo__titlenote { font-weight: 400; font-style: italic; color: var(--text-muted); font-size: 0.85em; }
.qdemo__meta { margin-top: 7px; font-size: 11.5px; color: var(--text-body); }
.qdemo__chip { font-family: var(--font-mono); font-size: 10.5px; background: var(--primary-100); color: var(--primary-700); padding: 2px 7px; border-radius: 6px; }
.qdemo__inst { color: var(--text-muted); font-size: 11.5px; }

.qdemo__table { margin-top: 14px; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; max-width: 420px; }
.qdemo__table--wide { max-width: 100%; }
.qdemo__tablescroll { overflow-x: auto; }
/* wide tables keep their columns roomy and scroll horizontally on narrow screens */
.qdemo__table--wide .qdemo__rows { min-width: 640px; }
.qdemo__tablebar { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; background: var(--surface-soft); border-bottom: 1px solid var(--border); }
.qdemo__tabletitle { font-size: 11.5px; color: var(--text-muted); font-weight: 400; }
.qdemo__csv { font-size: 10.5px; color: var(--text-muted); border: 1px solid var(--border-strong); border-radius: 6px; padding: 3px 7px; }
.qdemo__rows { width: 100%; border-collapse: collapse; }
.qdemo__rows th { padding: 8px 12px; font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-muted); font-weight: 600; text-align: right; border-bottom: 1px solid var(--border); white-space: nowrap; }
.qdemo__rows th:first-child { text-align: left; }
.qdemo__rows td { padding: 8px 12px; border-bottom: 1px solid var(--border); font-size: 11.5px; color: var(--text-body); text-align: right; white-space: nowrap; }
.qdemo__rows tr:last-child td { border-bottom: none; }
.qdemo__rows td:first-child { text-align: left; font-weight: 600; color: var(--text-heading); }
.qdemo__rows tr.is-key td { font-weight: 700; color: var(--text-heading); }
.qdemo__rows td.is-strong { font-weight: 700; color: var(--text-heading); }
.qdemo__rows tr.is-agg td { font-style: italic; color: var(--text-muted); }
.qdemo__rows tr.is-agg td:first-child { color: var(--text-body); }
.qdemo__rows tbody tr { opacity: 0; }
.qdemo.q-result .qdemo__rows tbody tr { opacity: 1; transition: opacity 0.4s ease; transition-delay: calc(0.2s + var(--r, 0) * 0.1s); }
.qdemo__rows thead tr { opacity: 0; }
.qdemo.q-result .qdemo__rows thead tr { opacity: 1; transition: opacity 0.4s ease; transition-delay: 0.18s; }
.qdemo__expl { margin-top: 12px; font-size: 11.5px; color: var(--text-muted); line-height: 1.5; }

@media (max-width: 560px) {
  .qdemo__body { padding: 14px 16px 16px; }
  .qdemo__table { max-width: none; }
}
@media (prefers-reduced-motion: reduce) {
  .qdemo__bubble::after { display: none; }
  .qdemo__thinking { display: none !important; }
  .qdemo__bubble, .qdemo__avatar, .qdemo__a, .qdemo__intro, .qdemo__rule,
  .qdemo__title, .qdemo__meta, .qdemo__table, .qdemo__expl,
  .qdemo__rows tr { opacity: 1 !important; transform: none !important; transition: none !important; }
}

.hero__demo { width: 100%; max-width: 880px; margin-top: 64px; }
.demo-card { border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-card); overflow: hidden; text-align: left; }
.demo-card__bar { display: flex; gap: 6px; padding: 12px 16px; border-bottom: 1px solid var(--border); background: var(--surface-soft); }
.demo-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--border-strong); }
.demo-card__body { padding: 24px; }
.demo-query { display: flex; flex-direction: column; gap: 6px; }
.demo-query__label { font-size: var(--fs-caption); letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); }
.demo-query__text { font-size: var(--fs-h5); color: var(--text-heading); }
.demo-result { display: flex; align-items: center; justify-content: center; min-height: 180px; margin-top: 20px; border: 1px dashed var(--border-strong); border-radius: var(--radius); background: var(--surface-tint); }
.demo-placeholder, .media-placeholder { color: var(--text-faint); font-family: var(--font-mono); font-size: var(--fs-body2); }

/* ===================== Trusted / Marquee ===================== */
.trusted { position: relative; overflow: hidden; padding: 80px 0; background: var(--primary-950); }
.trusted__grid { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }
.trusted .container { position: relative; z-index: 1; }
.trusted__title {
  text-align: center;
  font-size: var(--fs-overline);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--primary-300);
  margin-bottom: 48px;
}

/* Static client logo grid (no carousel); fades in one by one */
.clients-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 48px 32px; place-items: center; margin-top: 8px;
}
.tlogo {
  height: var(--h, 24px);
  background-color: #fff;
  -webkit-mask-repeat: no-repeat; -webkit-mask-position: center; -webkit-mask-size: contain;
  mask-repeat: no-repeat; mask-position: center; mask-size: contain;
  opacity: 0;
}
/* logos fade in one by one only once the section scrolls into view (.in-view) */
.trusted.in-view .tlogo {
  animation: tlogo-in 0.55s ease both;
  animation-delay: calc(0.4s + var(--i, 0) * 0.16s);
}
@keyframes tlogo-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 0.9; transform: none; }
}
@media (prefers-reduced-motion: reduce) {
  .tlogo { opacity: 0.9 !important; animation: none; transform: none; }
}
@media (max-width: 900px) { .clients-grid { grid-template-columns: repeat(3, 1fr); gap: 40px 24px; } }
@media (max-width: 560px) { .clients-grid { grid-template-columns: repeat(2, 1fr); gap: 32px 20px; } }

/* Static marker highlight (reusable, no animation) */
.mark {
  padding: 0 3px;
  font-weight: 600;
  color: var(--text-heading);
  background-image: linear-gradient(120deg, var(--primary-200) 0%, var(--primary-100) 100%);
  background-repeat: no-repeat;
  background-position: 0 88%;
  background-size: 100% 42%;
}

.marquee {
  overflow: hidden;
  /* fade out both edges */
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
}
.marquee__track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: marquee 50s linear infinite;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes marquee {
  to { transform: translateX(-50%); }
}

/* Each logo painted as a solid Tukan-blue silhouette via mask.
   mask-image is set inline per <li> so its url() resolves against index.html. */
.logo-item {
  flex: none;
  height: var(--h, 24px);        /* per-logo optical tuning, default 24px */
  margin-right: 64px;            /* trailing gap baked in → exact -50% loop */
  background-color: #ffffff;     /* white silhouettes on the dark section */
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  opacity: 0.7;
  transition: opacity 0.2s ease;
}
.logo-item:hover { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  .marquee { overflow-x: auto; }
  .marquee__track { animation: none; }
}

/* =========================== Logos =========================== */
.logos { padding: 10px 0 56px; border-bottom: 1px solid var(--border); }
.logos__caption { text-align: center; font-size: var(--fs-body2); color: var(--text-muted); }
.logos__grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 40px; margin-top: 24px; }
.logos__grid li { font-size: var(--fs-desc); font-weight: 600; color: var(--text-faint); }
.logos__grid--marks { gap: 46px; align-items: center; margin-top: 28px; }
.logos__grid--marks li { display: flex; }
.tool {
  display: block; width: 30px; height: 30px;
  background-color: var(--text-muted);
  -webkit-mask: var(--logo) center / contain no-repeat;
  mask: var(--logo) center / contain no-repeat;
  transition: background-color 0.2s ease, transform 0.2s ease;
}
.tool:hover { background-color: var(--primary-700); transform: translateY(-2px); }
@media (max-width: 640px) { .logos__grid--marks { gap: 30px; } .tool { width: 26px; height: 26px; } }

/* ===================== Clarity flow (ingesta → red → bases) === */
.clarity { padding: 96px 0 44px; background: var(--surface); }
.clarity__stage {
  position: relative; max-width: 1080px; height: 500px; margin: 8px auto 0;
  border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--border-strong); box-shadow: var(--shadow-card);
  /* Papel impreso: trama de puntos azul (halftone) + tinte navy sutil a la izquierda. */
  background:
    radial-gradient(circle, rgba(27, 81, 113, 0.13) 0.6px, transparent 1.05px),
    linear-gradient(90deg, rgba(19, 50, 71, 0.05) 0%, rgba(19, 50, 71, 0.012) 42%, var(--surface) 52%, var(--surface) 100%);
  background-size: 5px 5px, 100% 100%;
  /* Aísla y contiene el pintado: el scroll no repinta el resto de la página. */
  isolation: isolate; contain: paint;
}
/* Canvas en su propia capa GPU: al scrollear solo se traslada, no se repinta. */
.clarity__canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 1; will-change: transform; transform: translateZ(0); }
/* grano impreso sobre todo el stage (look rugged / duotono).
   Sin mix-blend-mode: ese modo forzaba recomposición en cada frame de scroll. */
.clarity__stage::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.12;
}
/* divisor fijo al centro */
.clarity__divline {
  position: absolute; top: 9%; bottom: 9%; left: 50%; width: 1px; transform: translateX(-0.5px);
  background: linear-gradient(180deg, transparent 0%, rgba(19, 50, 71, 0.18) 16%, rgba(19, 50, 71, 0.18) 84%, transparent 100%);
  z-index: 3;
}
/* hub Tukan al centro */
.clarity__hub {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 64px; height: 64px; border-radius: 18px; background: #fff;
  border: 1px solid var(--border-strong); box-shadow: 0 14px 34px rgba(19, 50, 71, 0.20);
  display: grid; place-items: center; z-index: 4;
}
.clarity__hub img { width: 34px; height: 34px; }
.clarity__hub::after {
  content: ""; position: absolute; inset: -6px; border-radius: 24px;
  border: 2px solid rgba(87, 174, 217, 0); pointer-events: none;
}
.clarity__hub.is-pulsing::after { animation: hub-pulse 0.6s ease-out; }
@keyframes hub-pulse {
  0%   { border-color: rgba(87, 174, 217, 0.7); transform: scale(0.88); opacity: 1; }
  100% { border-color: rgba(87, 174, 217, 0);   transform: scale(1.3);  opacity: 0; }
}

/* ---- móvil: flujo vertical (clase la pone clarity-flow.js) ---- */
.clarity__stage.is-mobile { height: 580px; }
.clarity__stage.is-mobile .clarity__hub { top: 40%; }
.clarity__stage.is-mobile .clarity__divline {
  top: 40%; left: 7%; right: 7%; bottom: auto; width: auto; height: 1px;
  transform: translateY(-0.5px);
  background: linear-gradient(90deg, transparent 0%, rgba(19, 50, 71, 0.18) 16%, rgba(19, 50, 71, 0.18) 84%, transparent 100%);
}

@media (max-width: 560px) {
  .clarity__hub { width: 56px; height: 56px; border-radius: 15px; }
  .clarity__hub img { width: 30px; height: 30px; }
}

/* ========================== Sections ========================= */
.section { padding: 96px 0; }
.section--alt { background: var(--primary-50); }
.divider { height: 1px; background: var(--border-strong); }

.section__head { max-width: 720px; margin: 0 auto 56px; text-align: center; }
.section__eyebrow {
  font-size: var(--fs-overline);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-overline);
  margin-bottom: 14px;
}
.section__title { margin-top: 12px; font-size: var(--fs-h3); line-height: var(--lh-h3); letter-spacing: -0.01em; }
.section__lead { margin-top: 16px; font-size: var(--fs-desc); color: var(--text-body); }

/* Product cards */
/* Relativo: 90% del ancho en pantallas grandes, sin quedar más angosto que el container estándar */
#producto .container { max-width: clamp(var(--container), 90%, 1400px); }
.products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 8px; }
.pcard {
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  background: var(--surface); overflow: hidden; box-shadow: var(--shadow-card);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.pcard:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(19, 50, 71, 0.12); }
.pcard__visual {
  position: relative; height: 168px; overflow: hidden;
  background: var(--surface-tint);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
}
.pcard__visual::after {
  content: "Imagen / vista previa";
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--text-faint);
}
/* card with a real image instead of the placeholder + icon badge */
.pcard__visual--img { padding: 0; display: block; }
.pcard__visual--img::after { content: none; }
.pcard__img { width: 100%; height: 100%; object-fit: cover; object-position: top left; display: block; }
.pcard__chip {
  position: absolute; top: 12px; right: 12px; z-index: 2;
  padding: 3px 11px; border-radius: 999px;
  background: var(--primary-100);
  color: var(--primary-700); text-transform: uppercase;
  border: 1px solid var(--primary-500);
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em;
  box-shadow: 0 2px 8px rgba(19, 50, 71, 0.18);
}
/* Pill "Beta" inline (p. ej. junto a un eyebrow/overview) */
.beta-pill {
  display: inline-block; vertical-align: middle;
  margin-left: 9px; padding: 2px 9px; border-radius: 999px;
  background: var(--primary-100); color: var(--primary-700);
  border: 1px solid var(--primary-300);
  font-size: 10px; font-weight: 700; letter-spacing: 0.06em;
  line-height: 1.45;
}
.pcard__icon {
  position: absolute; top: 16px; left: 16px;
  width: 46px; height: 46px; border-radius: 12px;
  background: var(--primary-700); color: #fff;
  display: grid; place-items: center;
  box-shadow: 0 6px 16px rgba(28, 96, 136, 0.28);
}
.pcard__body { padding: 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.pcard__title { font-size: var(--fs-h5); }
.pcard__text { color: var(--text-body); font-size: var(--fs-body); }
.pcard__link { margin-top: auto; padding-top: 14px; display: inline-flex; align-items: center; gap: 6px; color: var(--primary-600); font-weight: 600; font-size: var(--fs-body2); }
.pcard__link:hover { color: var(--primary-800); }
.pcard__link svg { transition: transform 0.2s ease; }
.pcard:hover .pcard__link svg { transform: translate(2px, -2px); }
@media (max-width: 900px) { .products-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .products-grid { grid-template-columns: 1fr; } }

/* Grids */
.grid { display: grid; gap: 24px; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

/* Feature */
.feature {
  padding: 28px; border: 1px solid var(--border); border-radius: var(--radius-lg);
  background: var(--surface); box-shadow: var(--shadow-card);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.feature:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(19, 50, 71, 0.10), 0 20px 44px rgba(19, 50, 71, 0.12);
}
.feature__icon {
  display: grid; place-items: center; width: 46px; height: 46px;
  margin-bottom: 18px; border-radius: 12px;
  background: var(--primary-50); color: var(--primary-600);
}
.feature__icon svg { width: 24px; height: 24px; }
.feature__title { font-size: var(--fs-h5); }
.feature__text { margin-top: 10px; color: var(--text-body); font-size: var(--fs-body); }
@media (prefers-reduced-motion: reduce) {
  .feature { transition: none; }
  .feature:hover { transform: none; }
}

/* Card */
.card { padding: 24px; border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--surface); }
.card__title { font-size: var(--fs-h5); }
.card__text { margin-top: 8px; color: var(--text-muted); font-size: var(--fs-body2); }

/* Split (text + media) */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split__text .section__title { text-align: left; }
.split__text .btn--link { margin-top: 24px; }
.split--reverse .split__text { order: 2; }
.media-placeholder { display: flex; align-items: center; justify-content: center; min-height: 320px; border: 1px dashed var(--border-strong); border-radius: var(--radius-lg); background: var(--surface); }

/* Team */
.member { text-align: center; }
.member__avatar { width: 96px; height: 96px; margin: 0 auto 16px; border-radius: 50%; background: var(--primary-100); }
.member__name { font-size: var(--fs-h5); }
.member__role { margin-top: 4px; color: var(--text-muted); font-size: var(--fs-body2); }

/* ============================= CTA =========================== */
.cta { padding: 96px 0; background: var(--surface-soft); border-top: 1px solid var(--border); }
.cta__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; text-align: left; }
.cta__title { font-size: var(--fs-h3); line-height: var(--lh-h3); color: var(--text-heading); max-width: 22ch; }
.cta__lead { margin: 18px 0 32px; max-width: 46ch; font-size: var(--fs-desc); color: var(--text-body); }
.cta__actions { display: flex; gap: 16px; flex-wrap: wrap; }
.cta__media { display: flex; align-items: center; justify-content: center; min-height: 320px; border: 1px dashed var(--border-strong); border-radius: var(--radius-lg); background: var(--surface); }
.cta__placeholder { font-family: var(--font-mono); font-size: var(--fs-body2); color: var(--text-faint); letter-spacing: 0.04em; text-transform: uppercase; }
@media (max-width: 860px) {
  .cta__inner { grid-template-columns: 1fr; gap: 36px; }
  .cta__title, .cta__lead { max-width: none; }
  .cta__media { min-height: 240px; }
}

/* =========================== Footer ========================== */
.footer { padding: 64px 0 32px; background: var(--primary-950); color: var(--primary-200); border-top: 1px solid rgba(255, 255, 255, 0.08); }
.footer__inner { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 32px; }
.footer__brand .nav__wordmark { color: #fff; }
.footer__logo { height: 26px; width: auto; display: block; }
.footer__tagline { margin-top: 12px; max-width: 280px; font-size: var(--fs-body2); color: var(--primary-300); }
.footer__mail { display: inline-block; margin-top: 12px; font-size: var(--fs-body2); color: var(--primary-200); border-bottom: 1px solid rgba(255, 255, 255, 0.18); transition: color 0.15s ease, border-color 0.15s ease; }
.footer__mail:hover { color: #fff; border-color: rgba(255, 255, 255, 0.5); }
.footer__col { display: flex; flex-direction: column; gap: 10px; }
.footer__heading { font-size: var(--fs-caption); letter-spacing: 0.1em; text-transform: uppercase; color: var(--primary-400); margin-bottom: 4px; }
.footer__col a { font-size: var(--fs-body2); color: var(--primary-200); }
.footer__col a:hover { color: #fff; }
.footer__bottom { margin-top: 48px; padding-top: 24px; border-top: 1px solid rgba(255, 255, 255, 0.08); font-size: var(--fs-caption); color: var(--primary-400); }

/* ========================= Responsive ======================== */
@media (max-width: 900px) {
  :root { --fs-h1: 40px; --fs-h2: 36px; --fs-h3: 28px; }
  .nav__toggle { display: flex; }
  .nav__pill--main .nav__links { display: none; }
  .nav__pill--main { padding: 9px 18px; }
  .nav__pill--actions { display: none; }
  .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .split { grid-template-columns: 1fr; gap: 32px; }
  .split--reverse .split__text { order: 0; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }

  /* Mobile nav drawer (hamburger) — dark pill */
  .nav__menu { display: none; }
  .nav__menu.is-open {
    display: flex; flex-direction: column; align-items: stretch; gap: 0;
    position: absolute; top: 72px; left: var(--gutter); right: var(--gutter);
    padding: 10px 20px 18px;
    background: var(--surface); border: 1px solid var(--border); border-radius: 14px;
    box-shadow: 0 16px 32px rgba(19, 50, 71, 0.12);
  }
  .nav__menu.is-open .nav__links { flex-direction: column; gap: 0; }
  .nav__menu.is-open .nav__links a { padding: 13px 2px; border-bottom: 1px solid var(--border); color: var(--text-body); }
  .nav__menu.is-open .nav__actions { display: flex; flex-direction: column; align-items: stretch; gap: 10px; padding-top: 14px; }
  .nav__menu.is-open .nav__signin { padding: 8px 0; text-align: center; }
  .nav__menu.is-open .nav__login { width: 100%; justify-content: center; height: 42px; }
}

@media (max-width: 560px) {
  :root { --fs-h1: 43px; }
  .hero { padding: 96px 0 40px; }
  .hero__subtitle { font-size: 16px; }
  .grid--3, .grid--4 { grid-template-columns: 1fr; }
  .hero__cta { flex-direction: column; width: 100%; }
  .hero__cta .btn { width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}

/* ===================== Nav dropdown (Productos) ===================== */
.nav__dd { position: relative; display: inline-flex; align-items: center; }
.nav__ddbtn {
  display: inline-flex; align-items: center; gap: 5px;
  background: none; border: 0; margin: 0; padding: 0; cursor: pointer;
  font-family: inherit; font-size: var(--fs-body2); font-weight: 500;
  line-height: 1; color: var(--text-body);
}
.nav__ddbtn:hover,
.nav__dd:hover .nav__ddbtn,
.nav__dd:focus-within .nav__ddbtn { color: var(--primary-700); }
.nav__ddcaret { transition: transform 0.2s ease; }
.nav__dd:hover .nav__ddcaret,
.nav__dd:focus-within .nav__ddcaret { transform: rotate(180deg); }

/* Desktop mega panel — product cards, centered under the floating nav */
.nav__mega {
  position: fixed; top: 74px; left: 50%;
  width: min(940px, calc(100vw - 32px));
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
  padding: 14px;
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg); box-shadow: 0 24px 48px rgba(19, 50, 71, 0.18);
  opacity: 0; visibility: hidden; pointer-events: none;
  transform: translateX(-50%) translateY(8px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
  z-index: 90;
}
/* Invisible bridge so the cursor can cross the gap into the panel */
.nav__mega::before { content: ""; position: absolute; left: 0; right: 0; top: -22px; height: 22px; }
.nav__dd:hover .nav__mega,
.nav__dd:focus-within .nav__mega {
  opacity: 1; visibility: visible; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.megacard {
  display: flex; flex-direction: column; gap: 9px;
  padding: 10px; border-radius: 10px; border: 1px solid transparent;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}
.megacard:hover { background: var(--surface-soft); border-color: var(--border); }
.megacard__media {
  position: relative; aspect-ratio: 16 / 10; overflow: hidden;
  border-radius: 8px; border: 1px solid var(--border); background: var(--surface-soft);
}
.megacard__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.megacard__chip {
  position: absolute; top: 8px; left: 8px; z-index: 1;
  padding: 3px 9px; border-radius: 999px;
  background: var(--primary-100); color: var(--primary-700); border: 1px solid var(--primary-500);
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase;
}
.megacard__title {
  display: flex; align-items: center; gap: 6px;
  font-size: var(--fs-body); font-weight: 600; color: var(--text-heading);
}
.megacard__title svg { color: var(--text-faint); transition: transform 0.15s ease, color 0.15s ease; }
.megacard:hover .megacard__title svg { transform: translateX(3px); color: var(--primary-700); }
.megacard__text { font-size: var(--fs-body2); font-weight: 400; line-height: 1.45; color: var(--text-muted); }

/* Mobile drawer reuses the simple text list (.nav__ddmenu) below */
.nav__ddmenu a { font-size: var(--fs-body2); font-weight: 500; color: var(--text-body); }

/* Mobile drawer: Productos becomes a labeled, always-open group */
@media (max-width: 900px) {
  .nav__menu.is-open .nav__dd { display: flex; flex-direction: column; align-items: stretch; }
  .nav__ddlabel {
    margin: 0; padding: 13px 2px; font-size: var(--fs-body2); font-weight: 600;
    color: var(--text-heading); border-bottom: 1px solid var(--border);
  }
  .nav__menu.is-open .nav__ddmenu { display: flex; flex-direction: column; }
  .nav__menu.is-open .nav__ddmenu a {
    padding: 12px 2px 12px 16px; border-bottom: 1px solid var(--border); color: var(--text-body);
  }
}

/* ============================================================
   Product landing (plataforma.html) — appended, no edita reglas previas
   ============================================================ */
.phero {
  position: relative; overflow: hidden;
  padding: 168px 0 110px;
  min-height: 560px;
  display: flex; align-items: center;
  background: var(--primary-950);
  color: #fff;
}
/* Imagen de fondo que cubre todo, con transparencia */
.phero__bg {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  opacity: 0.40; z-index: 0;
}
/* Overlay para legibilidad: más oscuro a la izquierda (donde va el texto) */
.phero::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    linear-gradient(90deg, var(--primary-950) 0%, rgba(19, 50, 71, 0.82) 38%, rgba(19, 50, 71, 0.35) 100%),
    linear-gradient(0deg, var(--primary-950) 0%, transparent 42%);
}
.phero .container { position: relative; z-index: 1; }
.phero__inner { max-width: 640px; margin: 0; text-align: left; }
.phero .section__eyebrow { color: var(--primary-300); }
.phero__title { margin-top: 14px; font-size: var(--fs-h1); line-height: var(--lh-h1); letter-spacing: -0.01em; color: #fff; }
.phero__accent { color: var(--primary-400); }
.phero__lead { max-width: 46ch; margin: 20px 0 0; font-size: var(--fs-desc); color: var(--primary-200); }
.phero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.phero .btn--primary { background: #fff; color: var(--primary-900); }
.phero .btn--primary:hover { background: var(--primary-50); box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35); }

.media-frame { display: flex; align-items: center; justify-content: center; min-height: 420px; border: 1px dashed var(--border-strong); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-card); }
.media-frame__label { font-family: var(--font-mono); font-size: var(--fs-body2); color: var(--text-faint); letter-spacing: 0.04em; text-transform: uppercase; }

/* Listas de beneficios en las secciones split */
.plp-list { margin-top: 22px; display: flex; flex-direction: column; gap: 12px; }
.plp-list li { position: relative; padding-left: 28px; color: var(--text-body); line-height: 1.5; }
.plp-list li::before {
  content: ""; position: absolute; left: 0; top: 3px; width: 18px; height: 18px;
  border-radius: 5px; background: var(--primary-50);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M2.5 6.2 5 8.5 9.5 3.5' stroke='%231c6088' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center;
}

@media (max-width: 900px) {
  .phero { padding: 132px 0 72px; min-height: 0; }
  .phero__inner { max-width: none; }
  .phero__lead { max-width: none; }
  .phero__bg { opacity: 0.28; }
}
@media (max-width: 560px) {
  .phero__title { font-size: 33px; }
  .phero__lead { font-size: var(--fs-body); }
}

/* ===================== CTA — Esfera de use cases ===================== */
.cta__media--graph {
  position: relative;
  display: block;
  padding: 0;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface) 0%, var(--primary-50) 100%);
  overflow: hidden;
}
.ctagraph { position: relative; width: 100%; height: 100%; min-height: 320px; }
.ctag-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

/* Mensaje (esquina superior derecha) */
.ctag-msg {
  position: absolute; top: 14px; right: 14px; z-index: 3;
  display: flex; align-items: flex-start; gap: 8px; max-width: 64%;
  opacity: 0; transform: translateY(-6px) scale(0.96);
  transition: opacity 0.35s ease, transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.ctag-msg.show { opacity: 1; transform: none; }
.ctag-bub {
  background: var(--primary-700); color: #fff; font-size: 11.5px; line-height: 1.35;
  padding: 8px 11px; border-radius: 12px 12px 3px 12px;
  box-shadow: 0 8px 20px rgba(19, 50, 71, 0.20);
}


/* ===== Product pages — visuales pulidas (sin placeholders de scaffold) ===== */
.phero__shot { position: relative; z-index: 1; border-radius: var(--radius-lg); border: 1px solid rgba(255, 255, 255, 0.12); box-shadow: 0 30px 60px rgba(0, 0, 0, 0.45); overflow: hidden; background: var(--primary-900); }
.phero__shot img { display: block; width: 100%; height: auto; }
.viz { display: flex; align-items: center; justify-content: center; min-height: 300px; padding: 32px; border-radius: var(--radius-lg); border: 1px solid var(--border); background: linear-gradient(135deg, var(--primary-50) 0%, var(--surface) 72%); box-shadow: var(--shadow-card); }
.section--alt .viz { background: linear-gradient(135deg, var(--surface) 0%, var(--primary-100) 100%); }
.viz svg { width: 84px; height: 84px; color: var(--primary-500); }

/* ===== Plataforma — demo de conversación (tarjeta .qdemo en el 1er split) ===== */
.split__media .qdemo { margin: 0; max-width: none; }
.split__media .qdemo__table { max-width: none; }
.qdemo__list { opacity: 0; transform: translateY(6px); transition: opacity 0.4s ease, transform 0.4s ease; transition-delay: 0.1s; }
.qdemo.q-result .qdemo__list { opacity: 1; transform: none; }
.qdemo__src { margin-top: 11px; font-size: 13px; line-height: 1.5; color: var(--text-body); }
.qdemo__src:first-child { margin-top: 8px; }
.qdemo__srcnum { font-weight: 700; color: var(--text-heading); }
.qdemo__srchead { font-weight: 700; color: var(--text-heading); }
.qdemo__subs { margin: 4px 0 0; padding-left: 20px; }
.qdemo__subs li { list-style: disc; font-size: 12.5px; color: var(--text-body); margin: 3px 0; padding-left: 2px; }
.qdemo__code { font-family: var(--font-mono); font-size: 10.5px; background: var(--surface-soft); color: var(--text-muted); border: 1px solid var(--border); padding: 2px 6px; border-radius: 6px; }
.qdemo__closing { margin-top: 13px; font-size: 13px; color: var(--text-body); opacity: 0; transition: opacity 0.4s ease; transition-delay: 0.5s; }
.qdemo.q-result .qdemo__closing { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  .qdemo__list, .qdemo__closing { opacity: 1 !important; transform: none !important; }
}

/* Hero plataforma: los saltos de línea del título solo aplican en desktop */
@media (max-width: 560px) { .phero__br { display: none; } }

/* Split: columnas de ancho fijo (que una tabla/contenido ancho no las estire) */
.split > * { min-width: 0; }

/* Bloque de fuentes apiladas (paso 3 del demo de plataforma) */
.qdemo__meta .qdemo__srcrow { display: flex; align-items: center; gap: 8px; margin-top: 6px; flex-wrap: wrap; }

/* Sección más ancha (menos margen lateral) — usada en el split del demo de plataforma */
.section--wide .container { max-width: clamp(var(--container), 94%, 1440px); }

/* ===== Red de integraciones (ilustración CSS estática, plataforma → AUTOMATIZA) =====
   Tukan al centro y 6 integraciones (no IA) alrededor (hexágono), unidas con radios
   SVG. Nodos/hub son HTML (círculos perfectos); las líneas viven en un SVG estirado
   al mismo sistema de % con vector-effect non-scaling-stroke, así sus extremos
   coinciden con los centros de los nodos en cualquier tamaño. */
.intnet { position: relative; width: 100%; max-width: 480px; margin-inline: auto; aspect-ratio: 3 / 2; }
.intnet__links { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; z-index: 0; }
.intnet__links line, .intnet__links path {
  fill: none; stroke: var(--primary-300); stroke-width: 1.5;
  stroke-linecap: round; vector-effect: non-scaling-stroke;
}
.intnet__node, .intnet__hub {
  position: absolute; left: var(--x); top: var(--y); transform: translate(-50%, -50%);
}
.intnet__node {
  z-index: 1;
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--surface); border: 1px solid var(--border-strong);
  box-shadow: var(--shadow-card);
  display: grid; place-items: center;
}
.intnet__node .tool { width: 28px; height: 28px; background-color: var(--primary-700); }
.intnet__hub {
  z-index: 2;
  width: 108px; height: 108px; border-radius: 50%;
  background: radial-gradient(circle at 50% 38%, var(--surface) 0%, var(--primary-100) 100%);
  border: 1.5px solid var(--primary-200);
  box-shadow: 0 14px 34px rgba(19, 50, 71, 0.22);
  display: grid; place-items: center;
}
.intnet__hub img { width: 52px; height: 52px; }
@media (max-width: 560px) {
  .intnet { max-width: 340px; }
  .intnet__node { width: 46px; height: 46px; }
  .intnet__node .tool { width: 23px; height: 23px; }
  .intnet__hub { width: 88px; height: 88px; }
  .intnet__hub img { width: 42px; height: 42px; }
}

/* ===== "Una única fuente de verdad" — band oscuro con stats (conteo) ===== */
.truth { position: relative; overflow: hidden; background: var(--primary-950); }
.truth > .trusted__grid { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }
.truth > .container { position: relative; z-index: 1; }
.truth .section__eyebrow { color: var(--primary-300); }
.truth .section__title { color: #fff; }
.truth .section__lead { color: var(--primary-200); }
/* Marcador en fondo oscuro: texto blanco + banda azul translúcida (mismo trazo que .mark) */
.truth .mark {
  color: #fff;
  background-image: linear-gradient(120deg, rgba(87, 174, 217, 0.50) 0%, rgba(49, 149, 198, 0.32) 100%);
}
.stats {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 44px 56px;
  max-width: 820px; margin: 52px auto 0;
}
.stat { text-align: center; position: relative; padding: 4px 12px; }
.stat:nth-child(even)::before {
  content: ""; position: absolute; left: -28px; top: 8%; bottom: 8%;
  width: 1px; background: rgba(255, 255, 255, 0.14);
}
.stat__num {
  display: block; font-size: clamp(36px, 4.6vw, 48px); font-weight: 700; line-height: 1;
  color: #fff; letter-spacing: -0.02em; font-variant-numeric: tabular-nums;
}
.stat__label { display: block; margin-top: 12px; font-size: var(--fs-body2); color: var(--primary-200); }
@media (max-width: 560px) {
  .stats { grid-template-columns: 1fr; gap: 32px; max-width: 320px; }
  .stat:nth-child(even)::before { display: none; }
  .stat__num { font-size: 40px; }
}

/* Imágenes dentro del media de los splits (enterprise) */
.split__img {
  width: 100%; height: auto; display: block;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
}

/* ===== MCP — ventana grande centrada (placeholder de animación Claude Code) ===== */
.ccdemo {
  max-width: 940px; margin: 8px auto 0;
  border: 1px solid var(--border-strong); border-radius: var(--radius-lg);
  overflow: hidden; background: var(--surface); box-shadow: var(--shadow-card);
}
.ccdemo__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 15px; background: var(--surface-soft);
  border-bottom: 1px solid var(--border);
}
.ccdemo__title { margin-left: 8px; font-family: var(--font-mono); font-size: 12px; color: var(--text-muted); }
.ccdemo__body {
  position: relative; aspect-ratio: 16 / 9;
  display: grid; place-items: center;
  background: var(--primary-950);
}
.ccdemo__video { width: 100%; height: 100%; object-fit: contain; display: block; background: var(--primary-950); }
@media (max-width: 560px) { .ccdemo__body { aspect-ratio: 4 / 3; } }

/* ============================================================
   Atlas · Demo "Explora el territorio" (Paso 1)
   Card con chrome tipo ventana + mapa animado (choropleth →
   establecimientos → radio). Controlado por js/atlas-explore.js.
   ============================================================ */
.amap {
  --c-compras: var(--primary-500);
  --c-finanzas: var(--primary-800);
  --c-salud: var(--melon-600);
  --c-comida: var(--green-600);
  --c-entretenimiento: var(--guinda-500);
  width: 100%; max-width: 560px; margin: 0 auto; text-align: left;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-card);
  overflow: hidden;
}
.amap__bar { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: var(--surface-soft); border-bottom: 1px solid var(--border); }
.amap__dot { width: 11px; height: 11px; border-radius: 50%; flex: none; }
.amap__dot--r { background: var(--primary-700); }
.amap__dot--y { background: var(--primary-500); }
.amap__dot--g { background: var(--primary-300); }

.amap__stage {
  position: relative; aspect-ratio: 420 / 320; overflow: hidden;
  background: #d7e1e9;
}
.amap__svg { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

/* --- Basemap vectorial (estilo mapa real) --- */
.amap__land  { fill: #d7e1e9; }

/* Calles: casing gris + trazo blanco encima */
.amap__rcase { fill: none; stroke: #c2cedb; stroke-width: 8; stroke-linecap: round; stroke-linejoin: round; }
.amap__rcase--min { stroke-width: 4.5; }
.amap__road  { fill: none; stroke: #ffffff; stroke-width: 5; stroke-linecap: round; stroke-linejoin: round; }
.amap__road--min { stroke: #eef3f7; stroke-width: 2.4; }

/* Etiquetas de colonias */
.amap__lbl {
  fill: #5d7080; font-family: var(--font-sans); font-style: italic; font-weight: 600;
  font-size: 13px; letter-spacing: .12em; text-anchor: middle; opacity: .9;
}
.amap__lbl--town { font-style: normal; font-weight: 500; font-size: 10.5px; letter-spacing: .02em; fill: #46586a; }

/* Establecimientos: pins tipo gota que caen */
.amap__pindot { fill: #fff; }
.amap__pin {
  opacity: 0; transform: translateY(-12px) scale(.5);
  transform-box: fill-box; transform-origin: 50% 100%;
  transition: transform .5s cubic-bezier(0.34,1.56,0.64,1), opacity .35s ease;
  transition-delay: calc(var(--i, 0) * 40ms);
  filter: drop-shadow(0 1.5px 1.5px rgba(19,50,71,.25));
}
.amap.is-poi .amap__pin { opacity: 1; transform: none; }
.amap__pin[data-cat="compras"]         { fill: var(--c-compras); }
.amap__pin[data-cat="finanzas"]        { fill: var(--c-finanzas); }
.amap__pin[data-cat="salud"]           { fill: var(--c-salud); }
.amap__pin[data-cat="comida"]          { fill: var(--c-comida); }
.amap__pin[data-cat="entretenimiento"] { fill: var(--c-entretenimiento); }
/* En selección: los de fuera del radio se atenúan, los de dentro saltan un poco */
.amap.is-sel .amap__pin.is-out { opacity: .26; }
.amap.is-sel .amap__pin.is-in  { transform: translateY(-3px) scale(1.12); }

/* Radio de análisis */
.amap__sel { opacity: 0; transition: opacity .4s ease; }
.amap.is-sel .amap__sel { opacity: 1; }
.amap__selfill { fill: rgba(49, 149, 198, 0.10); }
.amap__selring {
  fill: none; stroke: var(--primary-600); stroke-width: 2; stroke-dasharray: 5 5;
  transform: scale(0); transform-box: fill-box; transform-origin: center;
  transition: transform .6s cubic-bezier(0.34,1.56,0.64,1);
}
.amap.is-sel .amap__selring { transform: scale(1); }
.amap__selcore { fill: var(--primary-700); }

/* Leyenda de categorías */
.amap__legend {
  position: absolute; left: 12px; bottom: 12px; z-index: 3;
  display: flex; flex-direction: column; gap: 4px;
  padding: 9px 11px; background: rgba(255,255,255,0.92); backdrop-filter: blur(2px);
  border: 1px solid var(--border); border-radius: 8px; box-shadow: var(--shadow-card);
  opacity: 0; transform: translateY(6px); transition: opacity .4s ease, transform .4s ease;
}
.amap.is-poi .amap__legend { opacity: 1; transform: none; }
.amap__leg { display: flex; align-items: center; gap: 7px; font-size: 11px; color: var(--text-body); }
.amap__leg i { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.amap__leg[data-cat="compras"] i         { background: var(--c-compras); }
.amap__leg[data-cat="finanzas"] i        { background: var(--c-finanzas); }
.amap__leg[data-cat="salud"] i           { background: var(--c-salud); }
.amap__leg[data-cat="comida"] i          { background: var(--c-comida); }
.amap__leg[data-cat="entretenimiento"] i { background: var(--c-entretenimiento); }

/* Chip de resultado */
.amap__chip {
  position: absolute; right: 12px; bottom: 12px; z-index: 3;
  display: flex; flex-direction: column; gap: 1px;
  padding: 9px 12px; background: var(--primary-950); color: #fff;
  border-radius: 8px; box-shadow: 0 10px 24px rgba(19,50,71,.28);
  opacity: 0; transform: translateY(6px); transition: opacity .4s ease, transform .4s ease;
}
.amap.is-sel .amap__chip { opacity: 1; transform: none; }
.amap__chipk { font-size: 10px; color: var(--primary-200); font-family: var(--font-mono); letter-spacing: .02em; }
.amap__chipv { font-size: 12.5px; }
.amap__chipv b { font-size: 15px; font-weight: 700; }

@media (max-width: 560px) {
  .amap__legend { gap: 3px; padding: 7px 9px; }
  .amap__leg { font-size: 10px; }
}
@media (prefers-reduced-motion: reduce) {
  .amap__pin, .amap__sel, .amap__selring, .amap__legend, .amap__chip { transition: none; }
}

/* ============================================================
   Atlas · Demo "Define lo que importa" (Paso 2)
   Panel de pesos: buscador + filas con stepper (−/valor/+) que se
   pone azul (atractor +) o rojo (competidor −). js/atlas-weights.js.
   ============================================================ */
.wpan {
  position: relative; width: 100%; max-width: 520px; margin: 0 auto; text-align: left;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-card);
  padding: 18px; overflow: hidden;
}
.wpan__search {
  display: flex; align-items: center; gap: 9px;
  padding: 11px 13px; border: 1px solid var(--border-strong); border-radius: 8px;
  color: var(--text-faint); font-size: 13.5px;
}
.wpan__search svg { color: var(--text-faint); flex: none; }

.wpan__clear {
  display: block; width: 100%; margin-top: 12px; padding: 11px 12px;
  font: inherit; font-size: 13.5px; font-weight: 600; cursor: pointer;
  color: var(--melon-600); background: rgba(224, 62, 34, 0.06);
  border: 1px solid rgba(224, 62, 34, 0.25); border-radius: 8px;
  transition: background .15s ease, transform .12s ease;
}
.wpan__clear.is-press { background: rgba(224, 62, 34, 0.16); transform: scale(0.98); }

.wpan__count { margin: 16px 0 4px; font-size: 13.5px; font-weight: 700; color: var(--text-heading); }

.wpan__sec {
  margin: 14px 0 7px; font-size: var(--fs-overline); font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint);
}

.wpan__row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px 9px 13px; background: var(--surface-soft);
  border: 1px solid var(--border); border-radius: 8px;
}
.wpan__name { flex: 1 1 auto; font-size: 13.5px; color: var(--text-heading); }

/* Stepper */
.wpan__step {
  display: inline-flex; align-items: stretch; flex: none;
  border: 1px solid var(--border-strong); border-radius: 7px; overflow: hidden;
  background: var(--surface);
}
.wpan__minus, .wpan__plus {
  width: 34px; border: none; background: var(--surface); cursor: pointer;
  font: inherit; font-size: 17px; line-height: 1; color: var(--text-muted);
  display: grid; place-items: center; transition: background .15s ease, color .15s ease, transform .1s ease;
}
.wpan__val {
  min-width: 42px; padding: 0 6px; display: grid; place-items: center;
  font-size: 14px; font-weight: 700; color: var(--text-muted);
  border-left: 1px solid var(--border-strong); border-right: 1px solid var(--border-strong);
  transition: color .15s ease;
}
/* Atractor (+): azul navy */
.wpan__row.is-pos .wpan__plus { background: var(--primary-800); color: #fff; }
.wpan__row.is-pos .wpan__val  { color: var(--primary-800); }
/* Competidor (−): rojo */
.wpan__row.is-neg .wpan__minus { background: var(--melon-500); color: #fff; }
.wpan__row.is-neg .wpan__val   { color: var(--melon-600); }
/* Pulso al "presionar" */
.wpan__minus.is-press, .wpan__plus.is-press { transform: scale(0.86); }

.wpan__x {
  flex: none; width: 26px; height: 26px; border: none; background: none; cursor: pointer;
  font-size: 18px; line-height: 1; color: var(--text-faint);
  display: grid; place-items: center; border-radius: 6px;
  transition: color .15s ease, background .15s ease;
}

/* Cursor del demo */
.wpan__cursor {
  position: absolute; top: 0; left: 0; z-index: 5; pointer-events: none;
  filter: drop-shadow(0 2px 3px rgba(19, 50, 71, 0.3));
  opacity: 0; transform: translate(-2px, -2px);
  transition: left .5s cubic-bezier(0.5, 0, 0.2, 1), top .5s cubic-bezier(0.5, 0, 0.2, 1), opacity .3s ease;
}
.wpan.is-live .wpan__cursor { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  .wpan__clear, .wpan__minus, .wpan__plus, .wpan__val, .wpan__cursor { transition: none; }
  .wpan__cursor { display: none; }
}

/* ============================================================
   Atlas · Demo "Encuentra las mejores ubicaciones" (Paso 3)
   Panel de ranking simplificado: 2 sliders + lista rankeada con
   scores que cuentan hacia arriba. Controlado por js/atlas-rank.js.
   ============================================================ */
.rpan {
  width: 100%; max-width: 460px; margin: 0 auto; text-align: left;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-card);
  padding: 20px;
}
.rpan__eyebrow {
  margin: 0 0 14px; font-size: var(--fs-overline); font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint);
}
.rpan__ctrl { margin-bottom: 16px; }
.rpan__ctrlhead { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 9px; }
.rpan__ctrlhead span { font-size: 13.5px; font-weight: 600; color: var(--text-heading); }
.rpan__v { font-size: 13px; color: var(--text-heading); font-variant-numeric: tabular-nums; }
.rpan__track { position: relative; height: 4px; border-radius: 999px; background: var(--border-strong); }
.rpan__knob {
  position: absolute; top: 50%; left: 0; width: 16px; height: 16px; border-radius: 50%;
  background: var(--primary-900); border: 2px solid var(--surface);
  box-shadow: 0 1px 3px rgba(19,50,71,.3);
  transform: translate(-50%, -50%) scale(0);
  transition: left .7s cubic-bezier(0.5, 0, 0.2, 1), transform .35s cubic-bezier(0.34,1.56,0.64,1);
}
.rpan.is-set .rpan__knob { left: var(--pos, 50%); transform: translate(-50%, -50%) scale(1); }

.rpan__rule { height: 1px; background: var(--border); margin: 4px 0 6px; }

.rpan__list { list-style: none; margin: 0; padding: 0; }
.rpan__item {
  display: flex; align-items: center; gap: 13px; padding: 12px 2px;
  border-bottom: 1px solid var(--border);
  opacity: 0; transform: translateY(8px);
  transition: opacity .45s ease, transform .45s ease;
  transition-delay: calc(var(--i, 0) * 0.12s);
}
.rpan.is-rank .rpan__item { opacity: 1; transform: none; }
.rpan__rank { flex: none; width: 18px; font-size: 15px; font-weight: 600; color: var(--text-faint); text-align: center; }
.rpan__zone { flex: 1 1 auto; display: flex; flex-direction: column; gap: 1px; }
.rpan__zone b { font-size: 15px; font-weight: 700; color: var(--text-heading); }
.rpan__zone span { font-size: 12px; color: var(--text-muted); }
.rpan__score { flex: none; font-size: 19px; font-weight: 700; color: var(--primary-600); font-variant-numeric: tabular-nums; }
/* #1 destacado */
.rpan__item:first-child .rpan__rank { color: var(--primary-700); }

.rpan__more {
  margin-top: 14px; padding: 11px; text-align: center;
  font-size: 13.5px; font-weight: 600; color: var(--text-heading);
  border: 1px solid var(--border-strong); border-radius: 8px;
}

@media (prefers-reduced-motion: reduce) {
  .rpan__knob, .rpan__item { transition: none; }
}

/* --- Demos no interactivos: cursor normal, nada clickable --- */
.amap, .wpan, .rpan { pointer-events: none; }
.wpan__minus, .wpan__plus, .wpan__x, .wpan__clear { cursor: default; }

/* ============================================================
   Atlas · Demo "Lleva el territorio a tus modelos" (API)
   Ventana de código oscura: request pinpoint + respuesta JSON
   que se revela línea por línea. Controlado por js/atlas-api.js.
   ============================================================ */
.apidemo {
  width: 100%; max-width: 420px; margin: 0 auto; text-align: left;
  background: var(--primary-950); border: 1px solid var(--primary-900);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-card);
  overflow: hidden; pointer-events: none;
}
.apidemo__bar {
  display: flex; align-items: center; gap: 7px; padding: 8px 13px;
  background: rgba(255, 255, 255, 0.04); border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.apidemo__dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.apidemo__dot--r { background: var(--primary-600); }
.apidemo__dot--y { background: var(--primary-400); }
.apidemo__dot--g { background: var(--primary-300); }
.apidemo__body { padding: 20px 16px 22px; }
.apidemo__code {
  display: block; font-family: var(--font-mono); font-size: 11px; line-height: 2.05;
  color: #9fc6e0; white-space: normal; overflow-x: auto;
}
.apidemo__code .ln {
  display: block; white-space: pre; opacity: 0; transform: translateY(3px);
  transition: opacity .3s ease, transform .3s ease;
}
.apidemo__code .ln.is-on { opacity: 1; transform: none; }
.apidemo__code .tok-prompt { color: var(--green-500); font-weight: 600; }
.apidemo__code .tok-key { color: #6fc7ef; }
.apidemo__code .tok-str { color: var(--green-300); }
.apidemo__code .tok-cmt { color: #5f7c90; }

.apidemo__note {
  display: inline-flex; align-items: center; margin-top: 11px;
  font-family: var(--font-mono); font-size: 10px; color: var(--primary-100);
  background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 4px 9px; border-radius: 999px;
  opacity: 0; transform: translateY(4px); transition: opacity .4s ease, transform .4s ease;
}
.apidemo__note.is-on { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .apidemo__code .ln, .apidemo__note { transition: none; }
}
