/* Reusable UI: nav, buttons, card grids, goverless motes — Bloqio OS components.
 * Page-specific holo/hero/shine surfaces: styles/pages.css. System map: styles/tokens.css.
 * Holoform card families (A .glass-card / B goverless+shine stack) + reserved bhf-* names: see tokens.css
 *   (“Bloqio Holoform — official taxonomy” block, documentation only). */

/* —— Eyebrow —— */
/* Section / hero overlines — refined sentence case (reference: home “Por qué existe Bloqio”) */
.eyebrow {
  display: block;
  font-family: var(--font-subheader);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-3);
  line-height: var(--leading-snug);
}

/* —— Buttons —— Holo Motion: liquid-glass hover (primary + secondary) —— */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1;
  color: #fff;
  text-decoration: none;
  border-radius: var(--radius-full);
  border: 1px solid color-mix(in srgb, var(--color-cta) 42%, #1a3066);
  background:
    linear-gradient(
      165deg,
      color-mix(in srgb, #fff 12%, var(--color-cta)) 0%,
      var(--color-cta) 55%,
      color-mix(in srgb, var(--color-cta) 92%, #444) 100%
    );
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.22) inset,
    0 1px 2px rgba(68, 68, 68, 0.07);
  transition:
    background var(--holo-motion-duration-fast) var(--holo-motion-ease),
    border-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
    filter var(--holo-motion-duration-fast) var(--holo-motion-ease),
    transform var(--holo-motion-duration-micro) var(--holo-motion-ease),
    box-shadow var(--holo-motion-duration-micro) var(--holo-motion-ease);
}

.button:hover {
  color: #fff;
  border-color: color-mix(in srgb, var(--color-cta) 55%, #152550);
  background:
    linear-gradient(
      168deg,
      color-mix(in srgb, #fff 18%, var(--color-cta-hover)) 0%,
      var(--color-cta-hover) 48%,
      color-mix(in srgb, var(--color-cta-hover) 88%, #2a2a2a) 100%
    );
  transform: translateY(-1px);
  box-shadow: var(--shadow-button-primary-hover);
}

.button:active {
  transition-duration: var(--holo-motion-duration-press);
  transform: translateY(1px) scale(0.985);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.1) inset,
    0 1px 6px rgba(0, 0, 0, 0.06);
}

.button:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .button {
    transition:
      background var(--motion-duration-fast) var(--ease-out),
      border-color var(--motion-duration-fast) var(--ease-out);
  }

  .button:hover {
    transform: none;
  }

  .button:active {
    transform: none;
  }
}

.button--secondary {
  color: var(--color-text);
  border: 1px solid var(--bloqio-glass-border);
  background:
    linear-gradient(
      155deg,
      rgba(255, 255, 255, 0.94) 0%,
      color-mix(in srgb, var(--bloqio-glass-bg) 100%, transparent) 100%
    );
  box-shadow: var(--bloqio-glass-shadow);
  backdrop-filter: blur(var(--bloqio-glass-blur)) saturate(1.12);
  -webkit-backdrop-filter: blur(var(--bloqio-glass-blur)) saturate(1.12);
}

.button--secondary:hover {
  color: var(--color-text);
  border-color: color-mix(in srgb, var(--color-identity) 14%, var(--color-border-strong));
  background:
    linear-gradient(
      158deg,
      rgba(255, 255, 255, 0.995) 0%,
      color-mix(in srgb, #fff 92%, var(--color-bg-soft)) 100%
    );
  transform: translateY(-1px);
  box-shadow: var(--shadow-button-secondary-hover);
  filter: brightness(1.012);
}

.button--secondary:active {
  transition-duration: var(--holo-motion-duration-press);
  transform: translateY(1px) scale(0.985);
}

@media (prefers-reduced-motion: reduce) {
  .button--secondary:hover,
  .button--secondary:active {
    transform: none;
    filter: none;
  }
}

/* —— Ghost / tertiary —— Liquid Glass (same hierarchy as secondary; quieter fill) —— */
.button--ghost {
  color: var(--color-text);
  border: 1px solid color-mix(in srgb, var(--color-border) 88%, var(--color-accent-blue) 12%);
  background:
    linear-gradient(
      158deg,
      rgba(255, 255, 255, 0.62) 0%,
      color-mix(in srgb, var(--bloqio-glass-bg) 55%, transparent) 100%
    );
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.55) inset;
  backdrop-filter: blur(var(--bloqio-glass-blur)) saturate(1.06);
  -webkit-backdrop-filter: blur(var(--bloqio-glass-blur)) saturate(1.06);
}

.button--ghost:hover {
  color: var(--color-text);
  border-color: color-mix(in srgb, var(--color-identity) 12%, var(--color-border-strong));
  background:
    linear-gradient(
      162deg,
      rgba(255, 255, 255, 0.92) 0%,
      color-mix(in srgb, #fff 78%, var(--color-bg-soft)) 100%
    );
  transform: translateY(-1px);
  box-shadow: var(--shadow-button-ghost-hover);
  filter: brightness(1.01);
}

.button--ghost:active {
  transition-duration: var(--holo-motion-duration-press);
  transform: translateY(1px) scale(0.985);
}

.button--ghost:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .button--ghost {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .button--ghost:hover,
  .button--ghost:active {
    transform: none;
    filter: none;
  }
}

/* Alias hooks (Holo Motion system; inherits .button rules) */
.button.liquid-glass-hover,
.button.holo-motion-button {
  /* intentional no-op: documents liquid-glass treatment on .button */
}

.button--sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
}

/* —— Live status pill (e.g. App Embed activo) —— */
.live-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.03em;
  color: #444444;
  border: 1px solid color-mix(in srgb, #14ff00 18%, var(--color-border));
  background: color-mix(in srgb, #14ff00 7%, var(--color-bg-soft));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 55%, transparent);
}

.live-pill__text {
  color: #444444;
}

.live-pill__dot {
  flex-shrink: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: #14ff00;
  box-shadow: 0 0 0 1px color-mix(in srgb, #14ff00 35%, rgba(255, 255, 255, 0.9));
}

@media (prefers-reduced-motion: no-preference) {
  .live-pill {
    transition:
      border-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
      background-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
      box-shadow var(--holo-motion-duration-fast) var(--holo-motion-ease),
      transform var(--holo-motion-duration-fast) var(--holo-motion-ease);
  }

  .live-pill:hover {
    transform: translateY(-0.5px);
    border-color: color-mix(in srgb, #14ff00 26%, var(--color-border));
    box-shadow:
      inset 0 1px 0 color-mix(in srgb, #fff 62%, transparent),
      0 6px 16px color-mix(in srgb, #444 5%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .live-pill:hover {
    transform: none;
  }
}

/* Visible live pulse — class .live-pill--active (como-funciona “App embed activo” only) */
@media (prefers-reduced-motion: no-preference) {
  .live-pill--active .live-pill__dot {
    animation: live-pill-dot-pulse-active 2.75s ease-in-out infinite;
  }
}

@keyframes live-pill-dot-pulse-active {
  0%,
  100% {
    opacity: 1;
    transform: scale(1);
    box-shadow:
      0 0 0 1px color-mix(in srgb, #14ff00 30%, rgba(255, 255, 255, 0.92)),
      0 0 0 0 color-mix(in srgb, #14ff00 16%, transparent);
  }

  50% {
    opacity: 0.86;
    transform: scale(1.14);
    box-shadow:
      0 0 0 1px color-mix(in srgb, #14ff00 24%, rgba(255, 255, 255, 0.9)),
      0 0 0 7px color-mix(in srgb, #14ff00 12%, transparent),
      0 0 18px 2px color-mix(in srgb, #14ff00 9%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .live-pill--active .live-pill__dot {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

/* —— Text link / inline CTA — default for internal text links (not .button) —— */
.text-link,
.inline-cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  font-family: inherit;
  font-weight: 600;
  line-height: inherit;
  color: var(--color-link);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: color var(--motion-duration-fast) var(--ease-out);
}

.text-link::before,
.inline-cta::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.12em;
  height: 1px;
  width: 100%;
  background-color: currentColor;
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left center;
  transition:
    transform var(--motion-duration) var(--ease-out),
    opacity var(--motion-duration-fast) var(--ease-out);
}

.text-link::after,
.inline-cta::after {
  content: "\2192";
  display: inline-block;
  font-size: 0.82em;
  font-weight: 500;
  opacity: 0.68;
  transition:
    transform var(--motion-duration-fast) var(--ease-out),
    opacity var(--motion-duration-fast) var(--ease-out);
}

.text-link:hover,
.text-link:focus-visible,
.inline-cta:hover,
.inline-cta:focus-visible {
  color: var(--color-link-hover);
}

.text-link:hover::before,
.text-link:focus-visible::before,
.inline-cta:hover::before,
.inline-cta:focus-visible::before {
  transform: scaleX(1);
  opacity: 0.42;
}

.text-link:hover::after,
.text-link:focus-visible::after,
.inline-cta:hover::after,
.inline-cta:focus-visible::after {
  transform: translateX(0.14em);
  opacity: 0.88;
}

.text-link:focus-visible,
.inline-cta:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
}

.text-link:focus:not(:focus-visible),
.inline-cta:focus:not(:focus-visible) {
  outline: none;
}

@media (prefers-reduced-motion: reduce) {
  .text-link::before,
  .text-link::after,
  .inline-cta::before,
  .inline-cta::after {
    transition: none;
  }

  .text-link:hover::after,
  .text-link:focus-visible::after,
  .inline-cta:hover::after,
  .inline-cta:focus-visible::after {
    transform: none;
  }
}

/* —— Status signal (acid green dot + legible neutral copy; inline, lists, cards) —— */
.status-signal {
  --status-signal-bg: color-mix(in srgb, var(--color-accent-green) 6.5%, var(--color-bg));
  --status-signal-border: color-mix(in srgb, var(--color-accent-green) 20%, transparent);

  display: inline-flex;
  align-items: center;
  gap: 0.42em;
  max-width: 100%;
  padding: 0.12em 0.5em 0.14em 0.42em;
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: var(--leading-relaxed, 1.65);
  letter-spacing: inherit;
  color: var(--color-identity);
  vertical-align: baseline;
  background: var(--status-signal-bg);
  border: 1px solid var(--status-signal-border);
  border-radius: var(--radius-sm);
  box-decoration-break: clone;
}

.status-signal__dot {
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  margin: 0;
  padding: 0;
  border-radius: 50%;
  background: var(--color-accent-green);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-accent-green) 28%, transparent);
}

/* —— Bloqio Glass card —— */
.glass-card {
  position: relative;
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      128deg,
      color-mix(in srgb, #fff 22%, var(--color-accent-blue) 2%) 0%,
      transparent 44%
    ),
    linear-gradient(
      214deg,
      transparent 48%,
      color-mix(in srgb, var(--color-accent-orange) 3.5%, transparent) 100%
    ),
    radial-gradient(
      88% 62% at 88% 8%,
      color-mix(in srgb, var(--color-accent-orange) 5%, transparent),
      transparent 52%
    ),
    radial-gradient(
      120% 78% at 10% -4%,
      color-mix(in srgb, var(--bhf-glass-highlight) 38%, transparent),
      transparent 56%
    ),
    linear-gradient(
      164deg,
      color-mix(in srgb, var(--bhf-paper) 90%, var(--bhf-glass-fill) 10%) 0%,
      color-mix(in srgb, var(--bhf-paper-soft) 70%, #fff) 100%
    );
  border: 1px solid var(--bhf-glass-border);
  box-shadow: var(--bhf-glass-shadow);
  backdrop-filter: blur(var(--bloqio-glass-blur-strong)) saturate(var(--bloqio-glass-saturate));
  -webkit-backdrop-filter: blur(var(--bloqio-glass-blur-strong)) saturate(var(--bloqio-glass-saturate));
  transition:
    background var(--holo-motion-duration-fast) var(--holo-motion-ease),
    box-shadow var(--holo-motion-duration-fast) var(--holo-motion-ease),
    border-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
    transform var(--holo-motion-duration-micro) var(--holo-motion-ease);
}

@media (prefers-reduced-motion: no-preference) {
  .glass-card:hover {
    transform: translateY(-1px);
    box-shadow: var(--bhf-glass-shadow-hover);
    border-color: color-mix(in srgb, var(--bhf-glass-border) 90%, var(--bhf-lumenedge-muted) 10%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .glass-card {
    transition: none;
  }

  .glass-card:hover {
    transform: none;
    box-shadow: var(--bhf-glass-shadow);
  }
}

.glass-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: var(--space-8);
  right: var(--space-8);
  height: 1px;
  border-radius: var(--radius-full);
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in srgb, var(--color-accent-blue) 18%, transparent),
    transparent
  );
  pointer-events: none;
}

/* =============================================================================
   Bloqio Holoform future aliases — not applied in HTML yet
   Step 4: hook classes for premium cards; no visual rules (no second card system).
   .bhf-card--priority is a future label; it must be used with the current stack:
   .goverless-surface--card, .shine-card, child .shine-card__ring, optional
   .goverless-card-hover, optional .shine-card__surface / --holo-panel
   (see styles/tokens.css “Bloqio Holoform — official taxonomy”).
   Migration: additive only — add bhf classes alongside existing ones first; do not
   remove legacy classes in the same pass.
   Future HTML example (not live; do not paste into pages until approved):
   <article class="bhf-card bhf-card--priority goverless-surface goverless-surface--card shine-card goverless-card-hover">
     <span class="shine-card__ring" aria-hidden="true"></span>
     …
   </article>
   ============================================================================= */

.bhf-card {
  /* Reserved: umbrella hook; zero declarations until a planned migration. */
}

.bhf-card--priority {
  /* Priority hook: only augments existing shine/goverless stack where adopted. */
  isolation: isolate;
}

@media (prefers-reduced-motion: no-preference) {
  .bhf-card--priority.goverless-card-hover:hover {
    transform: translateY(-2px);
    box-shadow:
      0 1px 0 color-mix(in srgb, #fff 92%, transparent) inset,
      0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 22%, transparent),
      0 12px 40px color-mix(in srgb, var(--bhf-lumenedge-depth) 42%, transparent),
      0 28px 56px color-mix(in srgb, var(--color-identity) 4%, transparent);
  }
}

/* —— Product card —— (Holoform “Product Catalog” premium family (B) with
 *  .product-catalog-card + .product-catalog-card--shine on /apps; not the shine+ring
 *  stack — see styles/tokens.css “Card taxonomy”.) */
.product-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background:
    linear-gradient(
      168deg,
      color-mix(in srgb, #fff 91%, var(--bhf-glass-fill) 9%) 0%,
      #fff 100%
    );
  border: 1px solid color-mix(in srgb, var(--bhf-glass-border) 88%, var(--bhf-lumenedge-muted) 4%);
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 85%, transparent) inset,
    var(--color-shadow-card);
  backdrop-filter: blur(6px) saturate(1.04);
  -webkit-backdrop-filter: blur(6px) saturate(1.04);
  transition:
    box-shadow var(--holo-motion-duration-fast) var(--holo-motion-ease),
    transform var(--holo-motion-duration-fast) var(--holo-motion-ease),
    border-color var(--holo-motion-duration-fast) var(--holo-motion-ease);
}

.product-card:hover {
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 80%, transparent) inset,
    0 10px 32px rgba(68, 68, 68, 0.07),
    0 20px 48px color-mix(in srgb, var(--bhf-lumenedge-depth) 8%, transparent);
  border-color: var(--color-border-strong);
  transform: translateY(-1px);
}

@media (prefers-reduced-motion: reduce) {
  .product-card:hover {
    transform: none;
  }
}

.product-card__visual {
  position: relative;
  aspect-ratio: 16 / 10;
  background: linear-gradient(
    155deg,
    var(--color-bg-soft-alt) 0%,
    var(--color-bg-soft) 45%,
    #e8e8e8 100%
  );
}

.product-card__abstract {
  position: absolute;
  inset: 0;
}

.product-card__abstract--prometeo {
  background:
    linear-gradient(148deg, rgba(245, 145, 30, 0.09) 0%, transparent 42%),
    repeating-linear-gradient(
      -8deg,
      transparent,
      transparent 10px,
      rgba(68, 68, 68, 0.035) 10px,
      rgba(68, 68, 68, 0.035) 11px
    ),
    linear-gradient(165deg, var(--color-bg-soft-alt), var(--color-bg-soft));
}

.product-card__abstract--hermes {
  background:
    linear-gradient(210deg, color-mix(in srgb, var(--color-accent-blue) 14%, transparent) 0%, transparent 55%),
    repeating-linear-gradient(
      88deg,
      transparent,
      transparent 20px,
      rgba(68, 68, 68, 0.04) 20px,
      rgba(68, 68, 68, 0.04) 21px
    ),
    linear-gradient(175deg, var(--color-bg-soft), var(--color-bg-soft-alt));
}

.product-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-3);
  padding: var(--space-6);
  border-top: 1px solid color-mix(in srgb, var(--color-border) 82%, var(--bhf-lumenedge-muted) 4%);
  background: color-mix(in srgb, #fff 94%, var(--bhf-glass-fill) 6%);
}

/* Card context: reset .eyebrow vertical rhythm inside product-card__body */
.product-card__eyebrow {
  margin: 0;
}

.product-card__name {
  font-family: var(--font-subheader);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}

.product-card__subtitle {
  font-family: var(--font-subheader);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-text-subtle);
  margin: 0 0 var(--space-2);
}

.product-card__tagline {
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: var(--leading-snug);
  color: var(--color-identity);
  margin: 0;
}

.product-card__desc {
  flex: 1;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
}

.product-card__state {
  font-size: var(--text-xs);
  line-height: var(--leading-relaxed);
  color: var(--color-text-subtle);
  margin: 0;
}

.product-card__points {
  margin: 0;
  padding-left: 1.15rem;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  list-style: disc;
}

.product-card__points li + li {
  margin-top: var(--space-2);
}

.product-card__points li:has(.status-signal) {
  list-style: none;
}

/* Layout hook; pair with .text-link for inline CTA pattern */
.product-card__link {
  align-self: flex-start;
  margin-top: var(--space-4);
  font-size: var(--text-sm);
}

/* —— Feature grid —— */
.feature-grid {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 40rem) {
  .feature-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
  }
}

.feature-grid__item h3 {
  font-family: var(--font-subheader);
  font-size: var(--text-md);
  font-weight: 600;
  margin-bottom: var(--space-2);
  color: var(--color-text);
}

.feature-grid__item p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

/* —— Header nav + mobile: Holoform glass “plaque” (no full-bleed sheet) —— */
/* Mobile-only: soft full-viewport veil (blocks taps; not a grey mud smear) */
@media (max-width: 63.99rem) {
  body {
    --site-nav-panel-duration: 0.4s;
  }

  @media (prefers-reduced-motion: reduce) {
    body {
      --site-nav-panel-duration: var(--holo-motion-duration-fast);
    }
  }

  body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 44;
    /* Tinta mínima: separa el plano de la página sin robar el foco a la card */
    background: color-mix(in srgb, #fff 2.5%, var(--color-bg) 1.5%, transparent 96%);
    backdrop-filter: blur(3px) saturate(0.98);
    -webkit-backdrop-filter: blur(3px) saturate(0.98);
    box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 5%, transparent);
    opacity: 0;
    pointer-events: none;
    box-sizing: border-box;
    transition: opacity var(--site-nav-panel-duration) var(--holo-motion-ease);
  }

  body.site-nav-open::before {
    opacity: 0.86;
    pointer-events: auto;
  }
}

.site-header__nav {
  --site-nav-panel-duration: 0.4s;
  position: fixed;
  left: 50%;
  right: auto;
  top: calc(var(--site-header-stack-height, var(--header-height)) + var(--space-2));
  bottom: auto;
  z-index: 45;
  isolation: isolate;
  box-sizing: border-box;
  inline-size: min(22.5rem, calc(100% - 2rem));
  width: min(22.5rem, calc(100% - 2rem));
  max-width: 100%;
  min-width: 0;
  padding: var(--space-3);
  max-height: min(78dvh, calc(100dvh - var(--site-header-stack-height, var(--header-height)) - var(--space-6)));
  overflow-x: clip;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  /* LumenEdge en ::after; fill opaco-cristal, frosted + sombras = lectura y volumen */
  border: 1px solid color-mix(in srgb, var(--bhf-glass-border) 35%, var(--bhf-lumenedge-muted) 10%);
  border-radius: 1.5rem;
  background:
    linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.92) 0%,
      rgba(255, 255, 255, 0.82) 42%,
      rgba(255, 255, 255, 0.72) 100%
    ),
    radial-gradient(
      circle at 12% 0%,
      color-mix(in srgb, var(--bhf-lumenedge-blue-mid) 10%, transparent) 0 30%,
      transparent 66%
    ),
    radial-gradient(
      circle at 95% 100%,
      color-mix(in srgb, var(--color-accent-orange) 8%, transparent) 0 32%,
      transparent 70%
    );
  backdrop-filter: blur(44px) saturate(1.12);
  -webkit-backdrop-filter: blur(44px) saturate(1.12);
  /* Espesor óptico + separación del plano de la página */
  box-shadow:
    0 54px 130px rgba(17, 24, 39, 0.2),
    0 26px 60px rgba(17, 24, 39, 0.12),
    0 10px 24px rgba(17, 24, 39, 0.08),
    0 2px 6px rgba(17, 24, 39, 0.06),
    inset 0 2px 0 rgba(255, 255, 255, 0.98),
    inset 1px 0 0 rgba(255, 255, 255, 0.52),
    inset -1px 0 0 rgba(255, 255, 255, 0.26),
    inset 0 -22px 52px rgba(255, 255, 255, 0.28);
  transform: translate3d(-50%, -8px, 0) scale(0.985);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    transform var(--site-nav-panel-duration) var(--holo-motion-ease),
    opacity var(--site-nav-panel-duration) var(--holo-motion-ease),
    visibility 0s linear var(--site-nav-panel-duration);
}

/* Highlight + bisel: luz de cara, espesor en base */
.site-header__nav::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(168deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0) 46%),
    linear-gradient(0deg, rgba(0, 0, 0, 0.05) 0%, transparent 24%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
  opacity: 0.34;
}

/* LumenEdge: anillo 1px, contraste reforzado */
.site-header__nav::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  pointer-events: none;
  padding: 1px;
  background: linear-gradient(
    120deg,
    color-mix(in srgb, #fff 62%, var(--bhf-lumenedge-blue-mid) 0.25%) 0%,
    color-mix(in srgb, var(--bhf-lumenedge-muted) 2.6%, var(--bhf-glass-border) 34%) 50%,
    color-mix(in srgb, #fff 54%, var(--bhf-lumenedge-orange-mid) 0.2%) 100%
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  opacity: 1;
}

.site-header__nav.is-open {
  transform: translate3d(-50%, 0, 0) scale(1);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    transform var(--site-nav-panel-duration) var(--holo-motion-ease),
    opacity var(--site-nav-panel-duration) var(--holo-motion-ease),
    visibility 0s;
}

@media (prefers-reduced-motion: reduce) {
  .site-header__nav {
    --site-nav-panel-duration: var(--holo-motion-duration-fast);
    transform: translate3d(-50%, 0, 0) scale(1);
    transition: opacity var(--holo-motion-duration-fast) var(--holo-motion-ease);
  }

  .site-header__nav.is-open {
    transform: translate3d(-50%, 0, 0) scale(1);
    transition: opacity var(--holo-motion-duration-fast) var(--holo-motion-ease);
  }
}

.site-header__nav > ul {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-width: none;
  margin: 0;
  padding: var(--space-1);
  min-width: 0;
}

.site-header__nav a {
  display: flex;
  align-items: center;
  min-height: 2.75rem;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition:
    background-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
    color var(--holo-motion-duration-fast) var(--holo-motion-ease),
    box-shadow var(--holo-motion-duration-micro) var(--holo-motion-ease),
    transform var(--holo-motion-duration-micro) var(--holo-motion-ease);
}

@media (max-width: 63.99rem) {
  .site-header__nav > ul > li > a {
    font-size: var(--text-base);
    min-height: 2.9rem;
    font-weight: 500;
    background: rgba(255, 255, 255, 0.2);
    box-shadow: inset 0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 0.16, rgba(255, 255, 255, 0.22));
  }

  .site-header__nav > ul > li > a:hover {
    background: rgba(255, 255, 255, 0.36);
  }
}

@media (max-width: 63.99rem) {
  .site-header__nav a:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-focus) 75%, var(--bhf-lumenedge-muted) 10%);
    outline-offset: 2px;
  }

  .site-header__nav a:active {
    background: color-mix(in srgb, var(--bhf-glass-fill) 35%, #fff 65%);
  }
}

/* Apps — minimal dropdown */
.site-header__nav-item--has-sub {
  position: relative;
}

.site-header__subnav {
  list-style: none;
  margin: var(--space-2) 0 0;
  padding: var(--space-2);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--bhf-glass-border) 64%, var(--bhf-lumenedge-muted) 5%);
  background:
    linear-gradient(175deg, rgba(255, 255, 255, 0.32) 0%, rgba(255, 255, 255, 0.16) 100%),
    color-mix(in srgb, #fff 38%, var(--bhf-glass-fill) 62%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
  backdrop-filter: blur(18px) saturate(1.1);
  -webkit-backdrop-filter: blur(18px) saturate(1.1);
}

.site-header__subnav a {
  font-size: var(--text-xs);
  min-height: 2.5rem;
  padding: var(--space-2) var(--space-2);
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
}

.site-header__subnav a:hover {
  color: var(--color-text);
  background: color-mix(in srgb, #fff 70%, var(--bhf-glass-fill) 30%);
}

@media (min-width: 64rem) {
  .site-header__subnav {
    position: absolute;
    top: calc(100% + 2px);
    left: 50%;
    transform: translate3d(-50%, 4px, 0);
    min-width: 11.5rem;
    padding: var(--space-2);
    margin: 0;
    border-left: 0;
    border-radius: var(--radius-md);
    background:
      radial-gradient(140% 90% at 20% 0%, color-mix(in srgb, #fff 45%, transparent), transparent 50%),
      linear-gradient(
        170deg,
        color-mix(in srgb, var(--bloqio-glass-bg) 95%, #fff) 0%,
        color-mix(in srgb, var(--bloqio-glass-bg) 84%, #f5f5f5) 100%
      );
    border: 1px solid color-mix(in srgb, var(--bhf-glass-border) 88%, var(--bhf-lumenedge-muted) 5%);
    box-shadow:
      0 1px 0 color-mix(in srgb, #fff 88%, transparent) inset,
      0 0 0 0.5px color-mix(in srgb, var(--color-identity) 3.5%, transparent),
      0 10px 34px rgba(68, 68, 68, 0.07);
    backdrop-filter: blur(var(--blur-glass)) saturate(1.08);
    -webkit-backdrop-filter: blur(var(--blur-glass)) saturate(1.08);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
      opacity var(--motion-duration-fast) var(--ease-out),
      visibility var(--motion-duration-fast) var(--ease-out),
      transform var(--motion-duration-fast) var(--ease-out);
    z-index: 50;
  }

  .site-header__nav-item--has-sub:hover .site-header__subnav,
  .site-header__nav-item--has-sub:focus-within .site-header__subnav {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate3d(-50%, 0, 0);
  }

  .site-header__subnav a {
    font-size: var(--text-sm);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-header__subnav {
    transition:
      opacity var(--motion-duration-fast) var(--ease-out),
      visibility var(--motion-duration-fast) var(--ease-out);
  }
}

/* Legacy headers (no .site-header): comfortable tap targets */
header[role="banner"]:not(.site-header) nav a {
  display: inline-block;
  padding: 0.2rem 0;
}

/* Global primary nav: activo en negrita, sin caja; hover sin fondo gris */
header[role="banner"] nav a[aria-current="page"],
.site-header__nav a[aria-current="page"] {
  font-weight: 700;
  color: color-mix(in srgb, var(--color-text) 94%, #0a0a0a);
  text-decoration: none;
  background: transparent;
  box-shadow: none;
}

header[role="banner"] nav a[aria-current="page"]:hover,
.site-header__nav a[aria-current="page"]:hover {
  color: color-mix(in srgb, var(--color-text) 96%, #000);
  background: transparent;
  box-shadow: none;
}

/* Home: logo carries “current” when there is no Inicio link */
.site-header__logo[aria-current="page"] {
  font-weight: 700;
  color: var(--color-text);
  text-decoration: none;
}

.site-header__logo[aria-current="page"]:hover {
  opacity: 1;
  color: var(--color-text);
}

@media (min-width: 64rem) {
  .site-header__nav {
    position: static;
    inset: auto;
    left: auto;
    top: auto;
    width: auto;
    max-width: none;
    max-height: none;
    overflow: visible;
    flex: 1;
    display: flex;
    justify-content: center;
    padding: 0;
    margin: 0;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: none;
  }

  .site-header__nav::before,
  .site-header__nav::after {
    content: none;
  }

  .site-header__nav > ul {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-1);
  }

  .site-header__nav a {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    font-weight: 400;
    border-radius: var(--radius-sm);
  }
}

/* Legacy plain headers: Apps + nested links */
header[role="banner"]:not(.site-header) nav > ul > li > ul {
  list-style: none;
  margin: var(--space-2) 0 0 var(--space-3);
  padding: 0 0 0 var(--space-3);
  border-left: 1px solid color-mix(in srgb, var(--color-border) 88%, transparent);
}

header[role="banner"]:not(.site-header) nav > ul > li > ul a {
  display: block;
  padding: 0.2rem 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

header[role="banner"]:not(.site-header) nav > ul > li > ul a:hover {
  color: var(--color-text);
}

.site-header__cta {
  flex-shrink: 0;
}

.site-header__cta.button {
  display: none;
}

@media (min-width: 64rem) {
  .site-header__cta.button {
    display: inline-flex;
    font-size: var(--text-sm);
    padding-inline: var(--space-3);
    text-align: center;
    line-height: 1.25;
  }

  /* Shopify / Toolkit headers — CTA compacto, separado del borde y del nav */
  .site-header--panel-nav:not(.site-header--builder-product) .site-header__cta.button {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-xs);
    line-height: 1.2;
    min-height: 2rem;
    margin-inline-start: var(--space-3);
    margin-inline-end: var(--space-2);
  }
}

.site-header__nav-cta {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  margin-top: var(--space-3);
  margin-inline: 0;
  padding: var(--space-4) 0 0;
  border-top: 1px solid color-mix(in srgb, var(--bhf-glass-border) 58%, var(--bhf-lumenedge-muted) 6%);
  border-radius: 0 0 1.5rem 1.5rem;
  text-align: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, transparent 100%),
    rgba(255, 255, 255, 0.12);
  box-shadow: none;
}

/* CTA en panel: acción primaria Bloqio (naranja + texto blanco; alinea con .button) */
.site-header__nav-cta .button {
  width: 100%;
  max-width: 100%;
  min-height: 2.75rem;
  color: #fff;
  border: 1px solid color-mix(in srgb, var(--color-cta) 42%, #1a3066);
  background:
    linear-gradient(
      165deg,
      color-mix(in srgb, #fff 12%, var(--color-cta)) 0%,
      var(--color-cta) 55%,
      color-mix(in srgb, var(--color-cta) 92%, #444) 100%
    );
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.22) inset,
    0 1px 2px rgba(68, 68, 68, 0.07);
  transition:
    background var(--holo-motion-duration-fast) var(--holo-motion-ease),
    border-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
    filter var(--holo-motion-duration-fast) var(--holo-motion-ease),
    box-shadow var(--holo-motion-duration-micro) var(--holo-motion-ease),
    transform var(--holo-motion-duration-micro) var(--holo-motion-ease);
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .site-header__nav-cta .button:hover {
    color: #fff;
    border-color: color-mix(in srgb, var(--color-cta) 55%, #152550);
    background:
      linear-gradient(
        168deg,
        color-mix(in srgb, #fff 18%, var(--color-cta-hover)) 0%,
        var(--color-cta-hover) 48%,
        color-mix(in srgb, var(--color-cta-hover) 88%, #2a2a2a) 100%
      );
    transform: translateY(-1px);
    box-shadow: var(--shadow-button-primary-hover);
  }
}

@media (hover: hover) and (prefers-reduced-motion: reduce) {
  .site-header__nav-cta .button:hover {
    color: #fff;
    border-color: color-mix(in srgb, var(--color-cta) 55%, #152550);
    background:
      linear-gradient(
        168deg,
        color-mix(in srgb, #fff 18%, var(--color-cta-hover)) 0%,
        var(--color-cta-hover) 48%,
        color-mix(in srgb, var(--color-cta-hover) 88%, #2a2a2a) 100%
      );
  }
}

.site-header__nav-cta .button:active {
  color: #fff;
  border-color: color-mix(in srgb, var(--color-cta) 48%, #1a3066);
  transition-duration: var(--holo-motion-duration-press);
  transform: translateY(1px) scale(0.985);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.1) inset,
    0 1px 6px rgba(0, 0, 0, 0.06);
}

@media (prefers-reduced-motion: reduce) {
  .site-header__nav-cta .button:hover,
  .site-header__nav-cta .button:active {
    transform: none;
  }
}

.site-header__menu {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-inline-size: 2.75rem;
  min-block-size: 2.75rem;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--bhf-glass-border) 64%, var(--bhf-lumenedge-muted) 5%);
  border-radius: 1.0625rem;
  background:
    linear-gradient(168deg, color-mix(in srgb, #fff 92%, var(--bhf-glass-fill) 8%) 0%, color-mix(in srgb, #fafaf9 98%, #fff) 100%);
  color: var(--color-identity);
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 90%, transparent) inset,
    0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 2.5%, transparent),
    0 2px 8px rgba(17, 24, 39, 0.07);
  transition:
    background var(--holo-motion-duration-fast) var(--holo-motion-ease),
    border-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
    box-shadow var(--holo-motion-duration-micro) var(--holo-motion-ease),
    transform var(--holo-motion-duration-micro) var(--holo-motion-ease);
}

@media (prefers-reduced-motion: no-preference) {
  .site-header__menu:hover {
    background: color-mix(in srgb, #fff 88%, var(--bhf-glass-fill) 12%);
    border-color: color-mix(in srgb, var(--bhf-lumenedge-muted) 6%, var(--color-border) 48%);
    box-shadow:
      0 1px 0 color-mix(in srgb, #fff 92%, transparent) inset,
      0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 3.5%, transparent),
      0 6px 16px color-mix(in srgb, #1a1a1c 0.08, transparent);
    transform: translateY(-0.5px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-header__menu:hover {
    background: color-mix(in srgb, #fff 92%, var(--bhf-glass-fill) 8%);
  }
}

.site-header__menu:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-focus) 0.7, var(--bhf-lumenedge-muted) 0.1);
  outline-offset: 2px;
}

@media (max-width: 63.99rem) {
  .site-header__menu:active {
    transform: scale(0.97);
  }
}

@media (max-width: 63.99rem) and (prefers-reduced-motion: reduce) {
  .site-header__menu:active {
    transform: none;
  }
}

/* Tres trazos finos; morph a X (Holo Motion) */
.site-header__menu-icon {
  position: relative;
  width: 1.2rem;
  height: 1px;
  background: currentColor;
  border-radius: 0.5px;
  opacity: 0.88;
  transition:
    background var(--holo-motion-duration-fast) var(--holo-motion-ease),
    opacity var(--holo-motion-duration-fast) var(--holo-motion-ease);
}

.site-header__menu-icon::before,
.site-header__menu-icon::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  border-radius: 0.5px;
  transition:
    transform var(--holo-motion-duration-fast) var(--holo-motion-ease),
    top var(--holo-motion-duration-fast) var(--holo-motion-ease);
}

.site-header__menu-icon::before {
  top: -6px;
}

.site-header__menu-icon::after {
  top: 6px;
}

.site-header__menu[aria-expanded="true"] .site-header__menu-icon {
  background: transparent;
  opacity: 0.9;
}

.site-header__menu[aria-expanded="true"] .site-header__menu-icon::before {
  top: 0;
  transform: rotate(45deg);
}

.site-header__menu[aria-expanded="true"] .site-header__menu-icon::after {
  top: 0;
  transform: rotate(-45deg);
}

@media (prefers-reduced-motion: reduce) {
  .site-header__menu-icon,
  .site-header__menu-icon::before,
  .site-header__menu-icon::after {
    transition: none;
  }
}

@media (max-width: 63.99rem) {
  .site-header__menu[aria-expanded="true"] {
    background: linear-gradient(170deg, color-mix(in srgb, #fff 90%, var(--bhf-glass-fill) 10%) 0%, var(--bloqio-glass-bg) 100%);
    border-color: color-mix(in srgb, var(--bhf-lumenedge-muted) 7%, var(--color-border) 42%);
    box-shadow:
      0 1px 0 color-mix(in srgb, #fff 88%, transparent) inset,
      0 0 0 0.5px color-mix(in srgb, var(--color-identity) 4%, rgba(255, 255, 255, 0.2)),
      0 4px 14px rgba(17, 24, 39, 0.1);
  }

  .site-header__menu[aria-expanded="true"]:active {
    transform: scale(0.97);
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-header__menu[aria-expanded="true"]:active {
    transform: none;
  }
}

@media (min-width: 64rem) {
  .site-header__menu {
    display: none;
  }
}

@media (max-width: 63.99rem) {
  .site-header__menu {
    margin-left: auto;
  }

  .site-header__inner .site-header__cta {
    display: none;
  }
}

/* —— Abstract UI blocks (sin imágenes; bloques para galería / filosofía) —— */
.ui-abstract--grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  align-items: end;
  min-height: 7.5rem;
}

.ui-abstract__bar {
  display: block;
  height: 3.25rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, var(--color-bg-soft) 0%, #e8e8e8 100%);
  border: 1px solid var(--color-border);
}

.ui-abstract__bar--accent {
  height: 4.5rem;
  border-color: color-mix(in srgb, var(--color-accent-blue) 32%, var(--color-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-accent-blue) 12%, transparent);
}

.ui-abstract__dot {
  grid-column: 1 / -1;
  width: 6px;
  height: 6px;
  margin-top: var(--space-1);
  border-radius: 50%;
  background: var(--color-accent-blue);
  opacity: 0.4;
  justify-self: center;
}

.ui-abstract--stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  justify-content: center;
  min-height: 5rem;
}

.ui-abstract__line {
  display: block;
  height: 2px;
  border-radius: 1px;
  background: linear-gradient(90deg, var(--color-border-strong), transparent);
}

.ui-abstract__line--short {
  width: min(40%, 8rem);
}

/* =============================================================================
   Goverless — atmospheric layer (CSS-first; prefers-reduced-motion)
   Hero tiers: --strong|--home (max) · --medium|--product · --soft|--contact · --minimal
   Legacy: .goverless-surface--hero (product-tier wash when no .goverless-hero)
   Surfaces: --card | --premium (alias) · --cta | --cta-premium (alias)
   Motes: color (--blue|orange|green|neutral) + depth (--near|mid|far); opacity scales by hero tier
   Rail: .goverless-rail / .goverless-text-shine
   ============================================================================= */

.goverless-surface {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.goverless-surface__content {
  position: relative;
  z-index: 1;
}

/* ── Hero holo ambience (same family, different intensity) ── */
.goverless-surface.goverless-hero.goverless-hero--home,
.goverless-surface.goverless-hero.goverless-hero--strong {
  background:
    linear-gradient(
      118deg,
      transparent 0%,
      color-mix(in srgb, #426fff 7%, transparent) 18%,
      transparent 34%
    ),
    linear-gradient(
      32deg,
      transparent 55%,
      color-mix(in srgb, #f5911e 5%, transparent) 78%,
      transparent 92%
    ),
    linear-gradient(
      180deg,
      color-mix(in srgb, #fff 14%, transparent) 0%,
      transparent 28%
    ),
    radial-gradient(
      ellipse 78% 56% at 0% 0%,
      color-mix(in srgb, #426fff 15%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 72% 50% at 100% 6%,
      color-mix(in srgb, #f5911e 12%, transparent),
      transparent 56%
    ),
    radial-gradient(
      ellipse 68% 48% at 100% 96%,
      color-mix(in srgb, #426fff 10%, transparent),
      transparent 54%
    ),
    radial-gradient(
      ellipse 64% 46% at 0% 94%,
      color-mix(in srgb, #f5911e 9%, transparent),
      transparent 52%
    ),
    radial-gradient(
      ellipse 92% 72% at 50% 118%,
      color-mix(in srgb, var(--color-bg-soft) 58%, transparent),
      transparent 60%
    ),
    radial-gradient(
      ellipse 52% 40% at 22% 18%,
      color-mix(in srgb, #14ff00 5%, transparent),
      transparent 64%
    ),
    radial-gradient(
      ellipse 88% 58% at 50% -18%,
      color-mix(in srgb, #fff 12%, transparent),
      transparent 55%
    ),
    radial-gradient(
      ellipse 70% 48% at 78% 88%,
      color-mix(in srgb, #f5911e 7%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 96% 72% at 50% 32%,
      color-mix(in srgb, #426fff 8.5%, transparent),
      transparent 68%
    ),
    radial-gradient(
      ellipse 120% 48% at 12% 42%,
      color-mix(in srgb, #426fff 4.5%, transparent),
      transparent 70%
    );
}

.goverless-surface.goverless-hero.goverless-hero--product,
.goverless-surface.goverless-hero.goverless-hero--medium {
  background:
    radial-gradient(
      ellipse 82% 62% at 8% 4%,
      color-mix(in srgb, #426fff 12%, transparent),
      transparent 56%
    ),
    radial-gradient(
      ellipse 74% 54% at 96% 10%,
      color-mix(in srgb, #f5911e 9.5%, transparent),
      transparent 54%
    ),
    radial-gradient(
      ellipse 70% 50% at 92% 94%,
      color-mix(in srgb, #426fff 8.5%, transparent),
      transparent 52%
    ),
    radial-gradient(
      ellipse 66% 48% at 6% 90%,
      color-mix(in srgb, #f5911e 8%, transparent),
      transparent 50%
    ),
    radial-gradient(
      ellipse 90% 68% at 50% 108%,
      color-mix(in srgb, var(--color-bg-soft) 52%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 88% 60% at 50% -14%,
      color-mix(in srgb, #fff 10%, transparent),
      transparent 54%
    ),
    radial-gradient(
      ellipse 92% 70% at 48% 36%,
      color-mix(in srgb, #426fff 6.5%, transparent),
      transparent 66%
    );
}

.goverless-surface.goverless-hero.goverless-hero--contact,
.goverless-surface.goverless-hero.goverless-hero--soft {
  background:
    radial-gradient(
      ellipse 78% 54% at 4% 6%,
      color-mix(in srgb, #426fff 8.5%, transparent),
      transparent 56%
    ),
    radial-gradient(
      ellipse 74% 50% at 98% 4%,
      color-mix(in srgb, #f5911e 7.5%, transparent),
      transparent 55%
    ),
    radial-gradient(
      ellipse 72% 48% at 96% 96%,
      color-mix(in srgb, #426fff 6.5%, transparent),
      transparent 54%
    ),
    radial-gradient(
      ellipse 86% 62% at 50% 112%,
      color-mix(in srgb, var(--color-bg-soft) 48%, transparent),
      transparent 60%
    ),
    radial-gradient(
      ellipse 84% 58% at 50% -16%,
      color-mix(in srgb, #fff 8.5%, transparent),
      transparent 56%
    );
}

/* Person-led / profile: same family, lowest visual weight (no motes in markup) */
.goverless-surface.goverless-hero.goverless-hero--minimal {
  background:
    radial-gradient(
      ellipse 78% 48% at 50% 0%,
      color-mix(in srgb, #426fff 4.2%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 72% 44% at 92% 88%,
      color-mix(in srgb, var(--color-bg-soft) 38%, transparent),
      transparent 56%
    ),
    radial-gradient(
      ellipse 88% 56% at 50% 100%,
      color-mix(in srgb, #f5911e 3.2%, transparent),
      transparent 62%
    );
}

/* Legacy hero without .goverless-hero: toolkit-tier product wash */
.goverless-surface--hero:not(.goverless-hero) {
  background:
    radial-gradient(
      ellipse 96% 72% at 50% 30%,
      color-mix(in srgb, var(--color-accent-blue) 12%, transparent),
      transparent 62%
    ),
    radial-gradient(
      ellipse 58% 50% at 84% 76%,
      color-mix(in srgb, #f5911e 9%, transparent),
      transparent 56%
    ),
    radial-gradient(
      ellipse 75% 55% at 14% 88%,
      color-mix(in srgb, var(--color-bg-soft) 72%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 85% 55% at 50% -15%,
      color-mix(in srgb, var(--color-accent-blue) 6%, transparent),
      transparent 52%
    );
}

.goverless-motes {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.goverless-surface.goverless-hero.goverless-hero--product .goverless-motes,
.goverless-surface.goverless-hero.goverless-hero--medium .goverless-motes {
  opacity: 0.95;
}

.goverless-surface.goverless-hero.goverless-hero--contact .goverless-motes,
.goverless-surface.goverless-hero.goverless-hero--soft .goverless-motes {
  opacity: 0.78;
}

/* Holo dust: layered radial core + bloom; float (transform+scale) + breathe (opacity) */
.goverless-mote {
  --goverless-size: 1;
  --goverless-mote-blur: 1.25px;
  --goverless-mote-core: color-mix(in srgb, #426fff 78%, #fff);
  --goverless-mote-mid: color-mix(in srgb, #426fff 42%, transparent);
  --goverless-mote-bloom: color-mix(in srgb, #426fff 24%, transparent);
  --goverless-mote-bloom-outer: color-mix(in srgb, #426fff 11%, transparent);

  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  will-change: transform, opacity, filter;
  width: calc(18px * var(--goverless-size));
  height: calc(18px * var(--goverless-size));
  opacity: 0.24;
  background:
    radial-gradient(
      circle at 34% 32%,
      color-mix(in srgb, #fff 64%, var(--goverless-mote-core)) 0%,
      color-mix(in srgb, #fff 38%, var(--goverless-mote-core)) 18%,
      var(--goverless-mote-mid) 44%,
      transparent 78%
    ),
    conic-gradient(
      from 120deg,
      color-mix(in srgb, var(--goverless-mote-core) 22%, transparent),
      transparent 32%,
      color-mix(in srgb, #fff 35%, var(--goverless-mote-mid)) 50%,
      transparent 64%,
      color-mix(in srgb, var(--goverless-mote-core) 18%, transparent) 100%
    ),
    linear-gradient(
      135deg,
      transparent 33%,
      color-mix(in srgb, #fff 52%, var(--goverless-mote-core)) 50%,
      transparent 67%
    );
  box-shadow:
    0 0 10px var(--goverless-mote-bloom),
    0 0 24px var(--goverless-mote-bloom-outer),
    0 0 40px color-mix(in srgb, var(--goverless-mote-bloom-outer) 65%, transparent);
  filter: blur(var(--goverless-mote-blur)) brightness(1);
  animation:
    goverless-mote-float-1 48s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-a 18s var(--holo-motion-ease-drift) infinite;
}

.goverless-mote--near {
  --goverless-size: 1.18;
  --goverless-mote-blur: 1.25px;
  filter: blur(var(--goverless-mote-blur)) brightness(1.04);
}

.goverless-mote--mid {
  --goverless-size: 1;
}

.goverless-mote--far {
  --goverless-size: 0.84;
  --goverless-mote-blur: 1.9px;
  filter: blur(var(--goverless-mote-blur)) brightness(0.93);
}

.goverless-mote--blue {
  --goverless-mote-core: color-mix(in srgb, #426fff 78%, #fff);
  --goverless-mote-mid: color-mix(in srgb, #426fff 38%, transparent);
  --goverless-mote-bloom: color-mix(in srgb, #426fff 28%, transparent);
  --goverless-mote-bloom-outer: color-mix(in srgb, #426fff 12%, transparent);
}

.goverless-mote--orange {
  --goverless-mote-core: color-mix(in srgb, #f5911e 72%, #fff);
  --goverless-mote-mid: color-mix(in srgb, #f5911e 36%, transparent);
  --goverless-mote-bloom: color-mix(in srgb, #f5911e 26%, transparent);
  --goverless-mote-bloom-outer: color-mix(in srgb, #f5911e 11%, transparent);
}

.goverless-mote--green {
  --goverless-mote-core: color-mix(in srgb, #14ff00 38%, #fff);
  --goverless-mote-mid: color-mix(in srgb, #14ff00 22%, transparent);
  --goverless-mote-bloom: color-mix(in srgb, #14ff00 14%, transparent);
  --goverless-mote-bloom-outer: color-mix(in srgb, #14ff00 7%, transparent);
}

.goverless-mote--neutral {
  --goverless-mote-core: color-mix(in srgb, #444 18%, #fff);
  --goverless-mote-mid: color-mix(in srgb, #e8e8e8 28%, transparent);
  --goverless-mote-bloom: color-mix(in srgb, #fff 16%, transparent);
  --goverless-mote-bloom-outer: color-mix(in srgb, var(--color-accent-blue) 7%, transparent);
}

/* Placement + unique float/breathe timing (depth from --near|mid|far on each mote) */
.goverless-surface.goverless-hero .goverless-mote:nth-child(1) {
  left: 9%;
  top: 20%;
  animation:
    goverless-mote-float-1 43s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-a 17s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -4.2s, -1.2s;
}

.goverless-surface.goverless-hero .goverless-motes::before,
.goverless-surface.goverless-hero .goverless-motes::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.goverless-surface.goverless-hero .goverless-motes::before {
  background:
    radial-gradient(90% 68% at 12% 12%, color-mix(in srgb, #fff 30%, transparent), transparent 66%),
    radial-gradient(88% 66% at 86% 84%, color-mix(in srgb, var(--bhf-lumenedge-soft) 30%, transparent), transparent 68%),
    conic-gradient(
      from 200deg,
      color-mix(in srgb, var(--bhf-lumenedge) 4%, transparent),
      transparent 28%,
      color-mix(in srgb, var(--bhf-lumenedge-orange-soft) 4%, transparent) 52%,
      transparent 78%,
      color-mix(in srgb, var(--bhf-lumenedge-blue-mid) 3.5%, transparent) 100%
    );
  opacity: 0.5;
}

.goverless-surface.goverless-hero .goverless-motes::after {
  background:
    radial-gradient(circle at 15% 18%, color-mix(in srgb, #fff 60%, transparent) 0 1px, transparent 1.5px),
    radial-gradient(circle at 78% 26%, color-mix(in srgb, #fff 52%, transparent) 0 1px, transparent 1.5px),
    radial-gradient(circle at 62% 72%, color-mix(in srgb, #fff 50%, transparent) 0 1px, transparent 1.5px),
    radial-gradient(ellipse 120% 40% at 50% 20%, color-mix(in srgb, var(--bhf-lumenedge-primary) 5%, transparent), transparent 62%),
    linear-gradient(110deg, transparent 0 20%, color-mix(in srgb, var(--bhf-lumenedge-primary) 32%, transparent) 30%, transparent 40%),
    linear-gradient(88deg, transparent 0 64%, color-mix(in srgb, var(--bhf-lumenedge-soft) 35%, transparent) 74%, transparent 85%);
  background-size: auto, auto, auto, auto, 220% 100%, 200% 100%;
  background-repeat: no-repeat;
  opacity: 0.32;
}

@media (prefers-reduced-motion: no-preference) {
  .goverless-surface.goverless-hero .goverless-motes::after {
    animation: goverless-orbital-lines 30s linear infinite;
  }
}

@keyframes goverless-orbital-lines {
  from {
    background-position:
      0 0,
      0 0,
      0 0,
      0% 50%,
      0% 50%;
  }

  to {
    background-position:
      0 0,
      0 0,
      0 0,
      100% 50%,
      100% 50%;
  }
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(2) {
  left: 78%;
  top: 28%;
  animation:
    goverless-mote-float-2 36s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-f 12s cubic-bezier(0.45, 0.02, 0.55, 0.98) infinite;
  animation-delay: -11.5s, -8.4s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(3) {
  left: 22%;
  top: 62%;
  animation:
    goverless-mote-float-3 49s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-c 14s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -1.6s, -13.8s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(4) {
  right: 18%;
  top: 14%;
  left: auto;
  animation:
    goverless-mote-float-4 34s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-d 18s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -7.8s, -2.9s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(5) {
  left: 52%;
  top: 78%;
  animation:
    goverless-mote-float-5 39s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-g 11s cubic-bezier(0.45, 0.02, 0.55, 0.98) infinite;
  animation-delay: -17.2s, -21s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(6) {
  right: 42%;
  top: 52%;
  left: auto;
  animation:
    goverless-mote-float-6 51s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-b 15s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -21.4s, -5.8s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(7) {
  left: 4%;
  top: 48%;
  animation:
    goverless-mote-float-2 46s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-e 13s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -5.5s, -10.2s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(8) {
  right: 8%;
  top: 58%;
  left: auto;
  animation:
    goverless-mote-float-4 41s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-h 16s cubic-bezier(0.45, 0.02, 0.55, 0.98) infinite;
  animation-delay: -13.6s, -3.7s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(9) {
  left: 38%;
  top: 12%;
  animation:
    goverless-mote-float-1 38s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-f 14s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -24.8s, -16.5s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(10) {
  left: 66%;
  top: 38%;
  animation:
    goverless-mote-float-3 45s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-a 10s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -8.9s, -6.4s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(11) {
  right: 28%;
  top: 72%;
  left: auto;
  animation:
    goverless-mote-float-5 47s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-c 18s cubic-bezier(0.45, 0.02, 0.55, 0.98) infinite;
  animation-delay: -29.2s, -11.8s;
}

.goverless-surface.goverless-hero .goverless-mote:nth-child(12) {
  left: 58%;
  top: 88%;
  animation:
    goverless-mote-float-6 53s var(--holo-motion-ease-drift) infinite,
    goverless-mote-breathe-d 13s cubic-bezier(0.42, 0, 0.58, 1) infinite;
  animation-delay: -10.5s, -24.6s;
}

/* Float paths: translate + gentle scale (single transform stack) */
@keyframes goverless-mote-float-1 {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  22% {
    transform: translate3d(10px, -14px, 0) scale(1.045);
  }

  48% {
    transform: translate3d(-8px, 8px, 0) scale(0.96);
  }

  72% {
    transform: translate3d(6px, 12px, 0) scale(1.03);
  }
}

@keyframes goverless-mote-float-2 {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  30% {
    transform: translate3d(-12px, 6px, 0) scale(1.06);
  }

  55% {
    transform: translate3d(9px, -11px, 0) scale(0.94);
  }

  78% {
    transform: translate3d(5px, 14px, 0) scale(1.02);
  }
}

@keyframes goverless-mote-float-3 {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  25% {
    transform: translate3d(4px, 16px, 0) scale(1.04);
  }

  50% {
    transform: translate3d(-14px, -4px, 0) scale(0.95);
  }

  75% {
    transform: translate3d(11px, -10px, 0) scale(1.05);
  }
}

@keyframes goverless-mote-float-4 {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  33% {
    transform: translate3d(14px, 4px, 0) scale(0.97);
  }

  66% {
    transform: translate3d(-10px, -14px, 0) scale(1.06);
  }
}

@keyframes goverless-mote-float-5 {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  28% {
    transform: translate3d(-6px, -16px, 0) scale(1.05);
  }

  52% {
    transform: translate3d(13px, 7px, 0) scale(0.93);
  }

  80% {
    transform: translate3d(-9px, 10px, 0) scale(1.04);
  }
}

@keyframes goverless-mote-float-6 {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  20% {
    transform: translate3d(7px, 10px, 0) scale(0.96);
  }

  45% {
    transform: translate3d(-11px, -8px, 0) scale(1.07);
  }

  70% {
    transform: translate3d(12px, -6px, 0) scale(0.98);
  }
}

/* Opacity-only breathe — drift handles transform; ranges stay in ambient dust territory */
@keyframes goverless-mote-breathe-a {
  0%,
  100% {
    opacity: 0.12;
  }

  50% {
    opacity: 0.38;
  }
}

@keyframes goverless-mote-breathe-b {
  0%,
  100% {
    opacity: 0.14;
  }

  50% {
    opacity: 0.42;
  }
}

@keyframes goverless-mote-breathe-c {
  0%,
  100% {
    opacity: 0.1;
  }

  50% {
    opacity: 0.33;
  }
}

@keyframes goverless-mote-breathe-d {
  0%,
  100% {
    opacity: 0.15;
  }

  50% {
    opacity: 0.44;
  }
}

@keyframes goverless-mote-breathe-e {
  0%,
  100% {
    opacity: 0.12;
  }

  50% {
    opacity: 0.3;
  }
}

@keyframes goverless-mote-breathe-f {
  0%,
  100% {
    opacity: 0.12;
  }

  50% {
    opacity: 0.38;
  }
}

@keyframes goverless-mote-breathe-g {
  0%,
  100% {
    opacity: 0.1;
  }

  50% {
    opacity: 0.35;
  }
}

@keyframes goverless-mote-breathe-h {
  0%,
  100% {
    opacity: 0.14;
  }

  50% {
    opacity: 0.4;
  }
}

@media (max-width: 47.99rem) {
  .goverless-surface.goverless-hero .goverless-mote:nth-child(n + 6) {
    display: none;
  }

  @keyframes goverless-mote-float-1 {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }

    50% {
      transform: translate3d(5px, -7px, 0) scale(1.02);
    }
  }

  @keyframes goverless-mote-float-2 {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }

    50% {
      transform: translate3d(-6px, 5px, 0) scale(0.99);
    }
  }

  @keyframes goverless-mote-float-3 {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }

    50% {
      transform: translate3d(4px, 8px, 0) scale(1.02);
    }
  }

  @keyframes goverless-mote-float-4 {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }

    50% {
      transform: translate3d(-5px, -6px, 0) scale(1.02);
    }
  }

  @keyframes goverless-mote-float-5 {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }

    50% {
      transform: translate3d(6px, 5px, 0) scale(0.99);
    }
  }

  @keyframes goverless-mote-float-6 {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }

    50% {
      transform: translate3d(-4px, 6px, 0) scale(1.02);
    }
  }
}

@media (prefers-reduced-motion: reduce) {
  .goverless-mote {
    animation: none !important;
    opacity: 0.14;
    filter: blur(var(--goverless-mote-blur, 1.55px)) brightness(1);
    transform: none;
  }

  .goverless-surface.goverless-hero .goverless-motes::after {
    animation: none;
  }
}

/* Premium card: soft iridescent wash (pairs with .shine-card) */
.goverless-surface--card.shine-card::before,
.goverless-surface--premium.shine-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 90% 55% at 12% -10%,
      color-mix(in srgb, var(--color-accent-blue) 10.5%, transparent),
      transparent 52%
    ),
    radial-gradient(
      ellipse 70% 45% at 92% 102%,
      color-mix(in srgb, #f5911e 8%, transparent),
      transparent 48%
    );
  opacity: 0.52;
}

@media (prefers-reduced-motion: no-preference) {
  .goverless-surface--card.shine-card::before,
  .goverless-surface--premium.shine-card::before {
    animation: goverless-card-ambient 22s var(--holo-motion-ease-drift) infinite alternate;
  }
}

@keyframes goverless-card-ambient {
  0% {
    opacity: 0.48;
  }

  100% {
    opacity: 0.66;
  }
}

@media (prefers-reduced-motion: reduce) {
  .goverless-surface--card.shine-card::before,
  .goverless-surface--premium.shine-card::before {
    animation: none;
    opacity: 0.4;
  }
}

/* Final CTA shell: inner holo only (radial wash — same family as premium cards; no diagonal sheen). */
.goverless-surface--cta.shine-card::before,
.goverless-surface--cta-premium.shine-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 100% 72% at 14% 8%,
      color-mix(in srgb, var(--color-accent-blue) 8.5%, transparent),
      transparent 58%
    ),
    radial-gradient(
      ellipse 95% 68% at 88% 92%,
      color-mix(in srgb, var(--color-accent-orange) 6.5%, transparent),
      transparent 54%
    );
  opacity: 0.48;
}

@media (prefers-reduced-motion: no-preference) {
  .goverless-surface--cta.shine-card::before,
  .goverless-surface--cta-premium.shine-card::before {
    animation: goverless-card-ambient 22s var(--holo-motion-ease-drift) infinite alternate;
  }
}

@media (prefers-reduced-motion: reduce) {
  .goverless-surface--cta.shine-card::before,
  .goverless-surface--cta-premium.shine-card::before {
    animation: none;
    opacity: 0.4;
  }
}

/* Final CTA shine-card: same stack as /sobre-bloqio — goverless wash + .shine-card__ring + frost surface (no extra border pseudo). */
.cta-final .shine-card--cta {
  position: relative;
  isolation: isolate;
}

/* Stack: Goverless wash + ring; frost surface stays on top */
.goverless-surface--card .shine-card__ring,
.goverless-surface--premium .shine-card__ring,
.goverless-surface--cta .shine-card__ring,
.goverless-surface--cta-premium .shine-card__ring {
  z-index: 0;
}

.goverless-surface--card .shine-card__surface,
.goverless-surface--premium .shine-card__surface,
.goverless-surface--cta .shine-card__surface,
.goverless-surface--cta-premium .shine-card__surface {
  z-index: 1;
}

/* Marquee keyword shine — .goverless-text-shine or .goverless-rail items */
@keyframes goverless-shine-text {
  0% {
    background-position: 0% 50%;
  }

  100% {
    background-position: 100% 50%;
  }
}

/* Fallback when chromatic text shine isn’t available */
@supports (-webkit-background-clip: text) or (background-clip: text) {
  .goverless-text-shine,
  .goverless-rail .capability-rail__item {
    color: transparent;
    -webkit-text-fill-color: transparent;
    background-image: linear-gradient(
      102deg,
      color-mix(in srgb, #444444 74%, #fff) 0%,
      color-mix(in srgb, #426fff 48%, #444444) 12%,
      color-mix(in srgb, #444444 80%, #e8e8e8) 28%,
      color-mix(in srgb, #f5911e 46%, #444444) 44%,
      color-mix(in srgb, #444444 78%, #fff) 56%,
      color-mix(in srgb, #426fff 42%, #444444) 70%,
      color-mix(in srgb, #f5911e 40%, #444444) 82%,
      color-mix(in srgb, #14ff00 9%, #444444) 90%,
      color-mix(in srgb, #444444 82%, #f5f5f5) 100%
    );
    background-size: 260% 100%;
    background-clip: text;
    -webkit-background-clip: text;
    animation: goverless-shine-text var(--holo-motion-shine-text) linear infinite;
  }

  .goverless-rail .capability-rail__item:hover {
    color: transparent;
    -webkit-text-fill-color: transparent;
    filter: brightness(1.04);
  }
}

@media (max-width: 47.99rem) {
  @supports (-webkit-background-clip: text) or (background-clip: text) {
    .goverless-text-shine,
    .goverless-rail .capability-rail__item {
      animation-duration: calc(var(--holo-motion-shine-text) * 1.08);
      filter: saturate(0.94);
    }
  }
}

@media (prefers-reduced-motion: reduce) {
  @supports (-webkit-background-clip: text) or (background-clip: text) {
    .goverless-text-shine,
    .goverless-rail .capability-rail__item {
      animation: none;
      background-position: 38% 50%;
    }

    .goverless-rail .capability-rail__item:hover {
      filter: brightness(1.04);
    }
  }
}

/* =============================================================================
   Holo Motion — page enter + section reveal (tokens.css; IO in main.js)
   .holo-motion-enter / .holo-motion-page on <main>; .holo-motion-section / .holo-motion-visible on sections
   .holo-cta-surface on .cta-final .shine-card--cta; .goverless-card-hover on premium cards
   Uses --holo-motion-* tokens only (no ad-hoc eases). Profile page uses the same section reveal with restrained motion.
   ============================================================================= */

@keyframes holo-motion-page-in {
  from {
    opacity: 0.92;
    transform: translate3d(0, var(--holo-motion-page-y), 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  html.js .holo-motion-enter,
  html.js .holo-motion-page {
    animation: holo-motion-page-in var(--holo-motion-page-duration) var(--holo-motion-ease-enter) both;
  }

  html.js .holo-motion-section:not(.holo-motion-visible) {
    opacity: 0;
    transform: translate3d(0, var(--holo-motion-reveal-y), 0) scale(0.992);
    filter: blur(2px);
  }

  html.js .holo-motion-section.holo-motion-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
    transition:
      opacity var(--holo-motion-duration) var(--holo-motion-ease-enter),
      transform var(--holo-motion-duration) var(--holo-motion-ease-enter),
      filter var(--holo-motion-duration) var(--holo-motion-ease-enter);
    transition-delay: var(--holo-motion-stagger, 0s);
  }
}

@media (prefers-reduced-motion: reduce) {
  html.js .holo-motion-enter,
  html.js .holo-motion-page {
    animation: none;
  }

  html.js .holo-motion-section {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
}

/* Holo Motion 2.0 — optional hooks (pair with page-specific rules in pages.css) */
@media (prefers-reduced-motion: no-preference) {
  .goverless-card-hover {
    transition:
      transform var(--holo-motion-duration-micro) var(--holo-motion-ease),
      box-shadow var(--holo-motion-duration-micro) var(--holo-motion-ease),
      border-color var(--holo-motion-duration-fast) var(--holo-motion-ease),
      filter var(--holo-motion-duration-fast) var(--holo-motion-ease);
  }

  .cta-final .shine-card--cta.holo-cta-surface {
    transition: transform var(--holo-motion-duration-micro) var(--holo-motion-ease);
  }

  .cta-final .shine-card--cta.holo-cta-surface:hover {
    transform: translateY(-1.5px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .goverless-card-hover,
  .cta-final .shine-card--cta.holo-cta-surface {
    transition: none;
  }

  .cta-final .shine-card--cta.holo-cta-surface:hover {
    transform: none;
  }
}

/* CTA final — móvil: stack táctil sin romper filas en desktop */
@media (max-width: 40rem) {
  .cta-final__actions,
  .cta-final .hero__actions {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .cta-final__actions .button,
  .cta-final .hero__actions .button {
    width: 100%;
    max-width: 100%;
    justify-content: center;
  }
}

/* --------------------------------------------------------------------------
   Bloqio Holoform — abstract visuals (Glassware, LumenEdge, orbits, modules)
   Reusable: home, sobre, apps, galería, cómo-funciona. No 100vw. prefers-reduced-motion.
   -------------------------------------------------------------------------- */

.holoform-visual {
  position: relative;
  width: 100%;
  max-inline-size: 100%;
  min-height: 12rem;
  border-radius: clamp(1.25rem, 4vw, 2.25rem);
  isolation: isolate;
  overflow: clip;
  background:
    radial-gradient(ellipse 100% 80% at 12% 0%, color-mix(in srgb, var(--color-accent-blue) 5%, transparent), transparent 55%),
    radial-gradient(ellipse 90% 70% at 88% 100%, color-mix(in srgb, var(--color-accent-orange) 4.5%, transparent), transparent 52%),
    linear-gradient(180deg, #ffffff 0%, color-mix(in srgb, #fff 96%, var(--bloqio-glass-bg) 4%) 100%);
  border: 1px solid color-mix(in srgb, var(--bloqio-glass-border) 55%, #fff 25%);
  box-shadow: var(--bloqio-glass-shadow), inset 0 1px 0 color-mix(in srgb, #fff 88%, transparent);
}

.holoform-visual--compact {
  min-height: 8.5rem;
  max-width: 14rem;
  margin-left: auto;
}

.holoform-visual__plate {
  position: absolute;
  left: 50%;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, #fff 82%, var(--bloqio-glass-bg) 18%);
  border: 1px solid color-mix(in srgb, var(--bloqio-glass-border) 50%, #fff 30%);
  box-shadow: 0 4px 20px color-mix(in srgb, #444 5%, transparent), inset 0 1px 0 color-mix(in srgb, #fff 80%, transparent);
  pointer-events: none;
  transform: translateX(-50%);
  backdrop-filter: blur(6px) saturate(1.04);
  -webkit-backdrop-filter: blur(6px) saturate(1.04);
}

.holoform-visual--stack .holoform-visual__plate--a {
  bottom: 18%;
  width: 78%;
  height: 3.1rem;
  z-index: 4;
  background:
    linear-gradient(145deg, color-mix(in srgb, #fff 90%, var(--bhf-glass-fill) 10%), #fff);
  box-shadow:
    0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-primary) 18%, var(--bhf-lumenedge-muted) 8%),
    0 8px 28px color-mix(in srgb, #444 6%, transparent),
    inset 0 1px 0 #fff;
}

.holoform-visual--stack .holoform-visual__plate--a::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: conic-gradient(
    from 200deg,
    color-mix(in srgb, var(--color-accent-blue) 6%, transparent),
    transparent 40%,
    color-mix(in srgb, var(--color-accent-orange) 5%, transparent) 75%,
    transparent 100%
  );
  opacity: 0.4;
  mix-blend-mode: soft-light;
  pointer-events: none;
}

.holoform-visual--stack .holoform-visual__plate--b {
  bottom: 30%;
  width: 86%;
  height: 2.7rem;
  z-index: 3;
  opacity: 0.88;
}

.holoform-visual--stack .holoform-visual__plate--c {
  bottom: 42%;
  width: 92%;
  height: 2.3rem;
  z-index: 2;
  opacity: 0.75;
}

.holoform-visual--stack .holoform-visual__plate--d {
  bottom: 52%;
  width: 96%;
  height: 1.9rem;
  z-index: 1;
  opacity: 0.62;
}

.holoform-visual--stack .holoform-visual__ring {
  position: absolute;
  left: 8%;
  right: 8%;
  top: 8%;
  bottom: 22%;
  border: 1px solid color-mix(in srgb, var(--bhf-lumenedge-muted) 20%, var(--color-border) 40%);
  border-radius: 50%;
  opacity: 0.45;
  pointer-events: none;
  z-index: 0;
}

.holoform-visual--stack .holoform-visual__ring::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: conic-gradient(
    from 100deg,
    color-mix(in srgb, var(--color-accent-blue) 5%, transparent),
    transparent 50%,
    color-mix(in srgb, var(--color-accent-orange) 4%, transparent)
  );
  opacity: 0.35;
  mix-blend-mode: soft-light;
}

.holoform-visual--stack .holoform-visual__commerce {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 8%;
  display: flex;
  justify-content: center;
  gap: var(--space-3);
  z-index: 5;
  pointer-events: none;
}

.holoform-visual__module--topbar {
  display: block;
  width: min(45%, 5.5rem);
  height: 0.5rem;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--color-identity) 10%, #fff 90%);
  border: 1px solid color-mix(in srgb, var(--color-border) 45%, transparent);
}

.holoform-visual__module--sticky {
  display: block;
  width: min(24%, 3rem);
  height: 0.6rem;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--color-accent-blue) 20%, #fff 80%);
  border: 1px solid color-mix(in srgb, var(--color-accent-blue) 12%, var(--color-border) 50%);
}

.holoform-visual--orbit .holoform-visual__ring {
  position: absolute;
  inset: 8% 6%;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--bhf-lumenedge-muted) 18%, var(--color-border) 50%);
  opacity: 0.6;
  pointer-events: none;
}

.holoform-visual--orbit .holoform-visual__ring::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: conic-gradient(
    from 120deg,
    color-mix(in srgb, var(--color-accent-blue) 8%, transparent),
    transparent 40%,
    color-mix(in srgb, var(--color-accent-orange) 5%, transparent) 70%,
    transparent 100%
  );
  opacity: 0.45;
  mix-blend-mode: soft-light;
}

.holoform-visual--orbit .holoform-visual__glass {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(70%, 10rem);
  height: 4rem;
  transform: translate(-50%, -50%);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, #fff 80%, var(--bloqio-glass-bg) 20%);
  border: 1px solid color-mix(in srgb, var(--bloqio-glass-border) 55%, #fff 20%);
  box-shadow: var(--bloqio-glass-shadow), inset 0 1px 0 color-mix(in srgb, #fff 78%, transparent);
  backdrop-filter: blur(8px) saturate(1.05);
  -webkit-backdrop-filter: blur(8px) saturate(1.05);
  pointer-events: none;
}

.holoform-visual--orbit .holoform-visual__edge {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(75%, 10.5rem);
  height: 4.35rem;
  transform: translate(-50%, -50%);
  border-radius: calc(var(--radius-md) + 2px);
  box-shadow: 0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 14%, var(--color-border) 45%);
  pointer-events: none;
}

.holoform-visual--orbit .holoform-visual__node {
  position: absolute;
  width: 0.38rem;
  height: 0.38rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-accent-blue) 32%, #fff 68%);
  box-shadow: 0 0 0 1.5px color-mix(in srgb, #fff 80%, var(--bhf-lumenedge-muted) 6%);
  pointer-events: none;
}

.holoform-visual--orbit .holoform-visual__node--a {
  top: 24%;
  left: 20%;
}

.holoform-visual--orbit .holoform-visual__node--b {
  bottom: 24%;
  right: 18%;
  background: color-mix(in srgb, var(--color-accent-orange) 28%, #fff 72%);
}

.holoform-visual--orbit .holoform-visual__commerce {
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 10%;
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  align-items: flex-end;
  pointer-events: none;
}

.holoform-visual--commerce {
  min-height: 11rem;
}

.holoform-visual--commerce .holoform-visual__wire {
  position: absolute;
  left: 50%;
  top: 18%;
  width: 1px;
  height: 42%;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bhf-lumenedge-muted) 20%, transparent),
    color-mix(in srgb, var(--color-accent-blue) 25%, transparent) 50%,
    color-mix(in srgb, var(--bhf-lumenedge-muted) 20%, transparent)
  );
  opacity: 0.7;
  pointer-events: none;
}

.holoform-visual--commerce .holoform-visual__module--topbar {
  position: absolute;
  top: 10%;
  left: 50%;
  transform: translateX(-50%);
  width: min(72%, 9rem);
  height: 0.75rem;
  z-index: 2;
  box-shadow: 0 2px 10px color-mix(in srgb, #444 4%, transparent);
}

.holoform-visual--commerce .holoform-visual__module--sticky {
  position: absolute;
  bottom: 12%;
  left: 50%;
  transform: translateX(-50%);
  width: min(56%, 7rem);
  height: 1.1rem;
  z-index: 2;
  box-shadow: 0 3px 14px color-mix(in srgb, var(--color-accent-blue) 12%, transparent);
}

.holoform-visual--commerce .holoform-visual__card {
  position: absolute;
  left: 8%;
  bottom: 32%;
  width: 2.1rem;
  height: 2.6rem;
  border-radius: 0.35rem;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--color-border) 40%, transparent);
  box-shadow: 0 2px 8px color-mix(in srgb, #444 4%, transparent);
  pointer-events: none;
  opacity: 0.9;
}

.holoform-visual--commerce .holoform-visual__cart {
  position: absolute;
  right: 8%;
  bottom: 32%;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 0.3rem;
  background: color-mix(in srgb, var(--color-identity) 8%, #fff 92%);
  border: 1px solid var(--color-border);
  box-shadow: inset 0 1px 0 #fff;
  pointer-events: none;
}

.holoform-visual--commerce .holoform-visual__cart::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0.4rem;
  height: 0.4rem;
  margin: -0.2rem 0 0 -0.2rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-accent-blue) 20%, #fff 80%);
}

.holoform-visual--commerce .holoform-visual__node {
  position: absolute;
  width: 0.32rem;
  height: 0.32rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-accent-blue) 30%, #fff 70%);
  box-shadow: 0 0 0 1px color-mix(in srgb, #fff 75%, var(--bhf-lumenedge-muted) 8%);
  pointer-events: none;
  z-index: 3;
}

.holoform-visual--commerce .holoform-visual__node--a {
  top: 34%;
  left: 10%;
}

.holoform-visual--commerce .holoform-visual__node--b {
  top: 48%;
  right: 12%;
  background: color-mix(in srgb, var(--color-accent-orange) 26%, #fff 74%);
}

/* Alias: legacy class names used in some routes */
.holoform-orbit,
.holoform-visual.holoform-visual--orbit:not(.holoform-visual--compact) {
  min-height: 14rem;
}

.holoform-orbit,
.holoform-visual--orbit {
  border-radius: inherit;
  background: transparent;
  border: none;
  box-shadow: none;
}

body[data-page="home"] .philosophy__visual .holoform-visual--orbit,
body[data-page="home"] .philosophy__visual .holoform-orbit,
body[data-page="home"] .philosophy__visual .holoform-visual--stack {
  flex: 1;
  min-height: 15rem;
}

@media (prefers-reduced-motion: no-preference) {
  .holoform-visual--orbit .holoform-visual__ring,
  .holoform-orbit .holoform-orbit__ring,
  .holoform-visual--stack .holoform-visual__ring {
    animation: holoform-visual-breathe 22s var(--holo-motion-ease-drift) infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .holoform-visual--orbit .holoform-visual__ring,
  .holoform-orbit .holoform-orbit__ring,
  .holoform-visual--stack .holoform-visual__ring {
    animation: none;
  }
}

@keyframes holoform-visual-breathe {
  0%,
  100% {
    transform: none;
    opacity: 0.55;
  }

  50% {
    transform: scale(1.01);
    opacity: 0.7;
  }
}

/* --------------------------------------------------------------------------
   Holoform art — reutilizable (glass, LumenEdge, módulos, órbita, movimiento)
   -------------------------------------------------------------------------- */

.section-heading--center {
  text-align: center;
  max-width: 40rem;
  margin-inline: auto;
  margin-bottom: var(--space-6);
}

.section-heading--center .eyebrow {
  margin-bottom: var(--space-2);
}

.section-heading--center h2,
.section-heading--center .section-heading__title {
  margin: 0 0 var(--space-3);
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: var(--leading-snug);
  color: var(--color-text);
}

@media (min-width: 48rem) {
  .section-heading--center h2,
  .section-heading--center .section-heading__title {
    font-size: var(--text-xl);
  }
}

.section-heading--center p,
.section-heading--center .section-heading__lede {
  margin: 0;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
}

.section-heading__sub {
  margin: var(--space-3) 0 0;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}

.holoform-art {
  --holoform-art-lumen: color-mix(in srgb, var(--bhf-lumenedge-primary) 48%, #fff 52%);
  --holoform-art-surface: color-mix(in srgb, #fff 80%, var(--bhf-glass-fill) 20%);
  position: relative;
  isolation: isolate;
  overflow: clip;
  border-radius: clamp(1.25rem, 4vw, 2.25rem);
  background:
    radial-gradient(120% 90% at 12% 0%, color-mix(in srgb, var(--color-accent-blue) 10%, #fff 90%) 0%, transparent 55%),
    radial-gradient(90% 70% at 100% 100%, color-mix(in srgb, var(--color-accent-orange) 8%, #fff 92%) 0%, transparent 50%),
    linear-gradient(165deg, var(--holoform-art-surface) 0%, #fff 100%);
  border: 1px solid var(--holoform-art-lumen);
  box-shadow:
    0 1px 0 #fffc inset,
    0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 0.1%, #fff 99.9%),
    0 16px 48px color-mix(in srgb, #1a1a1a 5%, transparent);
  backdrop-filter: blur(14px) saturate(1.05);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
}

.holoform-art__edge {
  position: absolute;
  pointer-events: none;
  z-index: 2;
  inset: 0.12rem;
  border-radius: calc(clamp(1.25rem, 4vw, 2.25rem) - 0.1rem);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--bhf-lumenedge-primary) 16%, #fff 84%);
  mix-blend-mode: multiply;
  opacity: 0.7;
}

.holoform-art__plate {
  position: absolute;
  border-radius: 0.4rem;
  background: #fff;
  border: 0.2px solid color-mix(in srgb, var(--bhf-lumenedge-muted) 0.1%, #fff 99.9%);
  box-shadow: 0 3px 14px color-mix(in srgb, #2a2a2a 0.1%, #fff 99.9%),
    0 1px 0 #fff2 inset;
  pointer-events: none;
}

.holoform-art--prometeo,
.holoform-art--hermes {
  width: 100%;
  max-width: 18.5rem;
  min-height: 11.25rem;
  margin-inline: auto;
  padding: 0.55rem 0.5rem 0.6rem;
}

.holoform-art__orbit {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  left: 4%;
  right: 4%;
  top: 0.2rem;
  height: 1.35rem;
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 18%, #fff 82%);
  border-radius: 50%;
  opacity: 0.52;
  background: linear-gradient(
    100deg,
    transparent 0%,
    color-mix(in srgb, var(--bhf-lumenedge-muted) 0.1%, #fff 99.9%),
    transparent 60%
  );
}

.holoform-art--hermes .holoform-art__orbit {
  top: 0.3rem;
  height: 1.1rem;
  opacity: 0.32;
}

.holoform-art--prometeo .holoform-art__node--one {
  top: 6%;
  left: 3%;
  bottom: auto;
}

.holoform-art--prometeo .holoform-art__node--two {
  top: 32%;
  right: 4%;
  bottom: auto;
}

.holoform-art--hermes .holoform-art__node--one {
  top: 6%;
  left: 3%;
  bottom: auto;
}

.holoform-art--hermes .holoform-art__node--two {
  top: 44%;
  right: 4%;
  bottom: auto;
}

.holoform-art__node {
  position: absolute;
  z-index: 2;
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background: #fff;
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 20%, #fff 80%);
  box-shadow: 0 0 0 0.1rem color-mix(in srgb, var(--color-accent-blue) 8%, #fff0),
    0 0 9px color-mix(in srgb, var(--color-accent-blue) 6%, #fff0);
}

.holoform-art__node--one {
  top: 12%;
  left: 6%;
}

.holoform-art__node--two {
  bottom: 18%;
  right: 7%;
  box-shadow: 0 0 0 0.1rem color-mix(in srgb, var(--color-accent-orange) 8%, #fff0),
    0 0 9px color-mix(in srgb, var(--color-accent-orange) 5%, #fff0);
}

.holoform-art__cart {
  display: block;
  width: 0.3rem;
  height: 0.3rem;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 0.1px var(--holoform-art-lumen);
}

@media (prefers-reduced-motion: no-preference) {
  .holoform-art__orbit {
    animation: holoform-art-orbit 22s var(--bhf-motion-ease, ease-in-out) infinite;
  }

  .holoform-art__node {
    animation: holoform-art-node 6s var(--bhf-motion-ease, ease-in-out) infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .holoform-art__orbit,
  .holoform-art__node {
    animation: none;
  }
}

@keyframes holoform-art-orbit {
  0%,
  100% {
    transform: scale(1) translateY(0);
    opacity: 0.32;
  }

  50% {
    transform: scale(1.02) translateY(1px);
    opacity: 0.5;
  }
}

@keyframes holoform-art-node {
  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.1);
  }
}

/* App pages — mock browser / PDP (con holoform-art) */
.app-holoform-mock__browser {
  position: relative;
  z-index: 1;
  margin: 0.2rem 0.35rem 0.4rem;
  padding: 0.45rem 0.4rem 0.5rem;
  border-radius: 0.32rem;
  min-height: 7.2rem;
  background: #fff;
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 10%, #fff 90%);
  box-shadow: 0 1px 0 #fff0 inset, 0 4px 22px color-mix(in srgb, #1a1a1a 4%, #fff0),
    0 0 0 0.1px color-mix(in srgb, var(--color-accent-blue) 3%, #fff0);
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.app-holoform-mock--prometeo .app-holoform-mock__topbar {
  display: block;
  height: 0.7rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(180deg, #2e2e2e 0%, #1a1a1a 100%);
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 16%, #fff0);
  box-shadow: 0 0 0 0.1px color-mix(in srgb, var(--color-accent-blue) 5%, #fff0),
    0 2px 18px color-mix(in srgb, #000 16%, #fff0),
    inset 0 1px 0 color-mix(in srgb, #fff 8%, #0000 92%);
}

.app-holoform-mock--prometeo .app-holoform-mock__nav {
  height: 0.22rem;
  width: 55%;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--bhf-lumenedge-muted) 4%, #fff 96%);
}

.app-holoform-mock--prometeo .app-holoform-mock__hero {
  flex: 1;
  min-height: 2.5rem;
  border-radius: 0.2rem;
  background: linear-gradient(180deg, color-mix(in srgb, var(--bhf-holo-wash) 14%, #fff 86%), #fff 90%);
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 8%, #fff 92%);
  box-shadow: 0 1px 0 #fffc inset, 0 2px 10px color-mix(in srgb, #1a1a1a 3%, #fff0);
}

.app-holoform-mock--prometeo .app-holoform-mock__cta {
  align-self: flex-end;
  width: 1.5rem;
  height: 0.42rem;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--color-accent-blue) 7%, #fff 93%);
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 12%, #fff 88%);
  box-shadow: 0 0 0 0.1px color-mix(in srgb, var(--color-accent-blue) 4%, #fff0);
}

.app-holoform-mock--hermes .app-holoform-mock__pdp {
  position: relative;
  margin: 0.2rem 0.35rem 0.4rem;
  min-height: 7.1rem;
  padding: 0.4rem 0.4rem 0.5rem;
  border-radius: 0.32rem;
  background: #fff;
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 9%, #fff 91%);
  box-shadow: 0 1px 0 #fff0 inset, 0 4px 22px color-mix(in srgb, #1a1a1a 4%, #fff0);
}

.app-holoform-mock--hermes .app-holoform-mock__product {
  display: block;
  width: 42%;
  aspect-ratio: 1;
  max-width: 2.1rem;
  border-radius: 0.16rem;
  background: linear-gradient(145deg, color-mix(in srgb, var(--bhf-holo-wash) 20%, #fff 80%), #fff);
  border: 0.1px solid var(--holoform-art-lumen);
  margin: 0 auto 0.3rem;
  box-shadow: 0 1px 0 #fffc inset, 0 2px 8px color-mix(in srgb, #1a1a1a 2.5%, #fff0);
}

.app-holoform-mock--hermes .app-holoform-mock__textline {
  display: block;
  width: 68%;
  height: 0.2rem;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--bhf-lumenedge-muted) 3%, #fff 97%);
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 4%, #fff0);
  margin: 0.12rem 0.2rem;
}

.app-holoform-mock--hermes .app-holoform-mock__textline + .app-holoform-mock__textline {
  width: 48%;
  opacity: 0.7;
}

.app-holoform-mock--hermes .app-holoform-mock__cart {
  position: absolute;
  right: 0.35rem;
  top: 0.35rem;
  width: 0.3rem;
  height: 0.3rem;
  border-radius: 50%;
  background: #fff;
  border: 0.1px solid var(--holoform-art-lumen);
  box-shadow: 0 0 0 0.1px var(--holoform-art-lumen);
}

.app-holoform-mock--hermes .app-holoform-mock__sticky {
  position: absolute;
  left: 0.32rem;
  right: 0.32rem;
  bottom: 0.32rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 0.78rem;
  padding: 0 0.3rem;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--color-accent-orange) 10%, #fff 90%);
  border: 0.1px solid color-mix(in srgb, var(--bhf-lumenedge-primary) 10%, #fff 90%);
  box-shadow: 0 0 0 0.1px var(--holoform-art-lumen), 0 2px 14px color-mix(in srgb, #1a1a1a 4%, #fff0);
  gap: 0.2rem;
}

.app-holoform-mock--hermes .app-holoform-mock__sticky::before {
  content: "";
  width: 0.32rem;
  height: 0.26rem;
  border-radius: 0.1rem;
  background: #fff;
  border: 0.1px solid var(--holoform-art-lumen);
  flex-shrink: 0;
}

.app-holoform-mock--hermes .app-holoform-mock__sticky::after {
  content: "";
  width: 1.05rem;
  height: 0.36rem;
  border-radius: var(--radius-pill);
  background: #fff;
  box-shadow: 0 0 0 0.1px var(--holoform-art-lumen) inset;
  margin-left: auto;
}

/* Nav móvil — página actual: negrita + texto más definido, sin “pastilla” extra */
@media (max-width: 63.99rem) {
  .site-header__nav a[aria-current="page"] {
    font-weight: 700;
    color: color-mix(in srgb, var(--color-text) 94%, #0a0a0a);
    background: rgba(255, 255, 255, 0.22);
    box-shadow: inset 0 0 0 0.5px color-mix(in srgb, var(--bhf-lumenedge-muted) 0.16, rgba(255, 255, 255, 0.22));
  }
}
