/* ===================================================== production fallbacks */
.media-fallback,
.visual-fallback,
.globe-fallback {
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.92);
  border-radius: 18px;
  padding: 14px 16px;
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
}
.media-fallback {
  min-width: 96px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: rgba(255, 255, 255, 0.62);
}
.visual-fallback {
  position: absolute;
  inset: 0;
  z-index: 0;
  border: 0;
  border-radius: 0;
  background:
    radial-gradient(
      circle at 20% 20%,
      rgba(125, 140, 255, 0.22),
      transparent 32%
    ),
    radial-gradient(
      circle at 76% 40%,
      rgba(255, 255, 255, 0.08),
      transparent 35%
    ),
    linear-gradient(135deg, #141413, #232322 60%, #0f0f10);
  color: transparent;
  pointer-events: none;
}
.globe-fallback {
  position: relative;
  z-index: 1;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  display: grid;
  place-items: center;
  text-align: center;
  background: radial-gradient(
    circle,
    rgba(154, 166, 255, 0.22),
    rgba(255, 255, 255, 0.04) 58%,
    transparent 72%
  );
}

/* ===================================================== static paper shader fallbacks */
.hero,
.about-hero {
  background-image: url("../images/paper/paper-hero-static.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.page-banner,
.accent {
  background-image: url("../images/paper/paper-banner-static.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.hero .visual-fallback,
.about-hero .visual-fallback {
  background-image: url("../images/paper/paper-hero-static.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.page-banner .visual-fallback,
.accent .visual-fallback {
  background-image: url("../images/paper/paper-banner-static.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Readability adjustment: brighter secondary copy in event/open-position lists.
   Scoped to the .event cards themselves so it applies wherever the list is
   used (home events, open positions, volunteering) without touching unrelated
   intro copy. */
.event .desc,
.event.event-soon .desc {
  color: #d7d7d2;
}

.event .partners,
.event .idx,
.status {
  color: #bdbdb7;
}

/* Events/positions intro line — only where such an intro is shown. */
#events .events-intro,
body.page-open-positions .events-intro {
  color: #d7d7d2;
}
