/* ============================================================
   MIFF 2026 — Homepage-only styles v2
   Premium Awwwards-grade redesign
   ============================================================ */

/* ── Ticker band animations ── */
@keyframes left  { from{transform:translateX(0)} to{transform:translateX(-54000px)} }
@keyframes back  { from{transform:translateX(0)} to{transform:translateX(-54870px)} }
@keyframes right { from{transform:translateX(0)} to{transform:translateX(-55740px)} }
@keyframes filter-animation {
  0%,100% { filter:hue-rotate(0deg) }
  50%     { filter:hue-rotate(100deg) }
}
@keyframes zoom-in {
  0%   { transform:scale(1) }
  100% { transform:scale(2.5) }
}
@keyframes text-glow {
  0%,100% { opacity:.75 }
  50%     { opacity:1 }
}

/* ── 3D Poem / Prism animation section ── */
.pa-section {
  position:relative; width:100%; overflow:hidden;
  background:
    radial-gradient(ellipse 90% 70% at 29% 50%, rgba(34,197,94,.10) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 85% 30%, rgba(14,165,233,.06) 0%, transparent 55%),
    linear-gradient(160deg, #060C09 0%, var(--ink) 60%, #03080A 100%);
  display:flex; justify-content:center; align-items:center; min-height:562px;
}
.pa-outer   { display:flex; justify-content:center; align-items:center; width:100%; overflow:hidden; }
.pa-content { transform-origin:center top; flex-shrink:0; }
.pa-full    { position:relative; width:1000px; height:562px; overflow:hidden; }
.pa-full-scrim {
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(90deg, rgba(6,12,10,.6) 0%, rgba(6,12,10,.1) 60%, rgba(6,12,10,.5) 100%),
    linear-gradient(180deg, rgba(6,12,10,.5) 0%, transparent 40%, rgba(6,12,10,.65) 100%);
}
.pa-hue {
  position:absolute; inset:0; z-index:6; pointer-events:none;
  animation:filter-animation 8s ease-in-out infinite; mix-blend-mode:hue;
  background:rgba(34,197,94,.04); will-change:filter;
}
.pa-bg {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  animation:zoom-in 60s ease-in-out forwards; filter:brightness(.5) saturate(.85); will-change:transform;
}
.pa-fig { position:absolute; bottom:0; right:30px; height:100%; width:auto; object-fit:contain; z-index:2; }
.pa-cube-wrap {
  position:absolute; top:50%; left:29%; transform:translate(-50%,-50%);
  perspective:1000px; width:280px; height:280px; z-index:3;
}
.pa-cube-wrap::before {
  content:""; position:absolute; inset:-80px;
  background:radial-gradient(circle, rgba(34,197,94,.2), transparent 70%);
  filter:blur(32px); z-index:-1; pointer-events:none;
}
.pa-reflect-wrap {
  position:absolute; top:50%; left:29%;
  transform:translate(-50%,-50%) scaleY(-1) translateY(30px);
  perspective:1000px; width:280px; height:280px; z-index:1; opacity:.2; filter:blur(3px);
}
.pa-cube {
  width:280px; height:280px; position:relative; transform-style:preserve-3d;
  animation:pa-spin 20s linear infinite; will-change:transform;
}
@keyframes pa-spin {
  from { transform:rotateX(-15deg) rotateY(0deg) }
  to   { transform:rotateX(-15deg) rotateY(360deg) }
}
.pa-face {
  position:absolute; width:280px; height:280px; overflow:hidden;
  backface-visibility:hidden; background:rgba(6,12,10,.72);
  border:1px solid rgba(34,197,94,.22);
}
.pa-face.pa-front  { transform:rotateY(  0deg) translateZ(140px) }
.pa-face.pa-back   { transform:rotateY(180deg) translateZ(140px) }
.pa-face.pa-left   { transform:rotateY(-90deg) translateZ(140px) }
.pa-face.pa-right  { transform:rotateY( 90deg) translateZ(140px) }
.pa-face.pa-top    { transform:rotateX( 90deg) translateZ(140px); opacity:.35 }
.pa-face.pa-bottom { transform:rotateX(-90deg) translateZ(140px); opacity:.35 }
.pa-face.pa-text   { display:flex; align-items:center }
.pa-face.pa-text p {
  white-space:nowrap; font-size:10px; font-family:var(--font-mono);
  color:rgba(34,197,94,.82); line-height:1.4; padding:8px 12px; margin:0;
  animation:text-glow 4s ease-in-out infinite; will-change:transform,opacity;
}
.pa-face.pa-text p span { color:var(--amber-bright) }
#pa-face-left  p,#pa-rface-left  p { animation:left  180s linear infinite,text-glow 4s ease-in-out infinite }
#pa-face-back  p,#pa-rface-back  p { animation:back  185s linear infinite,text-glow 4s ease-in-out .8s infinite }
#pa-face-right p,#pa-rface-right p { animation:right 190s linear infinite,text-glow 4s ease-in-out 1.6s infinite }

/* ============================================================
   HERO — Two-column glassmorphism layout
   ============================================================ */

/* Hero base */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  padding-top: 120px;
  overflow: hidden;
}
.hero-media {
  position: absolute;
  inset: 0;
  z-index: 0;
  /* Deep layered hero base — indigo/rose ambient matching site background */
  background:
    radial-gradient(ellipse 120% 70% at 30% -5%,
      rgba(99,102,241,.14) 0%,
      rgba(99,102,241,.05) 40%,
      transparent 65%),
    radial-gradient(ellipse 60% 50% at 92% 10%,
      rgba(244,63,94,.09) 0%,
      transparent 55%),
    radial-gradient(ellipse 50% 80% at 0% 60%,
      rgba(139,92,246,.07) 0%,
      transparent 58%),
    linear-gradient(175deg, #050508 0%, #030303 55%, #040406 100%);
}
.hero-beams-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  filter: blur(18px);
}
.hero-scrim {
  position: absolute;
  inset: 0;
  background:
    /* Vertical depth fade — sky to ground */
    linear-gradient(180deg,
      rgba(4,10,7,.55) 0%,
      rgba(4,10,7,.18) 28%,
      rgba(4,10,7,.72) 72%,
      var(--ink) 100%),
    /* Left-edge vignette — frames the copy column */
    linear-gradient(90deg,
      rgba(4,10,7,.78) 0%,
      rgba(4,10,7,.38) 38%,
      transparent 60%),
    /* Right-edge fade — softens right column bleed */
    linear-gradient(270deg,
      rgba(4,10,7,.40) 0%,
      transparent 45%);
}
.hero-grid {
  position: absolute;
  inset: 0;
  opacity: .45;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: linear-gradient(180deg, transparent, #000 38%, #000 68%, transparent);
}

/* Two-col grid */
.hero-in {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: clamp(48px, 6vw, 96px);
  align-items: center;
  width: 100%;
}
.hero-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-element);
  padding-bottom: 120px;
}

/* Right glass column */
.hero-glass-col {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 120px;
}

.hero-cta { display: flex; gap: 16px; margin-top: var(--space-block); flex-wrap: wrap; }

/* Event strip — Framer-style minimal meta below CTAs */
.hero-event-strip {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 20px;
  flex-wrap: wrap;
}
.hes-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--muted);
}
.hes-item svg { opacity: .65; flex-shrink: 0; }
.hes-item--date {
  color: var(--amber);
  font-weight: 600;
  letter-spacing: .06em;
}
.hes-item--date svg { opacity: 1; stroke: var(--amber); }
.hes-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--faint);
  flex-shrink: 0;
}

/* Hero Associate Partner */
.hero-partner-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.hero-partner-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.hero-partner-logo {
  height: 32px;
  width: auto;
  object-fit: contain;
  filter: brightness(1.1) saturate(.85);
  opacity: .85;
  transition: opacity .2s;
}
.hero-partner-logo:hover { opacity: 1; }

/* Ticker */
.ticker {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 2;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(6,12,10,.9);
  overflow: hidden;
  padding: 15px 0;
}
.ticker-row {
  display: flex;
  gap: 0;
  white-space: nowrap;
  width: max-content;
  animation: tick 42s linear infinite;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  will-change: transform;
}
.ticker-row span { padding: 0 24px; }
.ticker-row i    { color: var(--amber); font-style: normal; }
@keyframes tick { to { transform: translateX(-50%) } }

/* ── Glass card base ── */
.glass-card {
  position: relative;
  border-radius: 22px;
  border: 1px solid var(--glass-border);
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  overflow: hidden;
  transition: border-color .4s, box-shadow .4s;
  /* Inset top shimmer edge */
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 1px 0 rgba(0,0,0,.3);
}
.glass-card:hover {
  border-color: rgba(34,197,94,.26);
  box-shadow:
    inset 0 1px 0 rgba(34,197,94,.14),
    0 0 0 1px rgba(34,197,94,.08),
    0 24px 72px -20px rgba(34,197,94,.28),
    0 8px 32px -8px rgba(0,0,0,.6);
}

/* Ambient glow inside stats card */
.gc-glow {
  position: absolute;
  top: -80px; right: -80px;
  width: 260px; height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34,197,94,.16) 0%, transparent 70%);
  pointer-events: none;
  filter: blur(22px);
}

.gc-inner { padding: 28px 28px 24px; }

/* Countdown block */
.gc-countdown-block {
  margin-bottom: 26px;
}
.gc-countdown-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
}
.gc-countdown-units {
  display: flex;
  align-items: center;
  gap: 6px;
}
.gc-cdu {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  min-width: 48px;
  background: rgba(34,197,94,.07);
  border: 1px solid rgba(34,197,94,.15);
  border-radius: 10px;
  padding: 8px 6px 6px;
}
.gc-cdu-val {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--text);
}
.gc-cdu-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--muted);
}
.gc-cdu-sep {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 300;
  color: rgba(34,197,94,.4);
  margin-bottom: 12px;
  user-select: none;
}
.gc-countdown-date {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--amber);
  margin-top: 10px;
}

/* Progress bar */
.gc-bar-row { margin-bottom: 24px; }
.gc-bar-labels {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.gc-bar-pct { color: var(--text); font-weight: 600; }
.gc-bar-track {
  height: 5px;
  border-radius: 99px;
  background: rgba(255,255,255,.07);
  overflow: hidden;
}
.gc-bar-fill {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--amber-deep), var(--amber), var(--amber-bright));
  box-shadow: 0 0 12px rgba(34,197,94,.55);
  will-change: width;
}

.gc-divider { height: 1px; background: rgba(255,255,255,.07); margin: 0 0 22px; }

/* Mini stats */
.gc-mini-stats {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  align-items: center;
  text-align: center;
  margin-bottom: 24px;
}
.gc-mini {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  cursor: default;
  transition: transform .25s;
}
.gc-mini:hover { transform: translateY(-2px); }
.gc-mini-val {
  font-family: var(--font-display);
  font-size: clamp(18px, 1.8vw, 24px);
  font-weight: 500;
  color: var(--text);
  line-height: 1;
  letter-spacing: -0.03em;
}
.gc-mini-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--faint);
}
.gc-mini-sep { width: 1px; height: 38px; background: rgba(255,255,255,.08); margin: 0 auto; }

/* Status pills */
.gc-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.gc-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 99px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
  transition: border-color .3s, background .3s;
}
.gc-pill:hover { background: rgba(255,255,255,.07); }
.gc-pill-live    { border-color: rgba(34,197,94,.25); color: var(--amber-bright); }
.gc-pill-premium { border-color: rgba(234,179,8,.25); color: #EAB308; }

/* Pulsing dot */
.gc-ping { position: relative; display: inline-flex; width: 7px; height: 7px; }
.gc-ping::before, .gc-ping::after { content:""; position:absolute; inset:0; border-radius:50%; background:var(--amber-bright); }
.gc-ping::before { animation: gcPing 1.4s cubic-bezier(0,0,.2,1) infinite; opacity:.7; }
@keyframes gcPing { 75%,100% { transform:scale(2.2); opacity:0; } }

/* ── Marquee glass card ── */
.glass-marquee .gc-inner { padding: 20px 0; }
.gc-marquee-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 0 24px 14px;
}
.gc-marquee-wrap {
  position: relative;
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent, #000 18%, #000 82%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, #000 18%, #000 82%, transparent);
}
.gc-marquee-curve {
  position: absolute;
  left: 0;
  right: 0;
  top: 6px;
  height: 120px;
  pointer-events: none;
  z-index: 0;
  display: block;
}
.gc-marquee-curve svg { width: 100%; height: 100%; display: block; }
.glass-marquee .gc-inner { position: relative; z-index: 2; }
.gc-marquee-wrap { position: relative; z-index: 3; }
.gc-marquee-track {
  display: flex;
  gap: 0;
  white-space: nowrap;
  width: max-content;
  animation: gcMarquee 28s linear infinite;
  will-change: transform;
}
.gc-logo-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 6px;
  vertical-align: middle;
  transform: translateY(0);
  transition: transform .34s cubic-bezier(.2,1,.3,1);
}
.gc-logo-item img { display:block; }
/* Create an arc by offsetting the first set of 11 items */
.gc-marquee-track .gc-logo-item:nth-child(1)  { transform: translateY(0px); }
.gc-marquee-track .gc-logo-item:nth-child(2)  { transform: translateY(-6px); }
.gc-marquee-track .gc-logo-item:nth-child(3)  { transform: translateY(-12px); }
.gc-marquee-track .gc-logo-item:nth-child(4)  { transform: translateY(-18px); }
.gc-marquee-track .gc-logo-item:nth-child(5)  { transform: translateY(-22px); }
.gc-marquee-track .gc-logo-item:nth-child(6)  { transform: translateY(-26px); }
.gc-marquee-track .gc-logo-item:nth-child(7)  { transform: translateY(-22px); }
.gc-marquee-track .gc-logo-item:nth-child(8)  { transform: translateY(-18px); }
.gc-marquee-track .gc-logo-item:nth-child(9)  { transform: translateY(-12px); }
.gc-marquee-track .gc-logo-item:nth-child(10) { transform: translateY(-6px); }
.gc-marquee-track .gc-logo-item:nth-child(11) { transform: translateY(0px); }
/* mirror offsets for the duplicated set */
.gc-marquee-track .gc-logo-item:nth-child(12) { transform: translateY(0px); }
.gc-marquee-track .gc-logo-item:nth-child(13) { transform: translateY(-6px); }
.gc-marquee-track .gc-logo-item:nth-child(14) { transform: translateY(-12px); }
.gc-marquee-track .gc-logo-item:nth-child(15) { transform: translateY(-18px); }
.gc-marquee-track .gc-logo-item:nth-child(16) { transform: translateY(-22px); }
.gc-marquee-track .gc-logo-item:nth-child(17) { transform: translateY(-26px); }
.gc-marquee-track .gc-logo-item:nth-child(18) { transform: translateY(-22px); }
.gc-marquee-track .gc-logo-item:nth-child(19) { transform: translateY(-18px); }
.gc-marquee-track .gc-logo-item:nth-child(20) { transform: translateY(-12px); }
.gc-marquee-track .gc-logo-item:nth-child(21) { transform: translateY(-6px); }
.gc-marquee-track .gc-logo-item:nth-child(22) { transform: translateY(0px); }
.gc-marquee-track .gc-logo {
  height: 44px;
  display: inline-block;
  margin: 0 24px;
  object-fit: contain;
  opacity: .92;
  filter: none;
  transition: opacity .22s, transform .22s, filter .22s;
}
.gc-marquee-track .gc-logo:hover {
  opacity: 1;
  transform: translateY(-4px) scale(1.02);
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.45));
}
.gc-marquee-wrap:hover .gc-marquee-track {
  animation-play-state: paused;
}
.gc-marquee-track i { color: var(--amber); font-style: normal; font-size: 12px; opacity: .4; align-self: center; }
@keyframes gcMarquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ============================================================
   STATS ROW
   ============================================================ */
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  margin-top: var(--space-block);
  border: 1px solid var(--line);
}
.stats-row .stat {
  background: linear-gradient(160deg, var(--surface), var(--ink));
  padding: 56px 44px;
  position: relative;
  overflow: hidden;
  transition: background .35s;
}
.stats-row .stat::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--amber), transparent 60%);
  opacity: 0;
  transition: opacity .35s;
}
.stats-row .stat:hover { background: linear-gradient(160deg, var(--surface-2), var(--ink-2)); }
.stats-row .stat:hover::before { opacity: 1; }

/* ============================================================
   OVERVIEW SPLIT
   ============================================================ */
.overview {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(64px, 8vw, 120px);
  align-items: center;
}
.ov-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-text);
}
.ov-text .ov-kicker { margin-bottom: 0; }
.ov-actions { margin-top: var(--space-element); }

/* Kicker with leading line */
.ov-kicker {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--muted);
}
.ov-kicker-line {
  display: block;
  width: 32px;
  height: 1px;
  background: var(--muted);
  flex-shrink: 0;
}

/* Heading with muted last segment */
.ov-heading-dim {
  -webkit-text-fill-color: var(--muted);
}

/* Mosaic image grid */
.ov-mosaic {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  height: 520px;
}
.ov-mosaic-col {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ov-mosaic-img {
  overflow: hidden;
  border-radius: 16px;
  position: relative;
  will-change: clip-path, transform, opacity;
}
.ov-mosaic-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  will-change: transform;
  transition: transform .8s cubic-bezier(.22,1,.36,1);
}
@media (prefers-reduced-motion: reduce) {
  .ov-mosaic-img,
  .ov-mosaic-img img { will-change: auto; }
}
.ov-mosaic-img:hover img { transform: scale(1.04); }

/* Left column: tall top + short bottom */
.ov-mosaic-col--left .ov-mosaic-img--tall { flex: 1.6; }
.ov-mosaic-col--left .ov-mosaic-img--wide { flex: 1; }

/* Right column: small top + taller bottom */
.ov-mosaic-col--right .ov-mosaic-img--sq { flex: 1; }
.ov-mosaic-col--right .ov-mosaic-img--portrait { flex: 1.6; }

/* ============================================================
   PILLAR CAROUSEL
   ============================================================ */
.pc-carousel {
  margin-top: 0;
  position: relative;
  overflow: hidden;
  border-radius: 2rem;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: linear-gradient(180deg, rgba(8, 8, 14, 0.5) 0%, rgba(3, 3, 5, 0.7) 100%);
  box-shadow: 
    inset 0 1px 0 rgba(255, 255, 255, 0.03),
    0 4px 24px -8px rgba(0, 0, 0, 0.5),
    0 32px 80px -20px rgba(0, 0, 0, 0.85);
  display: flex;
  flex-direction: column;
  min-height: auto;
  z-index: 2;
}

/* Spotlight hover glow effect */
.pc-carousel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at var(--glow-x, 20%) var(--glow-y, 30%), rgba(34, 197, 94, 0.08) 0%, transparent 60%);
  opacity: 0.8;
  transition: opacity 0.5s ease;
  z-index: 0;
}

@media (min-width: 900px) {
  .pc-carousel {
    flex-direction: column;
    aspect-ratio: unset;
    min-height: 520px;
    border-radius: 2.8rem;
  }
}

/* Heading now lives inside pc-left */
.pc-heading {
  padding: 0;
  margin-bottom: 1.25rem;
  flex-shrink: 0;
}
.pc-heading-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
}
.pc-step-counter {
  display: flex;
  align-items: baseline;
  gap: 2px;
  flex-shrink: 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  color: rgba(255, 255, 255, 0.35);
  padding-top: 6px;
}
.pc-step-cur {
  color: var(--amber-bright);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: .04em;
}
.pc-step-sep { opacity: .45; }
.pc-progress {
  margin-top: 1.25rem;
  height: 2px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}
.pc-progress-fill {
  height: 100%;
  width: 20%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--amber-deep), var(--amber-bright));
  box-shadow: 0 0 12px rgba(34, 197, 94, 0.45);
  transition: width 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}
@media (min-width: 900px) {
  .pc-heading {
    padding: 0;
    margin-bottom: 1.75rem;
  }
  .pc-step-cur { font-size: 22px; }
}

/* Inner row: left + right panels */
.pc-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
@media (min-width: 900px) {
  .pc-body {
    flex-direction: row;
    min-height: clamp(450px, 50vh, 520px);
  }
}

/* Left panel */
.pc-left {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 1.5rem 1.2rem;
  background: transparent;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  z-index: 2;
  overflow: hidden;
}
@media (min-width: 900px) {
  .pc-left {
    width: 44%;
    padding: 2.75rem 2.5rem 2.75rem 3rem;
    border-bottom: none;
    border-right: 1px solid rgba(255, 255, 255, 0.04);
  }
}

/* Fade indicators - no longer needed */
.pc-fade-top, .pc-fade-bot {
  display: none !important;
}

/* Labels wrap */
.pc-labels-wrap {
  display: flex;
  flex-direction: row;
  gap: 10px;
  width: 100%;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  z-index: 5;
  padding-block: 4px;
}
.pc-labels-wrap::-webkit-scrollbar {
  display: none;
}
@media (min-width: 900px) {
  .pc-labels-wrap {
    flex-direction: column;
    gap: 10px;
    overflow: visible;
    height: auto;
    flex: 1;
    justify-content: center;
    padding-block: 0.25rem;
  }
}

/* Label item */
.pc-label {
  flex-shrink: 0;
  transform: none !important;
  opacity: 1 !important;
  position: relative !important;
  height: auto !important;
  width: auto !important;
}
@media (min-width: 900px) {
  .pc-label {
    width: 100% !important;
  }
}

/* Label Button */
.pc-label-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  color: rgba(255, 255, 255, 0.42);
  cursor: pointer;
  font-family: var(--font-body);
  text-align: left;
  white-space: nowrap;
  opacity: 0.55;
  transition:
    opacity 0.35s cubic-bezier(0.16, 1, 0.3, 1),
    border-color 0.35s ease,
    background 0.35s ease,
    box-shadow 0.35s ease,
    transform 0.35s ease;
  position: relative;
  z-index: 1;
}
.pc-label-btn:focus-visible {
  outline: 2px solid rgba(34, 197, 94, 0.55);
  outline-offset: 2px;
}

.pc-label-marker {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  flex-shrink: 0;
}

.pc-label-copy {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.pc-label-num {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.32);
  transition: color 0.3s ease;
}

.pc-label-text {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: rgba(255, 255, 255, 0.5);
  transition: color 0.3s ease;
}

.pc-indicator-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: transparent;
  transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  opacity: 0;
  transform: scale(0.4);
  flex-shrink: 0;
}

/* Hover State */
.pc-label-btn:not(.is-active):hover {
  opacity: 0.82;
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.025);
}
.pc-label-btn:not(.is-active):hover .pc-label-text {
  color: rgba(255, 255, 255, 0.88);
}
.pc-label-btn:not(.is-active):hover .pc-label-num {
  color: rgba(255, 255, 255, 0.5);
}

/* Active State */
.pc-label-btn.is-active {
  opacity: 1;
  background: rgba(34, 197, 94, 0.04);
  border-color: rgba(34, 197, 94, 0.32);
  color: #fff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 0 1px rgba(34, 197, 94, 0.08),
    0 12px 32px -16px rgba(34, 197, 94, 0.35);
}
.pc-label-btn.is-active .pc-label-text {
  color: #fff;
}
.pc-label-btn.is-active .pc-label-num {
  color: var(--amber-bright);
}
.pc-label-btn.is-active .pc-indicator-dot {
  background: var(--amber-bright);
  box-shadow: 0 0 10px var(--amber-bright), 0 0 20px rgba(34, 197, 94, 0.35);
  opacity: 1;
  transform: scale(1);
}

@media (min-width: 900px) {
  .pc-label-btn {
    padding: 15px 18px;
    border-radius: 16px;
    white-space: normal;
  }

  .pc-label-num {
    font-size: 10px;
  }

  .pc-label-text {
    font-size: clamp(15px, 1.35vw, 17px);
    line-height: 1.25;
  }

  .pc-indicator-dot {
    width: 7px;
    height: 7px;
  }
}

/* Right panel */
.pc-right {
  flex: 1;
  min-height: 460px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  background: transparent;
  z-index: 2;
}
@media (min-width: 900px) {
  .pc-right {
    min-height: unset;
    padding: 2rem 2.5rem 2rem 1.5rem;
  }
}

.pc-card-wrap {
  position: relative;
  width: min(100%, 100%);
  max-width: 520px;
  flex: 1;
  min-height: 320px;
}
@media (min-width: 900px) {
  .pc-card-wrap {
    min-height: 0;
    aspect-ratio: 4 / 3;
  }
}

.pc-card {
  position: absolute;
  inset: 0;
  border-radius: 1.6rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: var(--ink);
  will-change: transform, opacity;
  transition: none;
  transform-origin: center center;
  box-shadow: 0 24px 64px -24px rgba(0, 0, 0, 0.75);
}
.pc-card.is-active {
  border-color: rgba(34, 197, 94, 0.22);
  box-shadow:
    0 0 0 1px rgba(34, 197, 94, 0.12),
    0 28px 72px -20px rgba(0, 0, 0, 0.85),
    0 0 48px -12px rgba(34, 197, 94, 0.18);
}

.pc-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: filter 0.55s ease, transform 8s ease;
  transform: scale(1.04);
}
.pc-card.is-active img {
  filter: saturate(1.05) contrast(1.02);
  transform: scale(1);
}
.pc-card:not(.is-active) img {
  filter: grayscale(1) brightness(0.45) blur(3px);
}

.pc-card-scrim {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.25) 0%, transparent 35%),
    linear-gradient(0deg, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.3) 45%, transparent 100%);
}

.pc-card-overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 3rem 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.45s ease 0.08s, transform 0.45s ease 0.08s;
  pointer-events: none;
  z-index: 2;
}
.pc-card.is-active .pc-card-overlay {
  opacity: 1;
  transform: translateY(0);
}

.pc-card-tag {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: rgba(255, 255, 255, 0.92);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  width: fit-content;
  margin-bottom: 12px;
}
.pc-card-desc {
  color: rgba(255, 255, 255, 0.94);
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 1.25vw, 1.12rem);
  font-weight: 400;
  line-height: 1.55;
  letter-spacing: -0.015em;
  max-width: 36ch;
}
.pc-live-dot {
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
  display: flex;
  align-items: center;
  gap: 8px;
  opacity: 0;
  transition: opacity 0.4s ease 0.15s;
  z-index: 2;
}
.pc-card.is-active .pc-live-dot { opacity: 1; }
.pc-live-dot .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.85);
  flex-shrink: 0;
  animation: pc-pulse 2.4s ease-in-out infinite;
}
@keyframes pc-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.88); }
}
.pc-live-dot span {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
}

.pc-footer-cta {
  margin-top: 36px;
  display: flex;
  justify-content: center;
}

@media (max-width: 899px) {
  .pc-label-btn {
    width: auto;
    min-width: max-content;
    border-radius: 99px;
    padding: 10px 16px;
  }
  .pc-label-marker { width: 10px; }
  .pc-label-copy { flex-direction: row; align-items: center; gap: 8px; }
  .pc-label-text { font-size: 12px; }
  .pc-step-counter { display: none; }
  .pc-progress { margin-top: 1rem; }
}

@media (prefers-reduced-motion: reduce) {
  .pc-card img { transition: filter 0.3s ease; transform: none !important; }
  .pc-live-dot .dot { animation: none; }
  .pc-progress-fill { transition: none; }
}

/* ============================================================
   SECTORS CAROUSEL
   ============================================================ */
.sectors-band {
  border-block: 1px solid var(--line);
  background: linear-gradient(160deg, rgba(34,197,94,.05), transparent 55%);
  position: relative;
}
.sectors-band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 15% 55%, rgba(34,197,94,.08), transparent 55%);
}
.sectors-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-block);
  gap: var(--space-element);
}
.sectors-head-left { display: flex; flex-direction: column; gap: var(--space-text); align-items: flex-start; }
.sectors-nav { display: flex; gap: 8px; flex-shrink: 0; padding-top: 8px; }
.sectors-arrow {
  width: 48px; height: 48px;
  border: 1px solid var(--line-2);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  transition: all .3s;
}
.sectors-arrow:hover:not(:disabled) { border-color: var(--amber); color: var(--amber); background: rgba(34,197,94,.07); }
.sectors-arrow:disabled { opacity: .25; cursor: not-allowed; }
.sectors-track-wrap { overflow: hidden; width: 100%; }
.sectors-track {
  display: flex;
  gap: 32px;
  padding-left: max(var(--gutter), calc((100vw - var(--maxw)) / 2 + var(--gutter)));
  padding-right: var(--gutter);
  will-change: transform;
}
.sector-slide { flex-shrink: 0; width: clamp(300px, 30vw, 400px); text-decoration: none; color: inherit; display: block; }
.sector-slide-inner {
  position: relative;
  height: 380px;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: 0 28px 70px -20px rgba(0,0,0,.55);
}
.sector-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform .55s cubic-bezier(.22,1,.36,1); }
.sector-slide:hover .sector-img { transform: scale(1.08); }
.sector-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(6,12,10,0) 0%, rgba(6,12,10,.15) 35%, rgba(6,12,10,.68) 65%, rgba(6,12,10,.94) 100%);
}
.sector-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 36px 30px; }
.sector-tag { font-family: var(--font-body); font-size: 12px; text-transform: none; letter-spacing: -0.01em; font-weight: 500; color: var(--amber); margin-bottom: 12px; }
.sector-name { font-family: var(--font-display); font-size: clamp(18px, 1.8vw, 24px); font-weight: 500; line-height: 1.2; letter-spacing: -0.02em; color: #fff; margin-bottom: 12px; }
.sector-desc {
  font-size: 15px;
  line-height: 1.65;
  color: rgba(238,242,248,.68);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 22px;
}
.sector-read { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; color: var(--amber); letter-spacing: .01em; transition: gap .3s; }
.sector-read svg { transition: transform .3s; }
.sector-slide:hover .sector-read { gap: 12px; }
.sector-slide:hover .sector-read svg { transform: translateX(3px); }
.sectors-dots { display: flex; justify-content: center; gap: 8px; margin-top: var(--space-block); }
.sectors-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: rgba(34,197,94,.2);
  transition: all .3s;
  padding: 0;
}
.sectors-dot.active { background: var(--amber); width: 24px; border-radius: 4px; }
@media (max-width: 767px) {
  .sectors-nav { display: none; }
  .sector-slide { width: 300px; }
  .sector-slide-inner { height: 320px; }
  .sector-content { padding: 24px 20px; }
}

/* ============================================================
   WHY SECTION — numbered list
   ============================================================ */
.why {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}
.why-head { position: sticky; top: 110px; }
.why-list { list-style: none; display: grid; gap: 0; }
.why-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  padding: 26px 0;
  border-top: 1px solid var(--line);
  cursor: default;
  transition: background .25s;
}
.why-list li:last-child { border-bottom: 1px solid var(--line); }
.why-list .idx { font-size: 14px; padding-top: 4px; }
.why-list h4 { margin-bottom: 8px; }
.why-list p  { font-size: 15px; line-height: 1.65; }

/* ── Why-list hover image (Framer-style cursor image) ── */
.why-hover-img {
  position: fixed;
  top: 0; left: 0;
  width: 220px;
  height: 160px;
  border-radius: 18px;
  overflow: hidden;
  pointer-events: none;
  z-index: 200;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.82) rotate(-3deg);
  transition:
    opacity 0.28s cubic-bezier(.4,0,.2,1),
    transform 0.28s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 24px 64px rgba(0,0,0,.55), 0 4px 16px rgba(0,0,0,.35);
  will-change: transform, opacity;
}
.why-hover-img.visible {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1) rotate(0deg);
}
.why-hover-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.why-list li {
  transition: background .22s;
}
.why-list li.hovered h4 { color: var(--amber); transition: color .2s; }

/* ============================================================
   SPEAKERS TEASER — horizontal scroll row
   ============================================================ */
.spk-row {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 6px;
  margin-top: 60px;
  scrollbar-width: none;
}
.spk-row::-webkit-scrollbar { display: none; }
.spk-card { flex: 0 0 290px; scroll-snap-align: start; transition: transform .4s cubic-bezier(.22,1,.36,1); }
.spk-card:hover { transform: translateY(-8px); }
.spk-photo {
  width: 100%;
  height: 360px;
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  background: #16161e;
  margin-bottom: 16px;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.75);
}
.spk-photo image-slot { width: 100%; height: 100%; }
.spk-photo image-slot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  filter: grayscale(100%) contrast(1.1) brightness(.9);
  transition: filter .5s ease, transform .6s cubic-bezier(.22,1,.36,1);
}
.spk-card:hover .spk-photo image-slot img { filter: grayscale(0%) contrast(1.05) brightness(1); transform: scale(1.05); }
.spk-socials { position: absolute; bottom: 10px; right: 10px; display: flex; gap: 7px; }
.spk-soc {
  width: 34px; height: 34px;
  background: rgba(15,15,25,.72);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
  transition: background .2s;
}
.spk-soc:hover { background: rgba(255,255,255,.15); }
.spk-soc svg { width: 14px; height: 14px; fill: none; stroke: #fff; stroke-width: 1.8; }
.spk-name { font-size: 17px; font-weight: 700; margin-bottom: 4px; }
.spk-role { font-size: 11px; color: rgba(255,255,255,.45); }
.spk-bar {
  display: flex;
  align-items: center;
  gap: 22px;
  margin-top: 48px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  justify-content: space-between;
}
.spk-count  { font-size: 14px; color: rgba(255,255,255,.48); flex-shrink: 0; }
.spk-line   { flex: 1; height: 1px; background: var(--line); }
.see-all-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  font-size: 15px;
  font-weight: 500;
  padding: 0;
  text-decoration: none;
  transition: all .3s;
}
.see-all-btn:hover { color: var(--amber); }
.see-all-circle {
  width: 44px; height: 44px;
  background: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: transform .3s ease;
}
.see-all-btn:hover .see-all-circle { transform: rotate(45deg) scale(1.08); }
.see-all-circle svg { width: 16px; height: 16px; fill: none; stroke: #000; stroke-width: 2; }
#speakers-teaser { background: var(--ink-2); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .hero-in { grid-template-columns: 1fr 380px; }
}
@media (max-width: 900px) {
  .hero-in {
    grid-template-columns: minmax(0, 1fr);
    padding-bottom: 72px;
  }
  .hero-body { padding-bottom: 0; min-width: 0; }
  .hero-glass-col {
    padding-bottom: 0;
    max-width: 560px;
    margin: 0 auto;
    width: 100%;
    min-width: 0;
  }
  .gc-marquee-wrap {
    mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
    -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
  }
  .overview { grid-template-columns: 1fr; gap: 36px; }
  .ov-mosaic { height: 360px; }
  .ov-mosaic-img { border-radius: 12px; }
  .why { grid-template-columns: 1fr; gap: 32px; }
  .why-head { position: static; }
  .spk-card { flex: 0 0 240px; }
  .stats-row { grid-template-columns: 1fr 1fr; }
  .stats-row .stat { padding: 36px 26px; }
}
@media (max-width: 480px) {
  .gc-inner { padding: 20px 16px 16px; }
}
@media (max-width: 560px) {
  .spk-card { flex: 0 0 200px; }
.spk-bar { flex-wrap: wrap; gap: 12px; flex-direction: column; align-items: flex-start; }
  .spk-line { width: 100%; height: 1px; margin: 8px 0; order: 2; }
  .see-all-btn { order: 3; align-self: flex-end; margin-top: 6px; }
  .stats-row { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .pa-cube, .pa-hue, .pa-bg,
  .ticker-row, .pa-face.pa-text p,
  #pa-face-left p, #pa-rface-left p,
  #pa-face-back p, #pa-rface-back p,
  #pa-face-right p, #pa-rface-right p,
  .gc-marquee-track, .gc-ping::before {
    animation: none !important;
  }
  .spk-card:hover, .glass-card:hover { transform: none; }
  .sector-slide:hover .sector-img, .sector-slide:hover .sector-read svg { transform: none; }
  .sectors-track { transition: none; }
}

/* ============================================================
   MEDIA PARTNERS SECTION
   ============================================================ */
@keyframes mp-scroll { from { transform: translateX(0) } to { transform: translateX(-50%) } }

.media-partners-sec {
  position: relative;
  overflow: hidden;
}
.media-partners-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 80% 50%, rgba(14,165,233,.05) 0%, transparent 60%),
    radial-gradient(ellipse 50% 80% at 10% 50%, rgba(34,197,94,.04) 0%, transparent 60%);
  pointer-events: none;
}

.mp-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: var(--space-block);
  flex-wrap: wrap;
}
.mp-header-copy { display: flex; flex-direction: column; gap: 12px; }

.mp-marquee-outer {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.mp-marquee-track {
  display: flex;
  flex-wrap: nowrap;
  width: max-content;
  gap: 16px;
  padding: 8px 0;
  max-width: none;
  margin: 0;
  animation: mp-scroll 35s linear infinite;
}
.mp-marquee-track:hover {
  animation-play-state: paused;
}
.mp-marquee-track .mp-logo-card {
  flex: 0 0 200px;
  width: 200px;
}

.mp-logo-card {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 120px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.03);
  transition: border-color .3s, background .3s, transform .3s;
  text-decoration: none;
  overflow: hidden;
  padding: 0;
  box-sizing: border-box;
}
.mp-logo-card:hover {
  border-color: rgba(34,197,94,.3);
  background: rgba(34,197,94,.05);
  transform: translateY(-3px);
}
.mp-logo-card img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: none;
  opacity: .8;
  transition: opacity .3s, filter .3s;
  display: block;
}
.mp-logo-card:hover img {
  opacity: 1;
  filter: none;
}

.mp-divider {
  display: none;
}

@media (max-width: 639px) {
  .mp-marquee-track .mp-logo-card { flex: 0 0 140px; width: 140px; }
  .mp-logo-card { height: 100px; padding: 0; }
}

/* Participating companies — left-to-right scrolling marquee */
@keyframes mp-scroll-ltr { from { transform: translateX(-50%) } to { transform: translateX(0%) } }

.pc-marquee-outer {
  overflow: hidden;
}
.pc-marquee-track {
  display: flex !important;
  flex-wrap: nowrap !important;
  grid-template-columns: none !important;
  width: max-content !important;
  gap: 16px !important;
  padding: 8px 0 !important;
  max-width: none !important;
  margin: 0 !important;
  animation: mp-scroll-ltr 35s linear infinite;
}
.pc-marquee-track .mp-logo-card {
  flex: 0 0 200px;
  width: 200px;
}
.pc-marquee-track:hover {
  animation-play-state: paused;
}

@media (max-width: 639px) {
  .pc-marquee-track .mp-logo-card { flex: 0 0 140px; width: 140px; }
}
