/* ============================================================================
 * Component: reviews — Splide-powered carousel.
 * Splide core handles arrows/pagination/keyboard/touch; we only style the
 * card content + override Splide defaults to match brand.
 * ========================================================================= */

.rc-comp-reviews {
    padding: 56px 16px;
    background: #FAFAF7;
    color: #1A1F26;
    font-family: 'ProximaNova', 'Proxima Nova', 'Noto Sans', sans-serif;
}
.rc-comp-reviews *,
.rc-comp-reviews *::before,
.rc-comp-reviews *::after { box-sizing: border-box; }

.rc-comp-reviews-head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 40px;
}
.rc-comp-reviews-eyebrow {
    display: inline-block;
    font-family: 'Plakkaat', 'ProximaNova', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #00A356;
    background: #E6F9F0;
    padding: 6px 14px;
    border-radius: 999px;
    margin-bottom: 16px;
}
.rc-comp-reviews-h2 {
    font-family: 'ProximaNova', sans-serif;
    font-weight: 700;
    font-size: 28px;
    line-height: 1.2;
    letter-spacing: -0.015em;
    margin: 0 0 12px;
}
.rc-comp-reviews-lead {
    font-size: 17px;
    color: #555E6B;
    margin: 0;
    line-height: 1.55;
}

/* Splide carousel container — give breathing room for arrows */
.rc-comp-reviews-splide {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px; /* room for default arrows outside content */
}

/* Card body */
.rc-comp-reviews-splide .splide__slide {
    height: auto;
    display: flex;
}
.rc-comp-reviews-card {
    background: #FFFFFF;
    border: 1px solid #EFF1F4;
    border-radius: 20px;
    padding: 28px 24px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
    height: 100%; /* fill slide so all cards align */
}

.rc-comp-reviews-stars {
    display: inline-flex;
    gap: 2px;
}
.rc-comp-reviews-stars svg.is-on  { color: #FFB800; }
.rc-comp-reviews-stars svg.is-off { color: #E5E7EB; }

.rc-comp-reviews-text {
    font-size: 16px;
    line-height: 1.55;
    color: #1A1F26;
    margin: 0;
}
.rc-comp-reviews-text::before {
    content: "“";
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 28px;
    line-height: 0;
    color: #00BF63;
    margin-right: 4px;
    vertical-align: -6px;
}
.rc-comp-reviews-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: auto;
}
.rc-comp-reviews-name {
    font-weight: 700;
    color: #1A1F26;
    font-size: 15px;
}
.rc-comp-reviews-child {
    font-size: 13px;
    color: #6B7380;
}

/* Brand override on Splide arrows + pagination */
.rc-comp-reviews-splide .splide__arrow {
    background: #FFFFFF;
    box-shadow: 0 8px 24px rgba(15,23,42,0.12);
    border: 1px solid #DEE2E8;
    width: 44px;
    height: 44px;
    opacity: 1;
}
.rc-comp-reviews-splide .splide__arrow svg { fill: #1A1F26; transition: fill .15s ease; }
.rc-comp-reviews-splide .splide__arrow:hover { background: #00BF63; border-color: #00BF63; }
.rc-comp-reviews-splide .splide__arrow:hover svg { fill: #FFFFFF; }
.rc-comp-reviews-splide .splide__arrow:disabled { opacity: 0.45; }
.rc-comp-reviews-splide .splide__arrow--prev { left: -4px; }
.rc-comp-reviews-splide .splide__arrow--next { right: -4px; }

.rc-comp-reviews-splide .splide__pagination { bottom: -28px; }
.rc-comp-reviews-splide .splide__pagination__page {
    background: #DEE2E8;
    width: 10px;
    height: 10px;
    margin: 0 4px;
    transition: transform .15s ease, background .15s ease;
}
.rc-comp-reviews-splide .splide__pagination__page.is-active {
    background: #00BF63;
    transform: scale(1.3);
}

@media (min-width: 600px) {
    .rc-comp-reviews-splide { padding: 0 48px; }
}
@media (min-width: 1024px) {
    .rc-comp-reviews { padding: 96px 32px; }
    .rc-comp-reviews-h2 { font-size: 36px; }
    .rc-comp-reviews-splide { padding: 0 56px; }
}
