/* Page-Specific Styles */

/* Homepage */
.hero {
  text-align: center;
  padding: var(--space-8) 0;
  margin-bottom: var(--space-8);
}

.hero-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 700;
  color: var(--color-charcoal);
  margin-bottom: var(--space-3);
}

.hero-subtitle {
  font-family: var(--font-handwritten);
  font-size: var(--text-2xl);
  color: var(--color-sage);
}

/* Recent Places */
.recent-places {
  margin-bottom: var(--space-12);
}

/* Place Detail */
.place-detail {
  background-color: white;
  border-radius: var(--border-radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
}

.place-detail-header {
  margin-bottom: var(--space-6);
}

.place-detail-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--color-charcoal);
  margin-bottom: var(--space-3);
}

.place-detail-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.place-detail-notes {
  font-family: var(--font-handwritten);
  font-size: var(--text-xl);
  line-height: 1.8;
  color: var(--color-charcoal);
  padding: var(--space-6);
  background-color: var(--color-cream);
  border-radius: var(--border-radius-md);
  border-left: 4px solid var(--color-sage);
  margin-bottom: var(--space-6);
}

.place-detail-actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* Add Place Form */
.add-place-form {
  background-color: white;
  border-radius: var(--border-radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
}

.form-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-charcoal);
  margin-bottom: var(--space-6);
}

/* Places List */
.places-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.places-header {
  margin-bottom: var(--space-6);
}

.places-count {
  font-size: var(--text-base);
  color: #666;
  margin-top: var(--space-2);
}

/* Recommendations */
.recommendations-intro {
  background-color: white;
  border-radius: var(--border-radius-md);
  padding: var(--space-6);
  margin-bottom: var(--space-8);
  border-left: 4px solid var(--color-sage);
}

.recommendations-intro p {
  font-size: var(--text-base);
  color: var(--color-charcoal);
  line-height: 1.6;
}

/* Error State */
.error-message {
  background-color: #FEE;
  border-left: 4px solid #C33;
  padding: var(--space-4);
  border-radius: var(--border-radius-sm);
  margin-bottom: var(--space-6);
  color: #C33;
  font-weight: 500;
}

/* Success State */
.success-message {
  background-color: #EFE;
  border-left: 4px solid #3C3;
  padding: var(--space-4);
  border-radius: var(--border-radius-sm);
  margin-bottom: var(--space-6);
  color: #3C3;
  font-weight: 500;
}
