/* components.css - reusable component classes per the Design Specification.
   The mockup composes most of these from Tailwind utilities inline; these
   classes exist for hand-written markup (admin pages, blog posts, forms)
   and anywhere a single class beats repeating a utility chain. */

/* ---------- Buttons ---------- */
.btn-primary,
.btn-call {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--gold);
  color: #FFFFFF;
  padding: 1rem 1.75rem;
  border-radius: 9999px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  transition: background-color .2s ease;
  box-shadow: 0 10px 15px -3px rgba(186,117,23,0.25);
  cursor: pointer;
  border: 0;
}
.btn-primary:hover,
.btn-call:hover { background: var(--golddk); }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: transparent;
  color: var(--ink);
  border: 2px solid var(--ink);
  padding: calc(1rem - 2px) calc(1.75rem - 2px);
  border-radius: 9999px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  transition: background-color .2s ease, color .2s ease;
  cursor: pointer;
}
.btn-secondary:hover { background: var(--ink); color: #FFFFFF; }

/* ---------- Gold left-border card (audience/service cards) ---------- */
.card-gold {
  display: block;
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  border-left: 4px solid var(--gold);
  border-radius: 1rem;
  padding: 1.75rem;
  transition: box-shadow .3s ease, transform .3s ease;
}
.card-gold:hover {
  box-shadow: 0 20px 25px -5px rgba(44,44,42,0.05), 0 8px 10px -6px rgba(44,44,42,0.05);
  transform: translateY(-2px);
}

/* ---------- Trust strip (hero credibility grid; columns in responsive.css) ---------- */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  row-gap: 1rem;
  column-gap: 1.25rem;
  background: rgba(255,255,255,0.95);
  border: 1px solid var(--hairline);
  border-radius: 1rem;
  box-shadow: 0 20px 25px -5px rgba(44,44,42,0.10);
  padding: 1.25rem;
}

/* ---------- Review card ---------- */
.review-card {
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  border-left: 4px solid var(--gold);
  border-radius: 1rem;
  padding: 1.75rem;
}
.review-card blockquote {
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink);
}
.review-card cite {
  display: block;
  margin-top: 1rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 13px;
  color: var(--graytxt);
}

/* ---------- Blog post body (article typography) ---------- */
.post-body { font-size: 16px; line-height: 1.8; color: var(--graytxt); }
.post-body h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 26px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 2.25rem 0 0.875rem;
}
.post-body h3 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 19px;
  color: var(--ink);
  margin: 1.75rem 0 0.625rem;
}
.post-body p { margin: 0 0 1.125rem; }
.post-body ul, .post-body ol { margin: 0 0 1.125rem; padding-left: 1.375rem; }
.post-body ul { list-style: disc; }
.post-body ol { list-style: decimal; }
.post-body li { margin-bottom: 0.5rem; }
.post-body a { color: var(--gold); font-weight: 600; }
.post-body a:hover { text-decoration: underline; }
.post-body strong { color: var(--ink); font-weight: 600; }
.post-body .post-callout {
  background: var(--goldtint);
  border-left: 4px solid var(--gold);
  border-radius: 0 1rem 1rem 0;
  padding: 1.375rem 1.5rem;
  margin: 2rem 0;
}
.post-body .post-callout p { margin: 0; font-size: 14.5px; }
.post-body .post-takeaway {
  background: var(--offwhite);
  border: 1px solid var(--hairline);
  border-radius: 1rem;
  padding: 1.375rem 1.5rem;
  margin: 2rem 0 0;
}
.post-body .post-takeaway p { margin: 0; font-size: 15px; color: var(--ink); }

/* ---------- Accordion (FAQ) - native details/summary ---------- */
.accordion-item {
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  border-radius: 0.75rem;
  overflow: hidden;
}
.accordion-item + .accordion-item { margin-top: 0.75rem; }
.accordion-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.125rem 1.375rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 15px;
  color: var(--ink);
  cursor: pointer;
  list-style: none;
}
.accordion-item summary::-webkit-details-marker { display: none; }
.accordion-item summary::after {
  content: '+';
  font-size: 20px;
  font-weight: 400;
  color: var(--gold);
  flex-shrink: 0;
  transition: transform .2s ease;
}
.accordion-item[open] summary::after { content: '\2212'; }
.accordion-item .accordion-body {
  padding: 0 1.375rem 1.25rem;
  font-size: 14px;
  line-height: 1.7;
  color: var(--graytxt);
}
