/* Shared styles for contact, blog, checkout, FAQ, shipping */

.page-hero {
  background: linear-gradient(135deg, var(--earth) 0%, #2a1a10 100%);
  padding: 56px 0;
  text-align: center;
}
.page-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: var(--cream);
  margin-bottom: 10px;
}
.page-hero p { color: rgba(253,246,236,0.75); max-width: 520px; margin: 0 auto; }

.page-content { padding: 64px 0 80px; background: var(--cream); }

/* CMS body copy — Alvar theme only (no WP/Elementor styles) */
.cms-prose {
  line-height: 1.75;
  color: var(--text-mid);
  font-size: 0.97rem;
  max-width: 720px;
}
.cms-prose h1,
.cms-prose h2,
.cms-prose h3 {
  font-family: var(--font-display);
  color: var(--earth);
  margin: 1.75rem 0 0.75rem;
  line-height: 1.25;
}
.cms-prose h1 { font-size: 1.75rem; }
.cms-prose h2 { font-size: 1.35rem; }
.cms-prose h3 { font-size: 1.1rem; }
.cms-prose p { margin-bottom: 1rem; }
.cms-prose ul, .cms-prose ol { margin: 0 0 1rem 1.25rem; }
.cms-prose li { margin-bottom: 0.35rem; }
.cms-prose img, .cms-prose video {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  margin: 1rem 0;
}
.cms-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
}
.cms-prose a { color: var(--green); text-decoration: underline; }
.cms-prose a:hover { color: var(--earth); }
.cms-prose hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 2rem 0;
}
.cms-prose strong { color: var(--earth); }

.page-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.contact-form label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--earth);
  margin-bottom: 6px;
}
.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.95rem;
  margin-bottom: 18px;
  background: var(--white);
}
.contact-form textarea { min-height: 140px; resize: vertical; }

.contact-info-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 20px;
}
.contact-info-card h3 { font-size: 1rem; color: var(--earth); margin-bottom: 8px; }
.contact-info-card p, .contact-info-card a {
  font-size: 0.9rem;
  color: var(--text-mid);
  text-decoration: none;
  line-height: 1.6;
}
.contact-info-card a:hover { color: var(--green); }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 28px;
}
.blog-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
  text-decoration: none;
  color: inherit;
  display: block;
}
.blog-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.blog-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.blog-card-body { padding: 22px; }
.blog-card .blog-tag {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gold);
  margin-bottom: 8px;
}
.blog-card h3 { font-size: 1.05rem; color: var(--earth); margin-bottom: 8px; line-height: 1.35; }
.blog-card p { font-size: 0.88rem; color: var(--text-light); }

.checkout-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 40px;
}
.checkout-box {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: var(--shadow-sm);
}
.checkout-box h2 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--earth);
  margin-bottom: 20px;
}
.checkout-line {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
}
.checkout-line.total {
  border-bottom: none;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--earth);
  margin-top: 8px;
}

.faq-list { max-width: 760px; margin: 0 auto; }
.faq-item {
  background: var(--white);
  border-radius: var(--radius-md);
  margin-bottom: 12px;
  border: 1px solid var(--border);
  overflow: hidden;
}
.faq-question {
  width: 100%;
  text-align: left;
  padding: 18px 22px;
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--earth);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.faq-answer {
  display: none;
  padding: 0 22px 18px;
  font-size: 0.9rem;
  color: var(--text-mid);
  line-height: 1.65;
}
.faq-item.open .faq-answer { display: block; }
.faq-item.open .faq-question span:last-child { transform: rotate(45deg); }

.prose { max-width: 720px; margin: 0 auto; }
.prose h2 { font-family: var(--font-display); color: var(--earth); margin: 32px 0 12px; font-size: 1.4rem; }
.prose p { color: var(--text-mid); line-height: 1.75; margin-bottom: 14px; }
.prose ul { margin: 0 0 16px 20px; color: var(--text-mid); }

@media (max-width: 768px) {
  .page-grid-2, .checkout-grid { grid-template-columns: 1fr; }
}
