/* GMB Testimonials — Public Styles */

:root {
  --gmbt-stars: #f5a623;
  --gmbt-card-bg: #ffffff;
  --gmbt-text: #333333;
  --gmbt-radius: 12px;
  --gmbt-shadow: 0 2px 16px rgba(0,0,0,.07);
  --gmbt-gap: 20px;
  --gmbt-accent: #4285F4;
}

/* ========================
   Base card
======================== */
.gmbt-testimonials {
  font-family: inherit;
  color: var(--gmbt-text);
}

.gmbt-card {
  background: var(--gmbt-card-bg);
  border-radius: var(--gmbt-radius);
  box-shadow: var(--gmbt-shadow);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform .2s, box-shadow .2s;
}

.gmbt-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 28px rgba(0,0,0,.12);
}

.gmbt-card.gmbt-featured {
  border: 2px solid var(--gmbt-accent);
}

/* Header row */
.gmbt-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
}

.gmbt-google-icon {
  margin-left: auto;
  flex-shrink: 0;
}

.gmbt-google-icon svg {
  width: 22px;
  height: 22px;
}

/* Avatar */
.gmbt-avatar-wrap { flex-shrink: 0; }

.gmbt-avatar {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid #eee;
}

.gmbt-avatar-placeholder {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4285F4, #34A853);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 18px;
  text-transform: uppercase;
}

.gmbt-reviewer-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.gmbt-reviewer-name {
  font-weight: 600;
  font-size: .95rem;
  color: var(--gmbt-text);
}

.gmbt-reviewer-name a {
  color: inherit;
  text-decoration: none;
}

.gmbt-reviewer-name a:hover { text-decoration: underline; }

.gmbt-review-date {
  font-size: .8rem;
  color: #888;
}

/* Stars */
.gmbt-stars { letter-spacing: 1px; font-size: 1.1rem; }
.gmbt-star-filled { color: var(--gmbt-stars); }
.gmbt-star-empty  { color: #ddd; }

/* Review text */
.gmbt-review-text {
  font-size: .925rem;
  line-height: 1.65;
  color: var(--gmbt-text);
  flex: 1;
}

.gmbt-text-full { display: none; }
.gmbt-text-full.is-open { display: block; }
.gmbt-text-short.is-hidden { display: none; }

.gmbt-read-more,
.gmbt-read-less {
  background: none;
  border: none;
  color: var(--gmbt-accent);
  cursor: pointer;
  font-size: inherit;
  padding: 0;
  font-weight: 600;
}

/* Footer - GMB link */
.gmbt-card-footer { margin-top: auto; }

.gmbt-gmb-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--gmbt-accent);
  text-decoration: none;
  border: 1.5px solid var(--gmbt-accent);
  border-radius: 6px;
  padding: 5px 12px;
  transition: background .15s, color .15s;
}

.gmbt-gmb-link:hover {
  background: var(--gmbt-accent);
  color: #fff;
}

.gmbt-external-icon { width: 13px; height: 13px; }

/* ========================
   GRID LAYOUT
======================== */
.gmbt-layout-grid {
  display: grid;
  grid-template-columns: repeat(var(--gmbt-cols, 3), 1fr);
  gap: var(--gmbt-gap);
}

.gmbt-cols-1 { --gmbt-cols: 1; }
.gmbt-cols-2 { --gmbt-cols: 2; }
.gmbt-cols-3 { --gmbt-cols: 3; }
.gmbt-cols-4 { --gmbt-cols: 4; }

/* ========================
   LIST LAYOUT
======================== */
.gmbt-layout-list {
  display: flex;
  flex-direction: column;
  gap: var(--gmbt-gap);
}

.gmbt-layout-list .gmbt-card { flex-direction: row; flex-wrap: wrap; }
.gmbt-layout-list .gmbt-card-header { flex: 0 0 220px; }
.gmbt-layout-list .gmbt-stars,
.gmbt-layout-list .gmbt-review-text,
.gmbt-layout-list .gmbt-card-footer { flex: 1; min-width: 200px; }

/* ========================
   MASONRY LAYOUT
======================== */
.gmbt-layout-masonry {
  columns: var(--gmbt-cols, 3);
  column-gap: var(--gmbt-gap);
}

.gmbt-layout-masonry .gmbt-card {
  break-inside: avoid;
  margin-bottom: var(--gmbt-gap);
}

/* ========================
   SLIDER LAYOUT
======================== */
.gmbt-layout-slider { position: relative; overflow: hidden; }

.gmbt-slider-wrapper { position: relative; }

.gmbt-slider-track {
  display: flex;
  gap: var(--gmbt-gap);
  transition: transform .4s cubic-bezier(.4,0,.2,1);
}

.gmbt-layout-slider .gmbt-card {
  flex: 0 0 calc(33.333% - 14px);
  min-width: 280px;
}

.gmbt-slider-prev,
.gmbt-slider-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  font-size: 22px;
  cursor: pointer;
  z-index: 10;
  line-height: 1;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
  transition: background .15s;
}

.gmbt-slider-prev:hover,
.gmbt-slider-next:hover { background: var(--gmbt-accent); color: #fff; }

.gmbt-slider-prev { left: -20px; }
.gmbt-slider-next { right: -20px; }

.gmbt-slider-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}

.gmbt-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ccc;
  cursor: pointer;
  border: none;
  padding: 0;
  transition: background .2s;
}

.gmbt-dot.active { background: var(--gmbt-accent); }

/* ========================
   Empty state
======================== */
.gmbt-no-testimonials {
  text-align: center;
  padding: 40px;
  color: #888;
  font-style: italic;
}

/* ========================
   Responsive
======================== */
@media (max-width: 1024px) {
  .gmbt-cols-4 { --gmbt-cols: 3; }
  .gmbt-layout-masonry.gmbt-cols-4 { columns: 3; }
}

@media (max-width: 768px) {
  .gmbt-cols-3,
  .gmbt-cols-4 { --gmbt-cols: 2; }
  .gmbt-layout-masonry.gmbt-cols-3,
  .gmbt-layout-masonry.gmbt-cols-4 { columns: 2; }
  .gmbt-layout-list .gmbt-card { flex-direction: column; }
  .gmbt-layout-slider .gmbt-card { flex: 0 0 calc(50% - 10px); }
}

@media (max-width: 480px) {
  .gmbt-cols-2,
  .gmbt-cols-3,
  .gmbt-cols-4 { --gmbt-cols: 1; }
  .gmbt-layout-masonry { columns: 1; }
  .gmbt-layout-slider .gmbt-card { flex: 0 0 calc(100%); }
  .gmbt-slider-prev { left: 0; }
  .gmbt-slider-next { right: 0; }
}
