/* Shared layout for legal / about / contact pages */
.page-wrap {
  padding: 100px 5vw 60px;
  max-width: 820px;
  margin: 0 auto;
}

.page-banner {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border-radius: 20px;
  margin-bottom: 32px;
  box-shadow: 0 16px 40px rgba(30, 21, 32, 0.1);
}

.page-wrap h1 {
  font-size: clamp(2rem, 4vw, 2.6rem);
  margin-bottom: 12px;
}

.page-meta {
  color: var(--mocha);
  font-size: 0.9rem;
  margin-bottom: 28px;
}

.page-wrap h2 {
  font-size: 1.35rem;
  margin: 28px 0 10px;
}

.page-wrap p,
.page-wrap li {
  color: var(--mocha);
  margin-bottom: 12px;
}

.page-wrap ul { padding-left: 1.25rem; }

.contact-form label {
  display: block;
  font-size: 0.85rem;
  font-weight: 500;
  margin-bottom: 6px;
  color: var(--mocha);
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid rgba(42, 33, 28, 0.15);
  border-radius: 12px;
  margin-bottom: 16px;
  font: inherit;
}

.contact-form textarea { min-height: 140px; resize: vertical; }

.contact-form button {
  background: var(--rose);
  color: white;
  border: none;
  padding: 14px 28px;
  border-radius: 14px;
  font-weight: 600;
  cursor: pointer;
}

.contact-note {
  background: var(--blush);
  border-radius: 14px;
  padding: 16px 18px;
  margin-top: 20px;
  font-size: 0.95rem;
}
