/**
 * Google Rating Badge & Reviews - Frontend Styles
 * Author: Dexville (dexville.be)
 */

:root {
    --grb-star-color: #FBBC04;
    --grb-card-bg: #ffffff;
    --grb-text-color: #333333;
    --grb-accent-color: #1a73e8;
}

/* Badge */
.grb-wrapper { display: inline-block; }

.grb-badge {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 16px 24px;
    background: var(--grb-card-bg);
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    text-decoration: none !important;
    color: var(--grb-text-color) !important;
    transition: box-shadow 0.2s, transform 0.2s;
}

.grb-badge:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.15);
    transform: translateY(-2px);
}

.grb-content { display: flex; flex-direction: column; gap: 4px; }
.grb-stars { display: flex; gap: 2px; }
.grb-star { width: 18px; height: 18px; }
.grb-star--small { width: 14px; height: 14px; }
.grb-rating { font-size: 24px; font-weight: 600; color: var(--grb-accent-color); line-height: 1; }
.grb-reviews { font-size: 12px; color: #5f6368; }
.grb-badge--compact { padding: 10px 16px; gap: 10px; }
.grb-badge--compact .grb-rating { font-size: 18px; }

/* Carousel Wrapper - Full Width */
.grb-carousel-wrapper {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    width: 100%;
    padding: 20px 0;
}

/* Header */
.grb-carousel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 24px;
}

.grb-carousel-stats { display: flex; align-items: center; gap: 12px; }
.grb-carousel-stats-content { display: flex; flex-direction: column; gap: 4px; }
.grb-carousel-stats-rating { display: flex; align-items: center; gap: 8px; }
.grb-carousel-rating-number { font-size: 28px; font-weight: 700; color: var(--grb-text-color); }
.grb-carousel-stats-count { font-size: 14px; color: #5f6368; }

.grb-cta-button {
    display: inline-flex;
    align-items: center;
    padding: 12px 24px;
    background: var(--grb-accent-color);
    color: #fff !important;
    border-radius: 8px;
    text-decoration: none !important;
    font-weight: 600;
    font-size: 14px;
    transition: background 0.2s, transform 0.2s;
}

.grb-cta-button:hover {
    filter: brightness(0.9);
    transform: translateY(-1px);
}

/* Carousel Container */
.grb-carousel {
    position: relative;
    display: flex;
    align-items: center;
}

.grb-carousel-track-container {
    overflow: hidden;
    flex: 1;
    margin: 0 10px;
    cursor: grab;
}

.grb-carousel-track-container:active {
    cursor: grabbing;
}

.grb-carousel-track-container.grb-dragging {
    cursor: grabbing;
}

/* When no navigation needed */
.grb-no-navigation .grb-carousel-track-container {
    cursor: default;
    margin: 0;
}

.grb-no-navigation .grb-carousel-arrow,
.grb-no-navigation .grb-carousel-dots {
    display: none !important;
}

.grb-carousel-track {
    display: flex;
    gap: 20px;
    transition: transform 0.4s ease;
}

.grb-carousel-track.grb-no-transition {
    transition: none;
}

/* Review Card - Base */
.grb-review-card {
    flex-shrink: 0;
    background: var(--grb-card-bg);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: box-shadow 0.2s, transform 0.2s;
    animation: grb-fade-in 0.5s ease;
    user-select: none;
}

.grb-review-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    transform: translateY(-2px);
}

@keyframes grb-fade-in {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Column widths - calculated with gap */
.grb-carousel-wrapper[data-columns="1"] .grb-review-card { width: 100%; }
.grb-carousel-wrapper[data-columns="2"] .grb-review-card { width: calc(50% - 10px); }
.grb-carousel-wrapper[data-columns="3"] .grb-review-card { width: calc(33.333% - 14px); }
.grb-carousel-wrapper[data-columns="4"] .grb-review-card { width: calc(25% - 15px); }
.grb-carousel-wrapper[data-columns="5"] .grb-review-card { width: calc(20% - 16px); }

/* Review Content */
.grb-review-header { display: flex; align-items: center; gap: 12px; }

.grb-review-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.grb-avatar-initials {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: 16px;
}

.grb-review-author-info { flex: 1; min-width: 0; }
.grb-review-author { font-weight: 600; color: var(--grb-text-color); font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.grb-review-date { font-size: 12px; color: #5f6368; }
.grb-review-rating .grb-stars { gap: 1px; }
.grb-review-rating .grb-star { width: 16px; height: 16px; }

.grb-review-text {
    font-size: 14px;
    line-height: 1.6;
    color: var(--grb-text-color);
    flex: 1;
}

.grb-read-more, .grb-read-less {
    background: none;
    border: none;
    color: var(--grb-accent-color);
    cursor: pointer;
    font-size: 14px;
    padding: 0;
    font-weight: 500;
}

.grb-read-more:hover, .grb-read-less:hover { text-decoration: underline; }

.grb-review-source {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #5f6368;
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid #f0f0f0;
}

.grb-review-source svg { width: 16px; height: 16px; }

/* Arrows - hidden by default, JS shows when needed */
.grb-carousel-arrow {
    display: none;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: var(--grb-card-bg);
    border: 1px solid #e0e0e0;
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.2s;
    flex-shrink: 0;
    z-index: 10;
}

.grb-carousel-arrow:hover { background: #f5f5f5; border-color: #ccc; }
.grb-carousel-arrow svg { width: 24px; height: 24px; color: var(--grb-text-color); }

/* Dots - hidden by default, JS shows when needed */
.grb-carousel-dots {
    display: none;
    justify-content: center;
    gap: 8px;
    margin-top: 20px;
}

.grb-carousel-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #e0e0e0;
    border: none;
    cursor: pointer;
    transition: all 0.2s;
    padding: 0;
}

.grb-carousel-dot:hover { background: #bbb; }
.grb-carousel-dot.active { background: var(--grb-accent-color); transform: scale(1.2); }

/* ===========================================
   RESPONSIVE BREAKPOINTS
   5 cols -> 4 cols -> 3 cols -> 2 cols -> 1 col
   =========================================== */

/* Large desktop: 5 columns stays 5 */
@media (max-width: 1400px) {
    .grb-carousel-wrapper[data-columns="5"] .grb-review-card { width: calc(25% - 15px); }
}

/* Desktop: max 4 columns */
@media (max-width: 1200px) {
    .grb-carousel-wrapper[data-columns="5"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="4"] .grb-review-card { width: calc(33.333% - 14px); }
}

/* Tablet landscape: max 3 columns */
@media (max-width: 1024px) {
    .grb-carousel-wrapper[data-columns="5"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="4"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="3"] .grb-review-card { width: calc(33.333% - 14px); }
}

/* Tablet portrait: max 2 columns */
@media (max-width: 768px) {
    .grb-carousel-wrapper[data-columns="5"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="4"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="3"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="2"] .grb-review-card { width: calc(50% - 10px); }
    
    .grb-carousel-header { flex-direction: column; align-items: flex-start; }
    .grb-carousel-arrow { width: 36px; height: 36px; }
    .grb-carousel-arrow svg { width: 20px; height: 20px; }
}

/* Mobile: always 1 column */
@media (max-width: 576px) {
    .grb-carousel-wrapper[data-columns="1"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="2"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="3"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="4"] .grb-review-card,
    .grb-carousel-wrapper[data-columns="5"] .grb-review-card { width: 100%; }
    
    .grb-carousel-track { gap: 15px; }
    .grb-review-card { padding: 16px; }
    .grb-carousel-rating-number { font-size: 24px; }
    .grb-cta-button { width: 100%; justify-content: center; }
}
