/* ============================================
   Map of Us 我们的地图 v2.0 — Wishlist Page Styles
   Soft Romance Palette + Glassmorphism
   ============================================ */

/* === Wishlist Page Layout === */
.wishlist-page {
  max-width: 900px;
  padding: var(--space-xl);
  margin: 0;
  animation: fadeIn var(--transition-normal);
}

/* === Wishlist Header === */
.wishlist-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
  gap: var(--space-base);
}

.wishlist-header__title {
  font-size: var(--font-display-md);
  font-weight: var(--weight-bold);
  color: var(--color-ink);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.wishlist-header__title svg {
  color: var(--color-primary);
  flex-shrink: 0;
}

.wishlist-header__count {
  font-size: var(--font-caption-sm);
  font-weight: var(--weight-normal);
  color: var(--color-muted);
  background: var(--color-surface-soft);
  border-radius: var(--radius-full);
  padding: 2px 10px;
  margin-left: var(--space-xs);
}

/* === Filter Toggle Pills === */
.wishlist-filters {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
  background: var(--color-surface-soft);
  border-radius: var(--radius-full);
  padding: 4px;
  width: fit-content;
}

.wishlist-filter-btn {
  font-family: var(--font-family);
  font-size: var(--font-caption);
  font-weight: var(--weight-medium);
  color: var(--color-muted);
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  padding: 8px 20px;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
  line-height: 1.4;
}

.wishlist-filter-btn:hover {
  color: var(--color-ink);
  background: var(--color-glass-bg);
}

.wishlist-filter-btn--active {
  background: var(--color-canvas);
  color: var(--color-ink);
  box-shadow: var(--shadow-sm);
}

/* === Wishlist Grid === */
.wishlist-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-base);
}

/* === Wishlist Card === */
.wishlist-card {
  background: var(--color-glass-bg);
  backdrop-filter: var(--glass-blur-light);
  -webkit-backdrop-filter: var(--glass-blur-light);
  border: var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: box-shadow var(--transition-normal),
              transform var(--transition-normal),
              opacity var(--transition-normal);
  position: relative;
  overflow: hidden;
}

.wishlist-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.wishlist-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-sm);
}

.wishlist-card__city {
  font-size: var(--font-display-sm);
  font-weight: var(--weight-bold);
  color: var(--color-ink);
  line-height: 1.3;
  word-break: break-word;
}

.wishlist-card__province {
  font-size: var(--font-caption-sm);
  color: var(--color-muted);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-top: 2px;
}

.wishlist-card__province svg {
  flex-shrink: 0;
}

.wishlist-card__note {
  font-size: var(--font-body-sm);
  color: var(--color-body);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wishlist-card__note--empty {
  color: var(--color-muted-soft);
  font-style: italic;
}

/* === Status Badge === */
.wishlist-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-badge);
  font-weight: var(--weight-semibold);
  padding: 4px 10px;
  border-radius: var(--radius-full);
  white-space: nowrap;
  width: fit-content;
}

.wishlist-card__badge--todo {
  background: var(--color-primary-light);
  color: var(--color-primary-hover);
}

.wishlist-card__badge--done {
  background: #eaf5ee;
  color: var(--color-success);
}

/* === Card Actions === */
.wishlist-card__actions {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-top: auto;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-hairline-soft);
}

.wishlist-card__checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--font-caption-sm);
  color: var(--color-muted);
  cursor: pointer;
  flex: 1;
  user-select: none;
}

.wishlist-card__checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-success);
  cursor: pointer;
  flex-shrink: 0;
}

.wishlist-card__action-btn {
  width: 32px;
  height: 32px;
  padding: 0;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--color-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
  border: none;
}

.wishlist-card__action-btn:hover {
  background: var(--color-surface-soft);
  color: var(--color-ink);
}

.wishlist-card__action-btn--danger:hover {
  background: #fef2f2;
  color: var(--color-error);
}

/* === Completed State === */
.wishlist-card--completed {
  opacity: 0.6;
}

.wishlist-card--completed .wishlist-card__city,
.wishlist-card--completed .wishlist-card__province {
  text-decoration: line-through;
  text-decoration-color: var(--color-muted-soft);
  text-decoration-thickness: 1px;
}

.wishlist-card--completed:hover {
  opacity: 0.75;
  transform: none;
}

/* === Wishlist Date === */
.wishlist-card__date {
  font-size: 12px;
  color: var(--color-muted-soft);
}

/* === Empty State === */
.wishlist-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-section) var(--space-lg);
  text-align: center;
  min-height: 360px;
}

.wishlist-empty__icon {
  font-size: 56px;
  margin-bottom: var(--space-lg);
  animation: floatUpDown 3s ease-in-out infinite;
}

.wishlist-empty__title {
  font-size: var(--font-display-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-ink);
  margin-bottom: var(--space-sm);
}

.wishlist-empty__text {
  font-size: var(--font-body-md);
  color: var(--color-muted);
  margin-bottom: var(--space-lg);
  max-width: 320px;
  line-height: 1.6;
}

/* === Stat Bar === */
.wishlist-stats {
  display: flex;
  gap: var(--space-base);
  margin-bottom: var(--space-lg);
}

.wishlist-stat {
  flex: 1;
  background: var(--color-glass-bg);
  backdrop-filter: var(--glass-blur-light);
  -webkit-backdrop-filter: var(--glass-blur-light);
  border: var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--space-base);
  text-align: center;
}

.wishlist-stat__value {
  font-size: var(--font-display-lg);
  font-weight: var(--weight-bold);
  color: var(--color-primary);
  line-height: 1.1;
}

.wishlist-stat__label {
  font-size: var(--font-caption-sm);
  color: var(--color-muted);
  margin-top: var(--space-xs);
}

/* === Responsive === */
@media (max-width: 744px) {
  .wishlist-page {
    padding: var(--space-base);
  }

  .wishlist-grid {
    grid-template-columns: 1fr;
  }

  .wishlist-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .wishlist-filters {
    width: 100%;
    justify-content: center;
  }

  .wishlist-filter-btn {
    flex: 1;
    text-align: center;
    padding: 8px 12px;
    font-size: var(--font-caption-sm);
  }

  .wishlist-stats {
    flex-direction: column;
    gap: var(--space-sm);
  }
}
