/**
 * Testimonial Card Templates - Kai House
 * Uses Brand Skin variables from theme-style.php:
 * --gold, --gold2, --line, --text, --muted, --brand-primary, --brand-secondary,
 * --brand-bg, --font-heading, --font-body, --grid-gap, --card-radius,
 * --card-shadow, --image-radius
 */

.testi-grid {
    display: grid;
    gap: var(--grid-gap, 18px);
    grid-template-columns: repeat(var(--testi-cols-desktop, 4), 1fr);
}

.testi-card {
    min-width: 0;
}

.testi-stars {
    display: inline-flex;
    gap: 2px;
    color: var(--gold, #d4a25a);
    font-size: 14px;
    line-height: 1;
    margin-bottom: 10px;
}

.testi-author {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: auto;
}

.testi-author img {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    object-fit: cover;
    flex: none;
}

.testi-author strong {
    display: block;
    font-family: var(--font-heading, 'Montserrat', sans-serif);
    color: var(--text, #172233);
    font-size: var(--font-size-small, 12px);
    line-height: 1.3;
}

.testi-author small {
    display: block;
    color: var(--muted, #68717d);
    font-size: var(--font-size-small, 10px);
    line-height: 1.35;
    margin-top: 2px;
}

.testi-tpl-testi-1 .testi-card {
    border: 1px solid var(--line, #e8e4dd);
    border-radius: var(--card-radius, 4px);
    background: var(--brand-bg, #fff);
    padding: 18px;
    min-height: 166px;
    display: flex;
    flex-direction: column;
    transition: transform .3s ease, box-shadow .3s ease;
}

.testi-tpl-testi-1.testi-skin-dark .testi-card {
    border-color: rgba(255,255,255,.08);
    background: linear-gradient(145deg, var(--brand-primary, #07131f), var(--brand-secondary, #0c1b2a));
}

.testi-tpl-testi-1.testi-skin-dark p,
.testi-tpl-testi-1.testi-skin-dark .testi-author small {
    color: rgba(255,255,255,.72);
}

.testi-tpl-testi-1.testi-skin-dark .testi-author strong {
    color: #fff;
}

.testi-tpl-testi-1 .testi-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--card-shadow, 0 10px 30px rgba(0,0,0,.08));
}

.testi-tpl-testi-1 .testi-quote {
    color: var(--gold, #d4a25a);
    font-family: Georgia, serif;
    font-size: 38px;
    line-height: .7;
    margin-bottom: 8px;
}

.testi-tpl-testi-1 p {
    color: #3d4650;
    font-size: var(--font-size-small, 12px);
    line-height: 1.6;
    margin: 0 0 14px;
}

.testi-tpl-testi-2 .testi-card {
    border: 1px solid var(--line, #e8e4dd);
    border-radius: var(--card-radius, 6px);
    background: var(--brand-bg, #fff);
    padding: 20px;
    min-height: 220px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 12px 32px -26px rgba(13,30,52,.36);
}

.testi-tpl-testi-2.testi-skin-dark .testi-card {
    border-color: rgba(255,255,255,.08);
    background: #0f1c2b;
    box-shadow: 0 18px 40px -24px rgba(0,0,0,.5);
}

.testi-tpl-testi-2.testi-skin-dark p,
.testi-tpl-testi-2.testi-skin-dark .testi-author small {
    color: rgba(255,255,255,.68);
}

.testi-tpl-testi-2.testi-skin-dark .testi-author strong {
    color: #fff;
}

.testi-tpl-testi-2 .testi-author {
    order: -1;
    margin: 0 0 16px;
}

.testi-tpl-testi-2 .testi-author img {
    width: 52px;
    height: 52px;
    border: 3px solid #fff;
    box-shadow: 0 10px 22px rgba(15,23,42,.12);
}

.testi-tpl-testi-2 p {
    color: var(--muted, #68717d);
    font-size: var(--font-size-small, 12px);
    line-height: 1.7;
    margin: 0 0 16px;
}

.testi-tpl-testi-3 .testi-card {
    position: relative;
    overflow: hidden;
    border-radius: var(--card-radius, 8px);
    background: linear-gradient(145deg, var(--brand-primary, #07131f), var(--brand-secondary, #0c1b2a));
    color: #fff;
    padding: 22px;
    min-height: 230px;
    display: flex;
    flex-direction: column;
}

.testi-tpl-testi-3.testi-skin-light .testi-card {
    border: 1px solid rgba(212,162,90,.24);
    background: linear-gradient(180deg, #fff, #fbfaf7);
    color: var(--text, #172233);
}

.testi-tpl-testi-3.testi-skin-light p {
    color: var(--muted, #68717d);
}

.testi-tpl-testi-3.testi-skin-light .testi-author strong {
    color: var(--text, #172233);
}

.testi-tpl-testi-3.testi-skin-light .testi-author small {
    color: var(--muted, #68717d);
}

.testi-tpl-testi-3 .testi-card:before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 3px;
    background: linear-gradient(90deg, var(--gold, #d4a25a), var(--gold2, #c9983a));
}

.testi-tpl-testi-3 .testi-quote {
    color: rgba(212,162,90,.25);
    font-family: Georgia, serif;
    font-size: 72px;
    line-height: .7;
    margin: 4px 0 0;
}

.testi-tpl-testi-3 p {
    color: rgba(255,255,255,.82);
    font-size: var(--font-size-small, 12px);
    line-height: 1.75;
    margin: 0 0 18px;
}

.testi-tpl-testi-3 .testi-author strong {
    color: #fff;
}

.testi-tpl-testi-3 .testi-author small {
    color: rgba(255,255,255,.62);
}

.testi-tpl-testi-4 .testi-card {
    border-left: 3px solid var(--gold, #d4a25a);
    background: transparent;
    padding: 6px 18px 8px;
    min-height: 165px;
    display: flex;
    flex-direction: column;
}

.testi-tpl-testi-4.testi-skin-dark .testi-card {
    border-left-color: var(--gold, #d4a25a);
    background: #07131f;
    border-radius: var(--card-radius, 4px);
    padding: 18px;
}

.testi-tpl-testi-4.testi-skin-dark p,
.testi-tpl-testi-4.testi-skin-dark .testi-author small {
    color: rgba(255,255,255,.72);
}

.testi-tpl-testi-4.testi-skin-dark .testi-author strong {
    color: #fff;
}

.testi-tpl-testi-4 p {
    color: var(--text, #172233);
    font-size: var(--font-size-small, 12px);
    line-height: 1.7;
    margin: 0 0 16px;
}

.testi-tpl-testi-4 .testi-author img {
    width: 34px;
    height: 34px;
}

.testi-tpl-testi-5 .testi-card {
    border: 1px solid rgba(212,162,90,.26);
    border-radius: var(--card-radius, 8px);
    background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.95)),
        radial-gradient(circle at 12% 0, rgba(212,162,90,.18), transparent 38%);
    padding: 22px;
    min-height: 230px;
    display: flex;
    flex-direction: column;
    box-shadow: var(--card-shadow, 0 10px 30px rgba(0,0,0,.08));
}

.testi-tpl-testi-5.testi-skin-dark .testi-card {
    border-color: rgba(212,162,90,.22);
    background:
        linear-gradient(180deg, rgba(12,27,42,.96), rgba(7,19,31,.98)),
        radial-gradient(circle at 12% 0, rgba(212,162,90,.24), transparent 38%);
}

.testi-tpl-testi-5.testi-skin-dark .testi-stars {
    background: rgba(212,162,90,.14);
}

.testi-tpl-testi-5.testi-skin-dark p,
.testi-tpl-testi-5.testi-skin-dark .testi-author small {
    color: rgba(255,255,255,.72);
}

.testi-tpl-testi-5.testi-skin-dark .testi-author strong {
    color: #fff;
}

.testi-tpl-testi-5 .testi-stars {
    width: max-content;
    border-radius: 999px;
    background: #fff6e8;
    padding: 7px 9px;
}

.testi-tpl-testi-5 p {
    color: var(--muted, #68717d);
    font-size: var(--font-size-small, 12px);
    line-height: 1.75;
    margin: 0 0 18px;
}

@media (max-width: 1199px) {
    .testi-grid {
        grid-template-columns: repeat(var(--testi-cols-laptop, 3), 1fr);
    }
}

@media (max-width: 991px) {
    .testi-grid {
        grid-template-columns: repeat(var(--testi-cols-ipad, 2), 1fr);
    }
}

@media (max-width: 599px) {
    .testi-grid {
        grid-template-columns: repeat(var(--testi-cols-mobile, 1), 1fr);
    }
}
