/* ============================================
   问鼎娱乐 - 主样式表 wz-style.css
   CSS前缀: wz-
   设计风格: 糖果色综艺潮流风 (Candy Pop Trend)
   ============================================ */

/* --- Google Fonts Import (本地化备选) --- */
@import url('https://fonts.googleapis.com/css2?family=Fredoka+One&family=Noto+Sans+SC:wght@300;400;500;700;900&display=swap');

/* --- CSS Variables --- */
:root {
  --wz-primary: #FF6B6B;
  --wz-secondary: #4ECDC4;
  --wz-accent: #FFD166;
  --wz-purple: #A06AB4;
  --wz-bg: #F7F7F7;
  --wz-text: #333333;
  --wz-text-light: #888888;
  --wz-white: #FFFFFF;
  --wz-gold: #FFD700;
  --wz-silver: #C0C0C0;
  --wz-bronze: #CD7F32;
  --wz-radius: 16px;
  --wz-shadow: 0 4px 12px rgba(255,107,107,0.2);
  --wz-shadow-hover: 0 8px 24px rgba(255,107,107,0.35);
  --wz-font-title: 'Fredoka One', 'Noto Sans SC', cursive;
  --wz-font-body: 'Noto Sans SC', sans-serif;
  --wz-transition: all 0.3s ease;
  --wz-container: 1200px;
}

/* --- Reset & Base --- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--wz-font-body);
  color: var(--wz-text);
  background-color: var(--wz-bg);
  line-height: 1.7;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; transition: var(--wz-transition); }
a:hover { color: var(--wz-primary); }

img { max-width: 100%; height: auto; display: block; }

ul, ol { list-style: none; }

h1, h2, h3, h4, h5, h6 { font-family: var(--wz-font-title); line-height: 1.3; }

/* --- Container --- */
.wz-container {
  max-width: var(--wz-container);
  margin: 0 auto;
  padding: 0 20px;
}

/* --- Section Spacing --- */
.wz-section {
  padding: 60px 0;
}

.wz-section-title {
  font-family: var(--wz-font-title);
  font-size: 2rem;
  text-align: center;
  margin-bottom: 40px;
  position: relative;
}

.wz-section-title::after {
  content: '';
  display: block;
  width: 60px;
  height: 4px;
  background: linear-gradient(90deg, var(--wz-primary), var(--wz-accent));
  margin: 12px auto 0;
  border-radius: 2px;
}

/* --- Navigation --- */
.wz-navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: var(--wz-white);
  border-bottom: 1px solid var(--wz-primary);
  z-index: 1000;
  height: 70px;
}

.wz-navbar-inner {
  max-width: var(--wz-container);
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

.wz-logo {
  font-family: var(--wz-font-title);
  font-size: 1.6rem;
  color: var(--wz-text);
  letter-spacing: 2px;
}

.wz-logo span { color: var(--wz-primary); }

.wz-nav-links {
  display: flex;
  align-items: center;
  gap: 24px;
}

.wz-nav-links a {
  font-size: 0.95rem;
  color: var(--wz-text-light);
  font-weight: 500;
  position: relative;
  padding-bottom: 4px;
}

.wz-nav-links a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: var(--wz-accent);
  transition: width 0.3s ease;
  border-radius: 2px;
}

.wz-nav-links a:hover { color: var(--wz-primary); }
.wz-nav-links a:hover::after { width: 100%; }
.wz-nav-links a.wz-active { color: var(--wz-primary); }
.wz-nav-links a.wz-active::after { width: 100%; }

.wz-btn-cta {
  display: inline-block;
  padding: 10px 22px;
  background: linear-gradient(135deg, var(--wz-primary), var(--wz-accent));
  color: var(--wz-white);
  border-radius: 50px;
  font-weight: 700;
  font-size: 0.9rem;
  border: none;
  cursor: pointer;
  transition: var(--wz-transition);
}

.wz-btn-cta:hover {
  transform: scale(1.08);
  box-shadow: var(--wz-shadow-hover);
  color: var(--wz-white);
}

/* Hamburger */
.wz-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 5px;
}

.wz-hamburger span {
  display: block;
  width: 26px;
  height: 3px;
  background: var(--wz-text);
  border-radius: 2px;
  transition: var(--wz-transition);
}

/* --- Hero Banner --- */
.wz-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  margin-top: 70px;
}

.wz-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
}

.wz-hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,107,107,0.7) 0%, rgba(78,205,196,0.5) 50%, rgba(255,209,102,0.4) 100%);
}

.wz-hero-content {
  position: relative;
  z-index: 2;
  max-width: 800px;
  padding: 40px 20px;
}

.wz-hero-tag {
  display: inline-block;
  padding: 6px 20px;
  border: 2px solid var(--wz-white);
  border-radius: 50px;
  color: var(--wz-white);
  font-size: 0.9rem;
  font-weight: 700;
  margin-bottom: 20px;
  backdrop-filter: blur(4px);
  background: rgba(255,255,255,0.15);
}

.wz-hero h1 {
  font-size: 3.5rem;
  color: var(--wz-white);
  margin-bottom: 16px;
  text-shadow: 2px 2px 8px rgba(0,0,0,0.3);
}

.wz-hero h1 .wz-highlight {
  color: var(--wz-accent);
  text-shadow: -1px -1px 0 var(--wz-white), 1px -1px 0 var(--wz-white), -1px 1px 0 var(--wz-white), 1px 1px 0 var(--wz-white);
}

.wz-hero-subtitle {
  color: rgba(255,255,255,0.9);
  font-size: 1.05rem;
  max-width: 640px;
  margin: 0 auto 30px;
  line-height: 1.8;
}

.wz-hero-btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 30px;
}

.wz-btn-primary {
  display: inline-block;
  padding: 14px 32px;
  background: var(--wz-primary);
  color: var(--wz-white);
  border-radius: 50px;
  font-weight: 700;
  font-size: 1rem;
  border: none;
  cursor: pointer;
  transition: var(--wz-transition);
  box-shadow: var(--wz-shadow);
}

.wz-btn-primary:hover { transform: translateY(-2px); box-shadow: var(--wz-shadow-hover); color: var(--wz-white); }

.wz-btn-outline {
  display: inline-block;
  padding: 14px 32px;
  background: transparent;
  color: var(--wz-white);
  border: 2px solid var(--wz-secondary);
  border-radius: 50px;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: var(--wz-transition);
}

.wz-btn-outline:hover { background: var(--wz-secondary); color: var(--wz-white); transform: translateY(-2px); }

.wz-hero-tags {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

.wz-hero-tags span {
  padding: 4px 14px;
  border-radius: 50px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--wz-white);
}

.wz-tag-pink { background: var(--wz-primary); }
.wz-tag-green { background: var(--wz-secondary); }
.wz-tag-yellow { background: var(--wz-accent); color: var(--wz-text); }
.wz-tag-purple { background: var(--wz-purple); }

/* --- Cards --- */
.wz-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.wz-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.wz-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

.wz-card {
  background: var(--wz-white);
  border-radius: var(--wz-radius);
  overflow: hidden;
  box-shadow: var(--wz-shadow);
  transition: var(--wz-transition);
}

.wz-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--wz-shadow-hover);
}

.wz-card-img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.wz-card-body {
  padding: 20px;
}

.wz-card-title {
  font-family: var(--wz-font-title);
  font-size: 1.15rem;
  margin-bottom: 8px;
  transition: var(--wz-transition);
}

.wz-card:hover .wz-card-title { color: var(--wz-primary); }

.wz-card-text {
  color: var(--wz-text-light);
  font-size: 0.9rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wz-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-size: 0.8rem;
  color: var(--wz-text-light);
}

.wz-card-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 50px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--wz-white);
  background: var(--wz-secondary);
}

.wz-card-rating {
  color: var(--wz-accent);
  font-size: 0.9rem;
}

/* --- Show Cards (Module 2) --- */
.wz-show-card .wz-card-img { height: 280px; }
.wz-show-card .wz-card-badge { margin-bottom: 8px; }

/* --- Video Module (Module 3) --- */
.wz-video-card {
  background: var(--wz-white);
  border-radius: var(--wz-radius);
  overflow: hidden;
  box-shadow: var(--wz-shadow);
  border: 3px dashed var(--wz-secondary);
  transition: var(--wz-transition);
}

.wz-video-card:hover { transform: translateY(-4px); box-shadow: var(--wz-shadow-hover); }

.wz-video-card video {
  width: 100%;
  height: 200px;
  object-fit: cover;
  background: #000;
}

.wz-video-card .wz-card-body { padding: 16px; }

.wz-video-duration {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(0,0,0,0.7);
  color: var(--wz-white);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.75rem;
}

.wz-video-wrapper { position: relative; }

/* --- Ranking Module (Module 4) --- */
.wz-ranking {
  display: flex;
  gap: 40px;
  align-items: flex-start;
}

.wz-ranking-podium {
  flex: 0 0 360px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 16px;
  padding-top: 40px;
}

.wz-podium-item {
  text-align: center;
}

.wz-podium-avatar {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--wz-accent);
  margin: 0 auto 8px;
}

.wz-podium-name { font-size: 0.85rem; font-weight: 700; margin-bottom: 4px; }

.wz-podium-bar {
  width: 90px;
  border-radius: 8px 8px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--wz-font-title);
  font-size: 1.5rem;
  color: var(--wz-white);
}

.wz-podium-1 .wz-podium-bar { height: 140px; background: linear-gradient(180deg, var(--wz-gold), #FFA500); }
.wz-podium-2 .wz-podium-bar { height: 110px; background: linear-gradient(180deg, var(--wz-silver), #999); }
.wz-podium-3 .wz-podium-bar { height: 85px; background: linear-gradient(180deg, var(--wz-bronze), #8B4513); }

.wz-ranking-table {
  flex: 1;
}

.wz-ranking-table table {
  width: 100%;
  border-collapse: collapse;
}

.wz-ranking-table th,
.wz-ranking-table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid #eee;
}

.wz-ranking-table th {
  background: var(--wz-bg);
  font-weight: 700;
  font-size: 0.85rem;
  color: var(--wz-text-light);
}

.wz-ranking-table tr:hover { background: #FFF5F5; }

.wz-trend-up { color: var(--wz-primary); font-weight: 700; }

/* --- CP Cards (Module 5) --- */
.wz-cp-card {
  position: relative;
  border-radius: var(--wz-radius);
  overflow: hidden;
  box-shadow: var(--wz-shadow);
  transition: var(--wz-transition);
}

.wz-cp-card:hover { transform: translateY(-6px); box-shadow: var(--wz-shadow-hover); }

.wz-cp-card img { width: 100%; height: 240px; object-fit: cover; }

.wz-cp-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 20px;
  background: linear-gradient(transparent, rgba(0,0,0,0.75));
  color: var(--wz-white);
}

.wz-cp-name { font-family: var(--wz-font-title); font-size: 1.1rem; margin-bottom: 4px; }
.wz-cp-hearts { color: var(--wz-primary); margin-bottom: 4px; }
.wz-cp-work { font-size: 0.8rem; opacity: 0.85; }
.wz-cp-desc { font-size: 0.8rem; opacity: 0.9; margin-top: 4px; }

/* --- Fan Chat (Module 6) --- */
.wz-fan-chat {
  display: flex;
  gap: 40px;
  background: var(--wz-white);
  border-radius: var(--wz-radius);
  padding: 40px;
  box-shadow: var(--wz-shadow);
}

.wz-fan-chat-left { flex: 0 0 40%; }
.wz-fan-chat-right { flex: 1; max-height: 320px; overflow-y: auto; }

.wz-chat-topic {
  font-family: var(--wz-font-title);
  font-size: 1.3rem;
  color: var(--wz-primary);
  margin-bottom: 12px;
}

.wz-chat-desc { color: var(--wz-text-light); margin-bottom: 20px; line-height: 1.8; }

.wz-comment-item {
  display: flex;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid #f0f0f0;
}

.wz-comment-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.wz-comment-content { flex: 1; }
.wz-comment-user { font-weight: 700; font-size: 0.85rem; margin-bottom: 4px; }
.wz-comment-text { font-size: 0.9rem; color: var(--wz-text); }
.wz-comment-likes { font-size: 0.8rem; color: var(--wz-text-light); margin-top: 4px; }

/* --- Vote Module (Module 7) --- */
.wz-vote-section {
  background: linear-gradient(135deg, #FFF5F5, #F0FFFE, #FFFDF0);
  border-radius: var(--wz-radius);
  padding: 40px;
  box-shadow: var(--wz-shadow);
}

.wz-vote-card {
  background: var(--wz-white);
  border-radius: var(--wz-radius);
  padding: 24px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  transition: var(--wz-transition);
}

.wz-vote-card:hover { transform: translateY(-4px); box-shadow: var(--wz-shadow); }

.wz-vote-avatar {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto 12px;
  border: 3px solid var(--wz-accent);
}

.wz-vote-name { font-family: var(--wz-font-title); font-size: 1.1rem; margin-bottom: 4px; }
.wz-vote-count { color: var(--wz-text-light); font-size: 0.85rem; margin-bottom: 12px; }

.wz-btn-vote {
  display: inline-block;
  padding: 10px 24px;
  background: var(--wz-primary);
  color: var(--wz-white);
  border-radius: 50px;
  font-weight: 700;
  font-size: 0.9rem;
  border: none;
  cursor: pointer;
  transition: var(--wz-transition);
}

.wz-btn-vote:hover { background: #E55A5A; transform: scale(1.05); }
.wz-btn-vote.wz-voted { background: var(--wz-text-light); cursor: default; }

.wz-vote-rules {
  margin-top: 20px;
  text-align: center;
  color: var(--wz-text-light);
  font-size: 0.85rem;
}

/* --- Deep Review (Module 8) --- */
.wz-review-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.wz-review-main .wz-card-img { height: 340px; }
.wz-review-side { display: flex; flex-direction: column; gap: 24px; }
.wz-review-side .wz-card { display: flex; }
.wz-review-side .wz-card-img { width: 180px; height: auto; min-height: 140px; flex-shrink: 0; }
.wz-review-side .wz-card-body { display: flex; flex-direction: column; justify-content: center; }

.wz-author-info {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}

.wz-author-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
}

.wz-author-name { font-size: 0.8rem; font-weight: 500; }
.wz-article-date { font-size: 0.8rem; color: var(--wz-text-light); }

/* --- Street Photo (Module 9) --- */
.wz-masonry {
  columns: 4;
  column-gap: 16px;
}

.wz-masonry-item {
  break-inside: avoid;
  margin-bottom: 16px;
  position: relative;
  border-radius: var(--wz-radius);
  overflow: hidden;
  cursor: pointer;
}

.wz-masonry-item img { width: 100%; display: block; }

.wz-masonry-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--wz-white);
  opacity: 0;
  transition: var(--wz-transition);
}

.wz-masonry-item:hover .wz-masonry-overlay { opacity: 1; }

.wz-masonry-name { font-family: var(--wz-font-title); font-size: 1.1rem; }
.wz-masonry-date { font-size: 0.8rem; opacity: 0.8; margin-top: 4px; }

/* --- Timeline (Module 10) --- */
.wz-timeline {
  display: flex;
  gap: 0;
  overflow-x: auto;
  padding: 20px 0 40px;
  position: relative;
}

.wz-timeline::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--wz-primary), var(--wz-secondary), var(--wz-accent));
  transform: translateY(-50%);
}

.wz-timeline-item {
  flex: 0 0 180px;
  text-align: center;
  position: relative;
  padding-top: 60px;
}

.wz-timeline-dot {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  background: var(--wz-primary);
  border: 3px solid var(--wz-white);
  border-radius: 50%;
  box-shadow: 0 0 0 3px var(--wz-primary);
  z-index: 2;
}

.wz-timeline-day {
  font-family: var(--wz-font-title);
  font-size: 0.9rem;
  color: var(--wz-primary);
  margin-bottom: 8px;
}

.wz-timeline-event {
  background: var(--wz-white);
  border-radius: 12px;
  padding: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  font-size: 0.8rem;
  margin-top: 20px;
}

.wz-timeline-icon { font-size: 1.2rem; margin-bottom: 4px; }

/* --- Partners & Honors (Module 11) --- */
.wz-partners {
  display: flex;
  gap: 40px;
}

.wz-partners-left, .wz-partners-right { flex: 1; }

.wz-partner-logos {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  align-items: center;
}

.wz-partner-logo {
  padding: 12px 20px;
  background: var(--wz-white);
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  font-weight: 700;
  color: var(--wz-text-light);
  font-size: 0.9rem;
}

.wz-honor-badges {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.wz-honor-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  background: var(--wz-white);
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  flex: 1;
}

.wz-honor-icon {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, var(--wz-accent), var(--wz-primary));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}

.wz-honor-text { font-size: 0.85rem; font-weight: 500; }

/* --- APP Download (Module 12) --- */
.wz-app-download {
  display: flex;
  align-items: center;
  gap: 60px;
  background: linear-gradient(135deg, var(--wz-primary), var(--wz-purple));
  border-radius: var(--wz-radius);
  padding: 60px;
  color: var(--wz-white);
}

.wz-app-img { flex: 0 0 280px; }
.wz-app-img img { border-radius: 20px; box-shadow: 0 8px 30px rgba(0,0,0,0.3); }
.wz-app-info { flex: 1; }
.wz-app-info h2 { font-size: 2rem; margin-bottom: 8px; }
.wz-app-info p { opacity: 0.9; margin-bottom: 20px; }

.wz-app-features {
  display: flex;
  gap: 20px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.wz-app-feature {
  padding: 8px 16px;
  background: rgba(255,255,255,0.2);
  border-radius: 50px;
  font-size: 0.85rem;
  backdrop-filter: blur(4px);
}

.wz-app-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.wz-app-btn {
  padding: 12px 24px;
  background: var(--wz-white);
  color: var(--wz-text);
  border-radius: 12px;
  font-weight: 700;
  font-size: 0.9rem;
  transition: var(--wz-transition);
}

.wz-app-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.2); color: var(--wz-text); }

/* --- Footer --- */
.wz-footer {
  background: var(--wz-bg);
  padding-top: 0;
  position: relative;
}

.wz-footer-wave {
  width: 100%;
  height: 60px;
  display: block;
}

.wz-footer-inner {
  max-width: var(--wz-container);
  margin: 0 auto;
  padding: 40px 20px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}

.wz-footer-col h4 {
  font-family: var(--wz-font-title);
  font-size: 1rem;
  margin-bottom: 16px;
  color: var(--wz-text);
}

.wz-footer-col p,
.wz-footer-col a {
  font-size: 0.85rem;
  color: var(--wz-text-light);
  line-height: 2;
}

.wz-footer-col a:hover { color: var(--wz-primary); }

.wz-footer-social {
  display: flex;
  gap: 12px;
  margin-top: 12px;
}

.wz-footer-social a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--wz-primary);
  color: var(--wz-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 700;
  transition: var(--wz-transition);
}

.wz-footer-social a:hover { background: var(--wz-secondary); transform: scale(1.1); color: var(--wz-white); }

.wz-footer-seo {
  max-width: var(--wz-container);
  margin: 0 auto;
  padding: 16px 20px;
  font-size: 12px;
  color: var(--wz-text-light);
  text-align: center;
  line-height: 1.8;
}

.wz-footer-bottom {
  text-align: center;
  padding: 20px;
  border-top: 1px solid #e0e0e0;
  font-size: 0.8rem;
  color: var(--wz-text-light);
  line-height: 1.8;
}

/* --- Breadcrumb --- */
.wz-breadcrumb {
  padding: 16px 0;
  font-size: 0.85rem;
  color: var(--wz-text-light);
}

.wz-breadcrumb a { color: var(--wz-primary); }
.wz-breadcrumb span { margin: 0 8px; }

/* --- Page Banner --- */
.wz-page-banner {
  position: relative;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-top: 70px;
  overflow: hidden;
}

.wz-page-banner-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

.wz-page-banner-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,107,107,0.75), rgba(78,205,196,0.6));
}

.wz-page-banner-content {
  position: relative;
  z-index: 2;
  color: var(--wz-white);
}

.wz-page-banner h1 {
  font-size: 2.5rem;
  margin-bottom: 12px;
  text-shadow: 2px 2px 6px rgba(0,0,0,0.3);
}

.wz-page-banner p {
  font-size: 1.05rem;
  opacity: 0.9;
  max-width: 600px;
  margin: 0 auto;
}

/* --- Content Page --- */
.wz-content-page {
  max-width: 900px;
  margin: 0 auto;
  padding: 40px 20px;
}

.wz-content-page h2 {
  font-size: 1.6rem;
  margin: 32px 0 16px;
  color: var(--wz-text);
  padding-left: 12px;
  border-left: 4px solid var(--wz-primary);
}

.wz-content-page h3 {
  font-size: 1.3rem;
  margin: 24px 0 12px;
  color: var(--wz-text);
}

.wz-content-page p {
  margin-bottom: 16px;
  line-height: 1.9;
}

.wz-content-page img {
  border-radius: var(--wz-radius);
  margin: 20px 0;
  box-shadow: var(--wz-shadow);
}

/* --- Animations --- */
.wz-fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.wz-fade-in.wz-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes wz-pulse-heart {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}

.wz-pulse-heart { animation: wz-pulse-heart 1.5s infinite; display: inline-block; }

@keyframes wz-slide-up {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- Scrollbar --- */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--wz-bg); }
::-webkit-scrollbar-thumb { background: var(--wz-primary); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #E55A5A; }

/* --- Utility --- */
.wz-text-center { text-align: center; }
.wz-mt-20 { margin-top: 20px; }
.wz-mb-20 { margin-bottom: 20px; }
.wz-candy-shadow { box-shadow: var(--wz-shadow); }
.wz-pop-border { border: 3px dashed var(--wz-secondary); }
