/* Spa Elysium — Components (carousel, lightbox, offers, faq) */

/* ── REVIEWS CAROUSEL ── */
#reviews { background: var(--bg); padding: 90px 0; }
.reviews-rating { font-family: 'Cormorant Garamond', serif; font-size: 20px; color: var(--green); text-align: center; margin-bottom: 36px; }
.carousel-wrapper { overflow: hidden; position: relative; }
.carousel-track { display: flex; transition: transform 0.4s ease; }
.review-card {
  flex: 0 0 calc(33.333% - 16px); margin-right: 24px;
  background: #111; border: 1px solid #1A1A1A;
  padding: 28px; border-radius: 4px; transition: border-color 0.3s;
}
.review-card:hover { border-color: var(--green); }
.review-stars { color: var(--gold); font-size: 14px; margin-bottom: 12px; }
.review-text { font-family: 'Inter', sans-serif; font-size: 14px; color: #555; font-style: italic; line-height: 1.8; margin-bottom: 16px; }
.review-name { font-family: 'Inter', sans-serif; font-size: 13px; color: var(--text); font-weight: 600; }
.review-source { font-family: 'Inter', sans-serif; font-size: 11px; color: var(--green); margin-top: 4px; }
.carousel-nav { display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 28px; }
.carousel-btn {
  background: rgba(45,122,58,0.2); border: 1px solid var(--green); color: var(--green);
  width: 40px; height: 40px; border-radius: 2px; font-size: 18px; cursor: pointer;
  transition: background 0.2s; display: flex; align-items: center; justify-content: center;
}
.carousel-btn:hover { background: var(--green); color: #fff; }
.carousel-dots { display: flex; gap: 8px; }
.carousel-dot { width: 8px; height: 8px; border-radius: 50%; background: #222; cursor: pointer; transition: background 0.2s; }
.carousel-dot.active { background: var(--green); }
.reviews-links { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 28px; }

/* ── SPECIAL OFFERS ── */
#offers { background: #0D0D0D; padding: 90px 0; }
.offers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 32px; }
.offer-card { background: #111; border: 1px solid #1A1A1A; padding: 26px; border-radius: 4px; }
.offer-card.featured { border-color: var(--green); }
.offer-emoji { font-size: 24px; margin-bottom: 10px; }
.offer-title-card { font-family: 'Cormorant Garamond', serif; font-size: 19px; color: var(--text); margin-bottom: 8px; }
.offer-desc { font-family: 'Inter', sans-serif; font-size: 13px; color: #555; line-height: 1.7; margin-bottom: 16px; }

/* ── FAQ ── */
#faq { background: var(--bg); padding: 90px 0; }
.faq-list { max-width: 740px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid #1A1A1A; }
.faq-q {
  width: 100%; background: none; border: none;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0; cursor: pointer; font-family: 'Inter', sans-serif;
  font-size: 14px; color: var(--text); text-align: left; gap: 16px;
}
.faq-q:hover { color: var(--green); }
.faq-toggle { color: var(--green); font-size: 18px; flex-shrink: 0; transition: transform 0.3s; display: inline-block; }
.faq-toggle.open { transform: rotate(45deg); }
.faq-a { overflow: hidden; max-height: 0; transition: max-height 0.35s ease; }
.faq-a.open { max-height: 500px; }
.faq-a-inner { padding: 0 0 18px; font-family: 'Inter', sans-serif; font-size: 13px; color: #555; line-height: 1.9; }

/* ── LIGHTBOX ── */
.lightbox {
  position: fixed; inset: 0; background: rgba(0,0,0,0.95);
  z-index: 9999; display: none; align-items: center; justify-content: center;
}
.lightbox.active { display: flex; }
.lightbox-img { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: 4px; }
.lightbox-close {
  position: absolute; top: 24px; right: 32px;
  background: none; border: none; color: #fff; font-size: 32px; cursor: pointer;
}
.lightbox-prev, .lightbox-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(45,122,58,0.4); border: none; color: #fff;
  font-size: 28px; width: 52px; height: 52px; cursor: pointer;
  border-radius: 2px; display: flex; align-items: center; justify-content: center;
  transition: background 0.2s;
}
.lightbox-prev:hover, .lightbox-next:hover { background: var(--green); }
.lightbox-prev { left: 24px; }
.lightbox-next { right: 24px; }
