/* ==========================================================================
   KE Testimonials Widget
   ========================================================================== */

.ke-testimonials {
    position: relative;
}

.ke-testimonials--layout-grid {
    display: grid;
    gap: 30px;
}

.ke-testimonials--layout-slider {
    overflow: hidden;
}

.ke-testimonials__item {
    background: var(--ke-card-solid);
    padding: 30px;
    border-radius: var(--ke-radius-md);
    box-shadow: var(--ke-shadow-sm);
}

.ke-testimonials__content {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--ke-text);
    margin-bottom: var(--ke-space-5);
    font-style: italic;
}

.ke-testimonials__content::before {
    content: '"';
    font-size: 3rem;
    color: var(--ke-primary);
    line-height: 0;
    display: block;
    margin-bottom: 10px;
}

.ke-testimonials__author,
.ke-testimonial-author {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 15px;
}

.ke-testimonials__avatar {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    overflow: hidden;
}

.ke-testimonials__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ke-testimonials__info {
    flex: 1;
}

.ke-testimonials__name {
    font-weight: 600;
    margin: 0 0 5px;
    color: var(--ke-text);
}

.ke-testimonials__title {
    font-size: 0.875rem;
    color: var(--ke-text-light);
    margin: 0;
}

.ke-testimonials__company {
    font-size: 0.875rem;
    color: var(--ke-text-light);
}

.ke-testimonials__rating {
    display: flex;
    gap: var(--ke-space-1);
    margin-bottom: 15px;
}

.ke-testimonials__star {
    color: #ffc107;
    font-size: 16px;
}

.ke-testimonials__star--empty {
    color: var(--ke-gray-150);
}

/* Slider Navigation */
.ke-testimonials__nav {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: var(--ke-space-5);
}

.ke-testimonials__nav-btn {
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 50%;
    background: var(--ke-primary);
    color: #fff;
    cursor: pointer;
    transition: var(--ke-transition);
}

.ke-testimonials__nav-btn:hover {
    background: var(--ke-primary-dark);
}

.ke-testimonials__pagination {
    display: flex;
    justify-content: center;
    gap: var(--ke-space-2);
    margin-top: var(--ke-space-5);
}

.ke-testimonials__pagination-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--ke-border);
    cursor: pointer;
    transition: var(--ke-transition);
}

.ke-testimonials__pagination-dot.is-active {
    background: var(--ke-primary);
}

/* ==========================================================================
   Inline-SVG-Icons (host-agnostisch, ersetzt Font-Awesome-Abhängigkeit)
   ========================================================================== */

/* Zitat-Icon — Größe via font-size (1em), Farbe via currentColor (Controls greifen) */
.ke-testimonial-quote {
    color: var(--ke-primary);
    font-size: 40px;
    line-height: 1;
    margin-bottom: 15px;
}
.ke-testimonial-quote svg {
    width: 1em;
    height: 1em;
    fill: currentColor;
    /* inline-block statt block: folgt dem (geerbten) text-align der Ausrichtung */
    display: inline-block;
    vertical-align: middle;
}

/* Sterne-Bewertung */
.ke-testimonial-rating {
    display: flex;
    gap: 4px;
}
.ke-testimonial-rating svg {
    width: 1em;
    height: 1em;
    font-size: 18px;
    fill: currentColor;
    color: #ffc107;
    flex: 0 0 auto;
}
.ke-testimonial-rating svg.ke-star-empty {
    color: #ddd;
}

/* ==========================================================================
   Slider-Navigation — self-contained (unabhängig von extern geladener Swiper-CSS)
   ========================================================================== */

.ke-testimonials--layout-slider {
    position: relative;
    /* Seitliche Gutter für die Pfeile: die Slides werden eingerückt, die Pfeile
       sitzen daneben statt darüber → keine Überschneidung mit dem Karten-Text. */
    padding-left: 56px;
    padding-right: 56px;
}

/* Clippt die Slides an der Content-Kante (innerhalb der Gutter). Ohne diese
   Ebene würden translatierte Slides im Gutter unter den Pfeilen durchscheinen. */
.ke-testimonials__viewport {
    overflow: hidden;
}

.ke-testimonials--layout-slider .swiper-button-prev,
.ke-testimonials--layout-slider .swiper-button-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--ke-primary);
    color: #fff;
    cursor: pointer;
    z-index: 5;
    transition: var(--ke-transition);
}
.ke-testimonials--layout-slider .swiper-button-prev { left: 8px; }
.ke-testimonials--layout-slider .swiper-button-next { right: 8px; }

/* Eigenes SVG — evtl. von externer Swiper-CSS injizierten ::after-Glyph unterdrücken */
.ke-testimonials--layout-slider .swiper-button-prev::after,
.ke-testimonials--layout-slider .swiper-button-next::after {
    display: none !important;
    content: none !important;
}
.ke-testimonials--layout-slider .swiper-button-prev svg,
.ke-testimonials--layout-slider .swiper-button-next svg {
    width: 40%;
    height: 40%;
    fill: currentColor;
}
.ke-testimonials--layout-slider .swiper-button-prev:hover,
.ke-testimonials--layout-slider .swiper-button-next:hover {
    opacity: 0.85;
}
.ke-testimonials--layout-slider .swiper-button-prev[disabled],
.ke-testimonials--layout-slider .swiper-button-next[disabled] {
    opacity: 0.35;
    cursor: default;
}

.ke-testimonials--layout-slider .swiper-pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 20px;
}
.ke-testimonials--layout-slider .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--ke-gray-150, #d1d5db);
    opacity: 1;
    cursor: pointer;
    transition: var(--ke-transition);
}
.ke-testimonials--layout-slider .swiper-pagination-bullet-active {
    background: var(--ke-primary);
}

/* Mobile: schmalere Gutter + kompaktere Pfeile, damit die Karte genug Breite behält. */
@media (max-width: 600px) {
    .ke-testimonials--layout-slider {
        padding-left: 44px;
        padding-right: 44px;
    }
    .ke-testimonials--layout-slider .swiper-button-prev,
    .ke-testimonials--layout-slider .swiper-button-next {
        width: 34px;
        height: 34px;
    }
    .ke-testimonials--layout-slider .swiper-button-prev { left: 5px; }
    .ke-testimonials--layout-slider .swiper-button-next { right: 5px; }
}

