/*
 * Faded State Styles
 * Visual degradation when a page passes its active_until date
 */

/* ==========================================================================
   Hero Image Degradation - Applies to Everyone
   ========================================================================== */

.page-faded .hero-images {
  position: relative;
  filter: blur(3px) grayscale(100%);
  transition: filter var(--transition-slow);
}

.page-faded .hero-images::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--color-faded-overlay);
  pointer-events: none;
}

/* ==========================================================================
   Public Visitor View - Content Truncated with Teasers
   ========================================================================== */

/* Hide full content from non-creators */
.page-faded:not(.creator-view) .contribution-text {
  display: none;
}

/* Show teaser text for public visitors */
.page-faded:not(.creator-view) .contribution-teaser {
  display: block;
  font-style: italic;
  color: var(--color-faded-text);
  margin-bottom: var(--space-4);
}

/* Blur contribution photos for public visitors */
.page-faded:not(.creator-view) .contribution-photos img {
  filter: blur(8px);
  opacity: 0.6;
}

/* ==========================================================================
   Creator View - Full Content but Faded Visuals
   ========================================================================== */

/* Creator can see full content */
.page-faded.creator-view .contribution-text {
  display: block;
}

/* Hide teasers for creators */
.page-faded.creator-view .contribution-teaser {
  display: none;
}

/* Creator sees slightly faded photos (but not fully blurred) */
.page-faded.creator-view .contribution-photos img {
  opacity: 0.8;
  filter: grayscale(50%);
}

/* ==========================================================================
   Disabled Actions - Applies to Everyone
   ========================================================================== */

.page-faded .btn-add-memory,
.page-faded .btn-share,
.page-faded .share-buttons button,
.page-faded .share-buttons a {
  opacity: 0.5;
  pointer-events: none;
  cursor: not-allowed;
}

/* ==========================================================================
   Restore Banner - Sticky CTA at Top
   ========================================================================== */

.faded-banner {
  position: sticky;
  top: 0;
  background: var(--color-surface);
  padding: var(--space-4);
  text-align: center;
  border-bottom: 1px solid var(--color-border);
  z-index: 100;
  box-shadow: var(--shadow-md);
}

.faded-banner-title {
  font-family: var(--font-ui);
  font-size: var(--text-body);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--space-2);
}

.faded-banner-text {
  font-family: var(--font-ui);
  font-size: var(--text-body-sm);
  color: var(--color-muted);
  margin: 0 0 var(--space-3);
}

.faded-banner .btn {
  margin-top: var(--space-2);
}

/* Desktop layout for banner */
@media (min-width: 768px) {
  .faded-banner {
    padding: var(--space-6);
  }

  .faded-banner-title {
    font-size: var(--text-h3);
  }

  .faded-banner-text {
    font-size: var(--text-body);
  }
}

/* ==========================================================================
   Contribution Teaser Styling (hidden by default, shown when faded)
   ========================================================================== */

.contribution-teaser {
  display: none; /* Hidden by default, shown only in faded state */
}
