/* =============================================
   GALLERY PAGE STYLES
   ============================================= */

.fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in.visible { opacity: 1; transform: translateY(0); }

/* ---- VIRAL SECTION ---- */
.viral-section { padding: 5rem 0; }

.viral-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.tiktok-embed-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  justify-items: center;
}

.tiktok-embed-wrap {
  width: 100%;
  max-width: 380px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 20px 50px rgba(0,0,0,0.5);
}

.tiktok-embed-wrap .tiktok-embed {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

.viral-card {
  background: var(--dark-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.viral-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.4);
}

.viral-thumb {
  height: 240px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.thumb-1 { background: linear-gradient(135deg, #1a0500, #3d1000, #1a0500); }
.thumb-2 { background: linear-gradient(135deg, #0a001a, #1a0035, #0a001a); }
.thumb-3 { background: linear-gradient(135deg, #001a0a, #00350d, #001a0a); }

/* Decorative patterns */
.thumb-1::before { content: '🌯'; font-size: 5rem; opacity: 0.3; }
.thumb-2::before { content: '👨‍👩‍👧‍👦'; font-size: 5rem; opacity: 0.3; }
.thumb-3::before { content: '🍣'; font-size: 5rem; opacity: 0.3; }

.play-btn {
  position: absolute;
  width: 60px;
  height: 60px;
  background: rgba(192, 57, 43, 0.9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: white;
  backdrop-filter: blur(4px);
  border: 2px solid rgba(255,255,255,0.2);
  transition: transform 0.2s ease, background 0.2s ease;
  z-index: 2;
}

.viral-card:hover .play-btn {
  transform: scale(1.1);
  background: var(--red);
}

.viral-stats {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1rem;
  background: linear-gradient(to top, rgba(0,0,0,0.7), transparent);
  display: flex;
  gap: 1rem;
  z-index: 2;
}

.viral-stats span {
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
}

.viral-info {
  padding: 1.25rem 1.5rem 1.5rem;
}

.viral-caption {
  font-size: 0.9rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin-bottom: 0.75rem;
  font-style: italic;
}

.viral-link {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--orange);
  letter-spacing: 0.03em;
  transition: color 0.2s ease;
}

.viral-link:hover { color: var(--orange-light); }

/* ---- PHOTO GRID ---- */
.photo-section { padding: 5rem 0; }

.photo-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto;
  gap: 1rem;
  margin-bottom: 2rem;
}

.photo-item { border-radius: 10px; overflow: hidden; }
.photo-item.large { grid-column: span 2; }
.photo-item img { width: 100%; height: auto; display: block; border-radius: 10px; }

.photo-placeholder {
  height: 220px;
  background: var(--dark-3);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  transition: border-color 0.2s ease, background 0.2s ease;
  cursor: pointer;
  border-radius: 10px;
}

.photo-item.large .photo-placeholder { height: 280px; }

.photo-placeholder:hover {
  border-color: rgba(230,126,34,0.4);
  background: var(--dark-2);
}

.photo-placeholder span { font-size: 2.5rem; }
.photo-placeholder p { font-size: 0.8rem; color: var(--text-muted); font-weight: 500; }

.photo-note {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1.25rem 1.5rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.photo-note p { font-size: 0.875rem; color: var(--text-muted); }
.photo-note a { color: var(--orange); }

/* ---- FOLLOW SECTION ---- */
.follow-section { padding: 5rem 0; }
.follow-inner { max-width: 600px; margin: 0 auto; }

.social-follow-btns {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 440px;
  margin: 0 auto;
}

.follow-btn {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.25rem 1.5rem;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--dark-2);
  transition: border-color 0.2s ease, transform 0.2s ease;
}

.follow-btn:hover {
  transform: translateY(-2px);
  border-color: rgba(230,126,34,0.4);
}

.follow-icon { font-size: 1.75rem; flex-shrink: 0; }

.follow-btn div {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.follow-btn strong {
  font-size: 1rem;
  color: var(--white);
}

.follow-btn span {
  font-size: 0.8rem;
  color: var(--text-muted);
}

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  .viral-grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .tiktok-embed-grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .photo-grid { grid-template-columns: repeat(2, 1fr); }
  .photo-item.large { grid-column: span 2; }
}

@media (max-width: 640px) {
  .photo-grid { grid-template-columns: 1fr; }
  .photo-item.large { grid-column: span 1; }
}
