/* =========================================
   WBMP Components – shared UI patterns
   (buttons, cards, pills, FAQ, price chip)
   ========================================= */

/* --- Small utilities --- */

.separator-gold {
  color: #D4AF30;
}

.excerpt-button,
.wp-block-read-more {
  width: initial !important;
  text-align: center !important;
  font-weight: bolder !important;
}

/* --- Card shell (used on archives, promos, etc.) --- */

.wbmp-card {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.wbmp-card-body {
  max-width: none;
}

/* CTA area inside a card or block */
.wbmp-card-cta {
  padding: 0 0 1rem;
  margin: var(--wp--preset--spacing--20) 0 0;
}

/* --- Global accent variables (gold) --- */

:root {
  --wbmp-accent: #D4AF30;
  --wbmp-accent-dark: #B9911F;
}

/* --- Primary CTA button (and card CTA buttons) --- */

a.wbmp-btn,
.wbmp-card-cta a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .6rem 1rem;
  border-radius: 9999px;
  background: var(--wbmp-accent, #D4AF30) !important;
  color: #111 !important;
  border: 2px solid var(--wbmp-accent-dark, #B9911F) !important;
  font-weight: 800 !important;
  letter-spacing: .2px;
  text-decoration: none !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
  transition: filter .15s ease, transform .02s ease, box-shadow .15s ease;
}

a.wbmp-btn:hover,
.wbmp-card-cta a:hover {
  filter: brightness(.98);
  box-shadow: 0 10px 28px rgba(0,0,0,.18);
}

a.wbmp-btn:active,
.wbmp-card-cta a:active {
  transform: translateY(1px);
}

/* Emoji “calendar” icon before CTA label */
a.wbmp-btn::before,
.wbmp-card-cta a::before {
  content: "📅";
  display: inline-block;
  margin-right: .5rem;
  line-height: 1;
  font-size: 1.1em;
}

/* --- Price chip component (used on service pages, but reusable) --- */

.wbmp-service-price {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .4rem .8rem;
  border-radius: 9999px;
  border: 2px solid var(--wbmp-accent-dark, #B9911F);
  background: linear-gradient(
    180deg,
    rgba(212, 175, 48, .22),
    rgba(212, 175, 48, .12)
  );
  box-shadow: 0 4px 14px rgba(0,0,0,.12);
}

.wbmp-service-price::before {
  content: "💲";
  font-size: 1.05em;
  line-height: 1;
}

.wbmp-price-label {
  font-size: .95rem;
  font-weight: 700;
  opacity: .95;
}

.wbmp-price-amount {
  font-size: 1.25rem;
  font-weight: 900;
}

/* --- Taxonomy pill components (under headings, in sidebars, etc.) --- */

/* Block of chips under a heading, usually in the booking card */
.wbmp-term-pills .wp-block-post-terms {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-top: .25rem;
}

/* Style only links as pills */
.wbmp-term-pills .wp-block-post-terms a {
  display: inline-block;
  padding: .35rem .65rem;
  border-radius: 9999px;
  background: var(--wp--preset--color--base-2, #f6f6f6);
  text-decoration: none;
  margin: 0;
}

/* Absolutely remove any separator output */
.wbmp-term-pills .wp-block-post-terms__separator {
  display: none !important;
}
.wbmp-term-pills .wp-block-post-terms > span {
  display: none !important;
}

/* Collapse stray whitespace between adjacent anchors */
.wbmp-term-pills .wp-block-post-terms {
  letter-spacing: 0;
}

/* Tiny heading spacing in the term pills block */
.wbmp-term-pills h6 {
  margin: .25rem 0 .25rem;
}

/* Inline pill row, e.g. under page titles */
.wbmp-terms-inline {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin: .25rem 0;
}

/* Merge multiple Post Terms blocks into a single flow */
.wbmp-terms-inline .wp-block-post-terms {
  display: contents;
}

/* Slightly tighter chips for title-adjacent usage */
.wbmp-terms-inline .wp-block-post-terms a {
  padding: .25rem .55rem;
  border: 1px solid var(--wp--preset--color--contrast-3, #e5e5e5);
  font-size: .9em;
  line-height: 1.2;
  border-radius: 9999px;
  text-decoration: none;
}

/* --- FAQ component --- */

.wbmp-faq .wp-block-heading {
  margin-top: 0;
  margin-bottom: .75rem;
  line-height: 1.2;
}

.wbmp-faq__list {
  display: grid;
  gap: .5rem;
}

.wbmp-faq__item {
  border: 1px solid var(--wp--preset--color--contrast-3, #e5e5e5);
  border-radius: 8px;
  background: var(--wp--preset--color--base, #fff);
  padding: .25rem .5rem;
}

.wbmp-faq__item[open] {
  background: var(--wp--preset--color--base-2, #f7f7f7);
}

.wbmp-faq__item summary {
  position: relative;
  display: block;
  margin: 0;
  padding: .35rem .25rem .35rem 1.25rem;
  list-style: none;
  cursor: pointer;
  font-weight: 600;
}

.wbmp-faq__item summary::-webkit-details-marker {
  display: none;
}

.wbmp-faq__item summary::before {
  content: '▸';
  position: absolute;
  left: .25rem;
  top: .4rem;
  transition: transform .18s ease;
}

.wbmp-faq__item[open] summary::before {
  transform: rotate(90deg);
}

.wbmp-faq__item summary:hover {
  text-decoration: underline;
}

.wbmp-faq__item summary:focus {
  outline: 2px solid var(--wp--preset--color--contrast-3, #d0d0d0);
  outline-offset: 2px;
  border-radius: 6px;
}

.wbmp-faq__a {
  padding: .35rem 0 0;
}