/* ===========================
   MEMORIES PAGE — Fixed & Improved
=========================== */
.memories-page { cursor: none; }

/* HERO */
.mem-hero {
  min-height: 45vh; display: flex; align-items: center; justify-content: center;
  padding: 120px 32px 64px; position: relative; overflow: hidden;
  background: linear-gradient(160deg, var(--ivory) 0%, var(--blush) 100%);
  text-align: center;
}
.mem-hero-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(201,116,138,0.12) 0%, transparent 70%);
}
.mem-hero-content { position: relative; z-index: 1; }
.mem-hero-title { font-family: var(--font-display); font-size: clamp(2.5rem, 7vw, 5rem); color: var(--text-dark); margin: 12px 0; line-height: 1.1; opacity: 0; }
.mem-hero-title .accent { color: var(--rose-deep); font-style: italic; }

/* STATS */
.mem-stats {
  background: linear-gradient(135deg, var(--rose-deep), var(--mauve));
  color: white; padding: 24px 48px;
  display: flex; align-items: center; justify-content: center; gap: 32px; flex-wrap: wrap;
}
.stat-item { text-align: center; }
.stat-num { display: block; font-family: var(--font-display); font-size: 2.4rem; font-weight: 700; line-height: 1; }
.stat-label { font-family: var(--font-body); font-size: 0.75rem; opacity: 0.8; letter-spacing: 0.12em; text-transform: uppercase; }
.stat-sep { font-size: 1.2rem; opacity: 0.35; }

/* FILTERS — FIXED (no sticky, proper layering) */
.mem-filters-bar {
  background: white;
  padding: 24px 32px;
  box-shadow: 0 2px 20px rgba(139,58,82,0.08);
  border-bottom: 1px solid var(--blush);
  position: relative;          /* NOT sticky — fixes click issues */
  z-index: 10;
}
.filter-row {
  display: flex; flex-wrap: wrap; gap: 20px 32px;
  align-items: flex-start; margin-bottom: 12px;
}
.filter-group { display: flex; flex-direction: column; gap: 8px; }
.filter-group-type { margin-left: auto; }
.filter-label {
  font-family: var(--font-body); font-size: 0.78rem;
  color: var(--text-soft); letter-spacing: 0.1em; text-transform: uppercase;
}
.filter-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.no-filter-msg { font-family: var(--font-body); font-size: 0.82rem; color: var(--text-soft); font-style: italic; }
.filter-actions { display: flex; align-items: center; gap: 12px; padding-top: 4px; }
.filter-result-text { font-family: var(--font-body); font-size: 0.85rem; color: var(--text-soft); }

/* CHIP STYLES */
.chip {
  padding: 6px 16px; border-radius: 50px;
  border: 1.5px solid var(--blush-dark);
  background: var(--ivory); color: var(--text-mid);
  cursor: pointer; font-family: var(--font-body); font-size: 0.82rem;
  transition: var(--transition); user-select: none;
  /* Make sure clicks register */
  position: relative; z-index: 1;
}
.chip:hover { background: var(--blush); border-color: var(--rose); color: var(--rose-deep); }
.chip.active { background: var(--rose); border-color: var(--rose); color: white; }
.chip-clear { background: transparent; border-color: var(--rose-deep); color: var(--rose-deep); }
.chip-clear:hover { background: var(--blush); }

/* GRID */
.mem-grid {
  display: grid; gap: 24px; padding: 48px 0;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.mem-card {
  background: white; border-radius: var(--radius-md); overflow: hidden;
  box-shadow: var(--shadow-soft); transition: var(--transition);
  cursor: pointer; opacity: 0; transform: translateY(20px);
  animation: cardReveal 0.5s ease forwards;
}
@keyframes cardReveal { to { opacity: 1; transform: none; } }
.mem-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-bloom); }
.mem-card-media { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--blush); }
.mem-card-media img, .mem-card-media video { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.mem-card:hover .mem-card-media img,
.mem-card:hover .mem-card-media video { transform: scale(1.06); }
.mem-card-badge {
  position: absolute; top: 10px; right: 10px;
  background: rgba(255,255,255,0.92); border-radius: 50px;
  padding: 3px 10px; font-size: 0.72rem; font-family: var(--font-body);
  color: var(--rose-deep); backdrop-filter: blur(4px);
}
.mem-card-body { padding: 18px 20px; }
.mem-card-date { font-family: var(--font-accent); font-size: 0.95rem; color: var(--rose); margin-bottom: 5px; }
.mem-card-title { font-family: var(--font-display); font-size: 1.1rem; color: var(--text-dark); font-style: italic; margin-bottom: 7px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mem-card-caption { font-family: var(--font-body); font-size: 0.88rem; color: var(--text-soft); line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mem-card-location { display: inline-flex; align-items: center; gap: 4px; font-family: var(--font-body); font-size: 0.78rem; color: var(--mauve); background: var(--mauve-light); padding: 3px 10px; border-radius: 50px; margin-top: 10px; }

/* EMPTY + LOADING */
.mem-empty { text-align: center; padding: 80px 32px; }
.empty-icon { font-size: 4rem; display: block; margin-bottom: 16px; }
.mem-empty h3 { font-family: var(--font-display); font-size: 1.6rem; color: var(--text-mid); margin-bottom: 8px; font-style: italic; }
.mem-empty p { font-family: var(--font-body); color: var(--text-soft); }
.mem-loading { text-align: center; padding: 60px; display: none; }
.loading-spinner { width: 40px; height: 40px; border: 3px solid var(--blush); border-top-color: var(--rose); border-radius: 50%; animation: spin 0.8s linear infinite; margin: 0 auto 16px; }
@keyframes spin { to { transform: rotate(360deg); } }
.mem-loading p { font-family: var(--font-accent); color: var(--rose); font-size: 1.1rem; }

/* YEAR TIMELINE */
.mem-section-divider {
  display: flex; align-items: center; gap: 20px;
  text-align: center; padding: 48px 0 32px;
}
.mem-section-divider span { color: var(--rose-gold); font-size: 1.2rem; }
.mem-section-divider h2 { font-family: var(--font-display); font-size: 2rem; color: var(--text-dark); font-style: italic; white-space: nowrap; }
.year-timeline { padding-bottom: 60px; }
.year-block { margin-bottom: 48px; }
.year-heading { font-family: var(--font-display); font-size: 1.8rem; color: var(--rose-deep); font-style: italic; padding: 12px 0; border-bottom: 1px solid var(--blush-dark); margin-bottom: 20px; }
.month-block { margin-bottom: 20px; }
.month-heading { font-family: var(--font-accent); font-size: 1.1rem; color: var(--mauve); margin-bottom: 12px; }
.month-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px; }
.mini-card { border-radius: var(--radius-sm); overflow: hidden; cursor: pointer; transition: var(--transition); aspect-ratio: 1; background: var(--blush); }
.mini-card:hover { transform: scale(1.05); box-shadow: var(--shadow-soft); }
.mini-card img, .mini-card video { width: 100%; height: 100%; object-fit: cover; }

/* CTA */
.add-more-cta { display: flex; gap: 16px; justify-content: center; padding: 40px 32px; flex-wrap: wrap; }

/* ===========================
   CAROUSEL / LIGHTBOX — SMOOTH ANIMATED
=========================== */
.carousel-overlay {
  display: none; position: fixed; inset: 0; z-index: 2000;
  background: rgba(20, 8, 14, 0.96);
  backdrop-filter: blur(12px);
  flex-direction: column; align-items: center; justify-content: center;
}
.carousel-overlay.active { display: flex; animation: overlayIn 0.35s ease; }
@keyframes overlayIn { from{opacity:0} to{opacity:1} }

.carousel-close {
  position: absolute; top: 20px; right: 24px;
  background: rgba(255,255,255,0.12); border: none; color: white;
  width: 46px; height: 46px; border-radius: 50%; font-size: 1.4rem;
  cursor: pointer; transition: var(--transition); z-index: 10;
  display: flex; align-items: center; justify-content: center;
}
.carousel-close:hover { background: rgba(255,255,255,0.25); transform: rotate(90deg); }

/* Stage */
.carousel-stage {
  position: relative; flex: 1; width: 100%; max-width: 1000px;
  display: flex; align-items: center; justify-content: center;
  padding: 20px 60px; overflow: hidden;
}

/* Media transition — key animation */
.carousel-media {
  max-width: 100%; max-height: 60vh; object-fit: contain;
  border-radius: var(--radius-md);
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
  animation: carouselFadeIn 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes carouselFadeIn {
  from { opacity: 0; transform: scale(0.94) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.carousel-media.slide-left {
  animation: carouselSlideLeft 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes carouselSlideLeft {
  from { opacity: 0; transform: scale(0.95) translateX(60px); }
  to   { opacity: 1; transform: scale(1) translateX(0); }
}
.carousel-media.slide-right {
  animation: carouselSlideRight 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes carouselSlideRight {
  from { opacity: 0; transform: scale(0.95) translateX(-60px); }
  to   { opacity: 1; transform: scale(1) translateX(0); }
}

/* Nav arrows */
.carousel-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(255,255,255,0.15);
  border: 1.5px solid rgba(255,255,255,0.3);
  color: white; font-size: 1.8rem; cursor: pointer;
  transition: var(--transition); display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(4px);
}
.carousel-nav:hover { background: rgba(201,116,138,0.5); border-color: var(--rose); transform: translateY(-50%) scale(1.08); }
.carousel-prev { left: 8px; }
.carousel-next { right: 8px; }

/* Info panel */
.carousel-info {
  width: 100%; max-width: 1000px;
  padding: 0 20px 16px; color: white;
}
.carousel-meta { display: flex; align-items: flex-start; gap: 20px; margin-bottom: 14px; }
.carousel-counter { font-family: var(--font-body); font-size: 0.82rem; color: rgba(255,255,255,0.5); letter-spacing: 0.08em; white-space: nowrap; min-width: 56px; margin-top: 4px; }
.carousel-details { flex: 1; }
.carousel-title { font-family: var(--font-display); font-size: 1.2rem; font-style: italic; color: white; margin-bottom: 4px; }
.carousel-caption-text { font-family: var(--font-body); font-size: 0.9rem; color: rgba(255,255,255,0.7); line-height: 1.55; }
.carousel-tags { display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.carousel-tag { font-family: var(--font-body); font-size: 0.78rem; color: rgba(255,255,255,0.8); background: rgba(255,255,255,0.12); padding: 3px 12px; border-radius: 50px; }

/* Thumbnail strip */
.carousel-thumbs {
  display: flex; gap: 8px; overflow-x: auto; padding: 0 4px 4px;
  scrollbar-width: thin; scrollbar-color: var(--rose) transparent;
}
.carousel-thumbs::-webkit-scrollbar { height: 3px; }
.carousel-thumbs::-webkit-scrollbar-thumb { background: var(--rose); border-radius: 2px; }
.carousel-thumb {
  flex-shrink: 0; width: 56px; height: 56px;
  border-radius: 8px; overflow: hidden; cursor: pointer;
  border: 2px solid transparent; transition: var(--transition); opacity: 0.6;
}
.carousel-thumb:hover { opacity: 0.9; }
.carousel-thumb.active { border-color: var(--rose); opacity: 1; transform: scale(1.05); }
.carousel-thumb img, .carousel-thumb video { width: 100%; height: 100%; object-fit: cover; }

/* Responsive */
@media (max-width: 768px) {
  .mem-stats { padding: 16px 24px; gap: 20px; }
  .mem-filters-bar { padding: 16px 20px; }
  .filter-row { flex-direction: column; gap: 16px; }
  .filter-group-type { margin-left: 0; }
  .mem-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); padding: 32px 0; gap: 16px; }
  .carousel-stage { padding: 16px 52px; }
  .carousel-media { max-height: 50vh; }
  .carousel-nav { width: 40px; height: 40px; font-size: 1.4rem; }
  .carousel-info { padding: 0 12px 12px; }
  .add-more-cta { flex-direction: column; align-items: center; }
}
