/* ============================================================
   public-pta-fundraising.css
   Audience-specific landing page for PTA fundraising.
   Layers on top of public-home, public-article, and
   public-format-guide. Body class: fr-public-pta-fundraising.
   This is the first of a series of audience-specific pages;
   new patterns introduced here (hero actions, format picker)
   are intended for reuse on subsequent pages.
   ============================================================ */

/* ------------------------------------------------------------
   Hero actions — primary CTA button + secondary soft link,
   stacked vertically.
   ------------------------------------------------------------ */

.fr-pta-hero-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--fr-space-3);
  margin-top: var(--fr-space-6);
}

.fr-pta-hero-actions__soft-link {
  font-size: var(--fr-text-sm);
  font-weight: var(--fr-weight-medium);
  color: var(--fr-color-link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.fr-pta-hero-actions__soft-link:hover {
  color: var(--fr-color-link-hover);
  text-decoration-thickness: 2px;
}

/* ------------------------------------------------------------
   Format picker — 2×2 image card grid
   ------------------------------------------------------------ */

.fr-format-picker {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--fr-space-5);
  margin-top: var(--fr-space-6);
  text-decoration: none;
}

@media (max-width: 640px) {
  .fr-format-picker {
    grid-template-columns: 1fr;
  }
}

@keyframes fr-card-vibrate {
  0%   { transform: translateX(0); }
  20%  { transform: translateX(-3px); }
  40%  { transform: translateX(3px); }
  60%  { transform: translateX(-2px); }
  80%  { transform: translateX(1px); }
  100% { transform: translateX(0); }
}

.fr-format-card {
  background: var(--fr-color-surface);
  border: 1.5px solid var(--fr-color-border);
  border-radius: var(--fr-radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.fr-format-card:hover {
  box-shadow: var(--fr-shadow-sm);
  border-color: var(--fr-color-border-strong);
  text-decoration: none;
  animation: fr-card-vibrate 0.3s ease;
}


.fr-format-card:focus-visible {
  outline: 2px solid var(--fr-color-primary);
  outline-offset: 2px;
}

.fr-format-card__img-wrap {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.fr-format-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fr-format-card__body {
  padding: var(--fr-space-5);
  display: flex;
  flex-direction: column;
  gap: var(--fr-space-2);
  flex: 1;
}

.fr-format-card__heading {
  font-size: var(--fr-text-lg);
  font-weight: var(--fr-weight-bold);
  color: var(--fr-color-heading);
  margin: 0;
  line-height: var(--fr-leading-tight);
}

.fr-format-card__desc {
  font-size: var(--fr-text-sm);
  color: var(--fr-color-ink-muted);
  margin: 0;
  flex: 1;
  line-height: var(--fr-leading-relaxed);
}

.fr-format-card__link {
  font-size: var(--fr-text-sm);
  font-weight: var(--fr-weight-medium);
  color: var(--fr-color-primary);
  margin-top: var(--fr-space-3);
  display: block;
}

/* ------------------------------------------------------------
   Parent journey numbered list + spacing after last item
   ------------------------------------------------------------ */

.fr-parent-journey {
  list-style: none;
  margin: var(--fr-space-5) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--fr-space-4);
  counter-reset: journey;
}

.fr-parent-journey li {
  counter-increment: journey;
  font-size: var(--fr-text-md);
  color: var(--fr-color-ink);
  line-height: var(--fr-leading-relaxed);
  padding-left: calc(var(--fr-space-7) + var(--fr-space-1));
  position: relative;
}

.fr-parent-journey li::before {
  content: counter(journey);
  position: absolute;
  left: 0;
  top: -0.1em;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: var(--fr-color-primary);
  color: #fff;
  font-size: var(--fr-text-xs);
  font-weight: var(--fr-weight-bold);
  display: flex;
  align-items: center;
  justify-content: center;
}

body.fr-public-pta-fundraising .fr-article-body .fr-parent-journey-close {
  margin-top: var(--fr-space-7);
}

.fr-calc-link {
  margin-top: var(--fr-space-7);
}
