/* ==========================================================================
   Block — Testimonials
   Mobile-first, breakpoint at 768px
   ========================================================================== */

/* ── Section ── */
.block-testimonials {
    background: var(--gradient-grey);
    padding: var(--section-padding-y) 0;
}

/* ── Inner (heading wrapper) ── */
.block-testimonials__inner {
    padding: 0 var(--grid-margin);
    margin-bottom: 36px;
}

/* ── Heading ── */
.block-testimonials__heading {
    font-family: var(--font-heading);
    font-size: var(--h3-size);
    font-weight: var(--weight-medium);
    line-height: var(--h2-line-height);
    color: var(--color-grey-ultra-dark);
    margin: 0;
    text-align: left;
}

/* ══════════════════════════════════════════════════════════════════════════
   NAV ARROWS
   Below track on mobile, absolutely positioned top-right on desktop
   ══════════════════════════════════════════════════════════════════════════ */

.block-testimonials__nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    margin-top: 36px;
    padding: 0 var(--grid-margin);
}

.block-testimonials__arrow {
    width: 34px;
    height: 34px;
    padding: 0;
    border: none;
    background: none;
    cursor: pointer;
    color: var(--color-primary-orange);
    transition: opacity 0.2s ease;
    flex-shrink: 0;
}

.block-testimonials__arrow svg {
    width: 100%;
    height: 100%;
    display: block;
}

.block-testimonials__arrow:hover {
    opacity: 0.8;
}

.block-testimonials__arrow:disabled {
    color: var(--color-orange-light);
    cursor: default;
    opacity: 0.5;
}

.block-testimonials__arrow:disabled:hover {
    opacity: 0.5;
}

/* ══════════════════════════════════════════════════════════════════════════
   TRACK (scrollable carousel)
   ══════════════════════════════════════════════════════════════════════════ */

.block-testimonials__track-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    padding: 0 var(--grid-margin);
}

.block-testimonials__track-wrap::-webkit-scrollbar {
    display: none;
}

.block-testimonials__track {
    display: flex;
    gap: var(--space-md);
    align-items: stretch;
}

/* ══════════════════════════════════════════════════════════════════════════
   CARDS — shared
   ══════════════════════════════════════════════════════════════════════════ */

.block-testimonials__card {
    flex: 0 0 calc(100vw - 2 * var(--grid-margin));
    min-height: 420px;
    border-radius: var(--radius-card);
    overflow: hidden;
    scroll-snap-align: start;
}

/* ── Text Card ── */
.block-testimonials__card--text {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background-color: var(--color-off-white);
    padding: var(--card-padding);
}

.block-testimonials__card-top {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.block-testimonials__avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.block-testimonials__quote {
    font-family: var(--font-body);
    font-size: var(--body-small-size);
    font-weight: var(--weight-regular);
    line-height: var(--body-small-line-height);
    color: var(--color-grey-ultra-dark);
    margin: 0;
}

/* ── Card Meta (name + role) ── */
.block-testimonials__card-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: var(--space-md);
}

.block-testimonials__name {
    font-family: var(--font-body);
    font-size: var(--body-small-size);
    font-weight: var(--weight-semibold);
    line-height: var(--body-small-line-height);
    color: var(--color-orange-dark);
    margin: 0;
}

.block-testimonials__role {
    font-family: var(--font-body);
    font-size: var(--body-small-size);
    font-weight: var(--weight-semibold);
    line-height: var(--body-small-line-height);
    color: var(--color-grey-dark);
    margin: 0;
}

/* ── Video Card ── */
.block-testimonials__card--video {
    position: relative;
    display: flex;
    align-items: flex-end;
    background-color: var(--color-grey-dark);
}

.block-testimonials__thumb {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.block-testimonials__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.65) 0%, transparent 60%);
    pointer-events: none;
}

.block-testimonials__play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 67px;
    height: 67px;
    border: none;
    background: none;
    padding: 0;
    cursor: pointer;
    z-index: 2;
    transition: transform 0.2s ease;
}

.block-testimonials__play:hover {
    transform: translate(-50%, -50%) scale(1.08);
}

.block-testimonials__play svg {
    width: 100%;
    height: 100%;
    display: block;
}

.block-testimonials__card-meta--light {
    position: relative;
    z-index: 1;
    padding: var(--card-padding);
    width: 100%;
}

.block-testimonials__card-meta--light .block-testimonials__name {
    color: var(--color-off-white);
}

.block-testimonials__card-meta--light .block-testimonials__role {
    color: var(--color-off-white);
}

/* ══════════════════════════════════════════════════════════════════════════
   VIDEO MODAL
   ══════════════════════════════════════════════════════════════════════════ */

.block-testimonials__modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.block-testimonials__modal.is-open {
    opacity: 1;
    visibility: visible;
}

.block-testimonials__modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.85);
}

.block-testimonials__modal-content {
    position: relative;
    width: 90vw;
    max-width: 900px;
    aspect-ratio: 16 / 9;
}

.block-testimonials__modal-content iframe,
.block-testimonials__modal-content video {
    width: 100%;
    height: 100%;
    border: none;
    border-radius: var(--radius-card);
}

.block-testimonials__modal-close {
    position: absolute;
    top: -40px;
    right: 0;
    width: 32px;
    height: 32px;
    border: none;
    background: none;
    color: var(--color-white);
    cursor: pointer;
    padding: 0;
}

.block-testimonials__modal-close svg {
    width: 100%;
    height: 100%;
}

/* ══════════════════════════════════════════════════════════════════════════
   Desktop (≥ 768px)
   ══════════════════════════════════════════════════════════════════════════ */

@media (min-width: 768px) {

    .block-testimonials {
        position: relative;
    }

    .block-testimonials__inner {
        max-width: var(--grid-max-width);
        margin-left: auto;
        margin-right: auto;
        margin-bottom: var(--space-xxl);
    }

    .block-testimonials__heading {
        font-size: var(--h2-size);
    }

    /* Arrows positioned top-right, inline with heading */
    .block-testimonials__nav {
        position: absolute;
        top: var(--section-padding-y);
        right: max(var(--grid-margin), calc((100vw - var(--grid-max-width)) / 2 + var(--grid-margin)));
        margin-top: 0;
        padding: 0;
        justify-content: flex-end;
    }

    /* Track left edge aligns with heading; right extends to viewport edge */
    .block-testimonials__track-wrap {
        padding-left: max(var(--grid-margin), calc((100vw - var(--grid-max-width)) / 2 + var(--grid-margin)));
        padding-right: 0;
    }

    .block-testimonials__card {
        flex: 0 0 400px;
    }
}
