/* ============================================================
   GOOGLE REVIEWS — cards + carousel
   ============================================================ */

.reviews-section { padding-block: var(--sp-8) var(--sp-6); }

.reviews-summary {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    margin-top: var(--sp-4);
    color: var(--text-muted);
}
.reviews-summary strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 1.25rem;
}

/* ---------- carousel ---------- */
.carousel { overflow: hidden; }

.carousel-track {
    display: flex;
    gap: var(--sp-5);
    transition: transform 0.6s var(--ease-out);
    padding-block: var(--sp-2) var(--sp-4); /* room for card shadows */
}

.review-card {
    flex: 0 0 100%;
    padding: var(--sp-6);
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
    transition: transform var(--speed) var(--ease-out), box-shadow var(--speed) var(--ease-out);
}
.review-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.review-head {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}
.review-name { font-weight: 600; }
.review-date { font-size: var(--fs-200); color: var(--text-muted); }
.review-g { width: 22px; height: 22px; margin-left: auto; flex-shrink: 0; }

.review-text {
    color: var(--text-muted);
    font-size: var(--fs-300);
    line-height: 1.7;
}

/* ---------- controls ---------- */
.carousel-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-4);
    margin-top: var(--sp-4);
}

.carousel-btn {
    width: 44px; height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: var(--bg-raised);
    color: var(--text);
    transition: background-color var(--speed) ease, color var(--speed) ease, transform var(--speed) var(--ease-out);
}
.carousel-btn:hover { background: var(--c-primary); border-color: var(--c-primary); color: #fff; transform: scale(1.08); }
.carousel-btn svg { width: 18px; height: 18px; }

.carousel-dots { display: flex; gap: 0.5rem; }
.carousel-dots button {
    width: 9px; height: 9px;
    padding: 0;
    border: 0;
    border-radius: var(--radius-pill);
    background: var(--line);
    transition: width var(--speed) var(--ease-out), background-color var(--speed) ease;
}
.carousel-dots button.is-active { width: 26px; background: var(--c-primary); }

.reviews-cta {
    margin-top: var(--sp-5);
    text-align: center;
    color: var(--text-muted);
    font-size: var(--fs-300);
}

/* ---------- breakpoints ---------- */
@media (min-width: 768px) {
    .review-card { flex-basis: calc((100% - var(--sp-5)) / 2); }
}
@media (min-width: 1024px) {
    .review-card { flex-basis: calc((100% - 2 * var(--sp-5)) / 3); }
}
