/* ==========================================================================
   TECH STACK TICKER  (#ticker) - page order 3
   Builds on the foundation .marquee / .marquee__track mechanism:
   - .marquee already provides overflow:hidden, edge mask, the `marquee`
     keyframe (translateX 0 -> -50%), pause-on-hover, and the reduced-motion
     kill switch. We only layer ticker-specific layout + item styling here.
   All rules scoped under #ticker so they never collide with other sections.
   ========================================================================== */

#ticker {
  /* tighten the vertical rhythm - this is a slim trust band, not a tall block */
  padding-block: var(--section-padding-y-sm);
  overflow: hidden;
}

#ticker .section-header {
  margin-bottom: var(--space-2xl);
}

/* --- marquee shell -------------------------------------------------------- */
/* Re-declare the edge fade locally so the transparent feathering is a touch
   wider/softer and tied to the section, while still cooperating with the
   foundation .marquee mask. */
#ticker .ticker__marquee {
  position: relative;
  padding-block: var(--space-md);
  -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%
  );
}

/* the auto-scrolling track (animation + pause-on-hover come from foundation) */
#ticker .marquee__track {
  align-items: center;
  gap: 0;                 /* spacing handled by the two lists' own gap */
  animation-duration: 42s; /* slow, premium drift */
}

/* each duplicated sequence is a flex row of items */
#ticker .ticker__list {
  display: inline-flex;
  align-items: center;
  gap: clamp(var(--space-xl), 4vw, var(--space-3xl));
  margin: 0;
  padding: 0 clamp(var(--space-xl), 4vw, var(--space-3xl)) 0 0;
  list-style: none;
  white-space: nowrap;
}

/* --- individual stack item ------------------------------------------------ */
#ticker .ticker__item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-text-muted);          /* legible at rest (WCAG AA); accent on hover */
  font-family: var(--font-heading);
  font-size: var(--fs-h4);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  line-height: 1;
  white-space: nowrap;
  transition: color var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}

#ticker .ticker__glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5em;
  height: 1.5em;
  color: var(--color-grey-600);            /* slightly dimmer than the label */
  transition: color var(--dur-base) var(--ease-out),
              filter var(--dur-base) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
}

#ticker .ticker__glyph svg {
  width: 100%;
  height: 100%;
  display: block;
}

#ticker .ticker__label {
  background: none;
}

/* --- hover reveal: metallic grey -> vibrant orange + glow ----------------- */
#ticker .ticker__item:hover,
#ticker .ticker__item:focus-visible {
  color: var(--color-accent);
  transform: translateY(-2px);
}

#ticker .ticker__item:hover .ticker__glyph,
#ticker .ticker__item:focus-visible .ticker__glyph {
  color: var(--color-accent);
  filter: drop-shadow(0 0 8px var(--color-accent-tint-2));
  transform: rotate(-4deg) scale(1.06);
}

/* --- responsive ----------------------------------------------------------- */
@media (min-width: 768px) {
  #ticker .ticker__item {
    font-size: clamp(1.25rem, 1rem + 0.9vw, 1.75rem);
  }
}

/* --- reduced motion ------------------------------------------------------- */
/* The foundation already pauses .marquee__track under reduced motion. We make
   sure the full content is still readable by allowing the track to wrap and
   center, and we strip the per-item lift/rotate transforms. */
@media (prefers-reduced-motion: reduce) {
  #ticker .ticker__marquee {
    -webkit-mask-image: none;
    mask-image: none;
  }
  #ticker .marquee__track {
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(var(--space-lg), 3vw, var(--space-2xl));
    width: 100%;
  }
  #ticker .ticker__list[aria-hidden="true"] {
    display: none;            /* hide the duplicate sequence when static */
  }
  #ticker .ticker__list {
    flex-wrap: wrap;
    justify-content: center;
    padding: 0;
  }
  #ticker .ticker__item:hover,
  #ticker .ticker__item:focus-visible {
    transform: none;
  }
  #ticker .ticker__item:hover .ticker__glyph,
  #ticker .ticker__item:focus-visible .ticker__glyph {
    transform: none;
    filter: none;
  }
}
