/* FreshMart · Reviews · template-4 — 0.0 avg block + 5-row star bars + Submit form */

.review-4 {
    background: var(--bs-bg-surface, var(--bs-body-bg));
    border: 1px solid var(--bs-border-color, var(--bs-border-color));
    border-radius: 0.75rem;
    padding: 28px;
    margin: 24px 0;
}

.review-4-aggregate {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 40px;
    align-items: start;
}

.review-4-aggregate-score { text-align: left; }

.review-4-score-value {
    font-family: var(--bs-heading-font-family, Manrope, Inter, sans-serif);
    font-size: 3rem;
    font-weight: 700;
    color: var(--bs-body-color, var(--bs-body-color));
    line-height: 1;
    margin-bottom: 4px;
}

.review-4-score-label {
    font-size: 0.9375rem;
    color: var(--bs-body-color, var(--bs-body-color));
    font-weight: 600;
    margin-bottom: 6px;
}

.review-4-score-stars-track {
    position: relative;
    width: 110px;
    height: 18px;
    background: var(--bs-border-color, var(--bs-border-color));
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 110 18'%3E%3Cg fill='%23000'%3E%3Cpolygon points='11,0 13.6,6 20,6.4 15,10.4 16.8,17 11,13.8 5.2,17 7,10.4 2,6.4 8.4,6'/%3E%3Cpolygon points='33,0 35.6,6 42,6.4 37,10.4 38.8,17 33,13.8 27.2,17 29,10.4 24,6.4 30.4,6'/%3E%3Cpolygon points='55,0 57.6,6 64,6.4 59,10.4 60.8,17 55,13.8 49.2,17 51,10.4 46,6.4 52.4,6'/%3E%3Cpolygon points='77,0 79.6,6 86,6.4 81,10.4 82.8,17 77,13.8 71.2,17 73,10.4 68,6.4 74.4,6'/%3E%3Cpolygon points='99,0 101.6,6 108,6.4 103,10.4 104.8,17 99,13.8 93.2,17 95,10.4 90,6.4 96.4,6'/%3E%3C/g%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 110 18'%3E%3Cg fill='%23000'%3E%3Cpolygon points='11,0 13.6,6 20,6.4 15,10.4 16.8,17 11,13.8 5.2,17 7,10.4 2,6.4 8.4,6'/%3E%3Cpolygon points='33,0 35.6,6 42,6.4 37,10.4 38.8,17 33,13.8 27.2,17 29,10.4 24,6.4 30.4,6'/%3E%3Cpolygon points='55,0 57.6,6 64,6.4 59,10.4 60.8,17 55,13.8 49.2,17 51,10.4 46,6.4 52.4,6'/%3E%3Cpolygon points='77,0 79.6,6 86,6.4 81,10.4 82.8,17 77,13.8 71.2,17 73,10.4 68,6.4 74.4,6'/%3E%3Cpolygon points='99,0 101.6,6 108,6.4 103,10.4 104.8,17 99,13.8 93.2,17 95,10.4 90,6.4 96.4,6'/%3E%3C/g%3E%3C/svg%3E");
}

.review-4-score-stars-fill { height: 100%; width: 0; background: var(--bs-warning); }

.review-4-score-count {
    font-size: 0.8125rem;
    color: var(--bs-secondary-color, var(--bs-secondary-color));
    margin: 4px 0;
}

.review-4-score-recommend {
    font-family: var(--bs-heading-font-family, Manrope, Inter, sans-serif);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--bs-body-color, var(--bs-body-color));
}

.review-4-score-recommend span {
    font-size: 0.8125rem;
    font-weight: 400;
    color: var(--bs-secondary-color, var(--bs-secondary-color));
}

/* Star bars */
.review-4-bars { display: flex; flex-direction: column; gap: 8px; }

.review-4-bar {
    display: grid;
    grid-template-columns: 100px 1fr 40px;
    gap: 10px;
    align-items: center;
}

.review-4-bar-stars { display: inline-flex; gap: 2px; }

.review-4-bar-track {
    height: 6px;
    background: var(--bs-bg-alt, var(--bs-secondary-bg));
    border-radius: 999px;
    overflow: hidden;
    position: relative;
}

.review-4-bar-fill { position: absolute; inset: 0; background: var(--bs-warning); width: 0; }

.review-4-bar-pct { font-size: 0.75rem; color: var(--bs-secondary-color, var(--bs-secondary-color)); text-align: right; }

/* Submit form */
.review-4-submit-wrap {
    grid-column: 1 / -1;
    padding-top: 28px;
    margin-top: 12px;
    border-top: 1px solid var(--bs-border-color, var(--bs-border-color));
}

.review-4-submit-title {
    font-family: var(--bs-heading-font-family, Manrope, Inter, sans-serif);
    font-size: 1.125rem;
    font-weight: 700;
    margin: 0 0 4px;
    color: var(--bs-body-color, var(--bs-body-color));
    position: relative;
    display: inline-block;
    padding-bottom: 6px;
}

.review-4-submit-title::after {
    content: '';
    position: absolute;
    left: 0; bottom: 0;
    width: 42px;
    height: 2px;
    background: var(--bs-primary, var(--bs-border-accent));
    border-radius: 2px;
}

.review-4-submit-note {
    margin: 0 0 14px;
    font-size: 0.8125rem;
    color: var(--bs-secondary-color, var(--bs-secondary-color));
}

.review-4-form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 6px;
    color: var(--bs-body-color, var(--bs-body-color));
}

.review-4-form-input {
    display: block;
    width: 100%;
    padding: 12px 14px;
    font-size: 0.9375rem;
    border: 1px solid var(--bs-border-color, var(--bs-border-color));
    border-radius: 0.5rem;
    background: var(--bs-bg-surface, var(--bs-body-bg));
    color: var(--bs-body-color, var(--bs-body-color));
    box-sizing: border-box;
    resize: vertical;
    margin-bottom: 14px;
}

.review-4-form-input:focus { outline: 0; border-color: var(--bs-primary, var(--bs-border-accent)); box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb, 232, 106, 28), 0.15); }

.review-4-form-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.review-4-form-select {
    padding: 10px 14px;
    font-size: 0.9375rem;
    border: 1px solid var(--bs-border-color, var(--bs-border-color));
    border-radius: 0.5rem;
    background: var(--bs-bg-surface, var(--bs-body-bg));
    min-width: 200px;
}

.review-4-form-submit {
    padding: 12px 28px;
    background: var(--bs-secondary, var(--bs-secondary));
    color: var(--bs-body-bg);
    border: 0;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    cursor: pointer;
    margin-left: auto;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
}

.review-4-form-submit:hover { background: #0A2A1B; color: var(--bs-body-bg); }

/* Review card */
.review-4-list { margin-top: 24px; display: flex; flex-direction: column; gap: 14px; }

.review-4-card { padding: 16px; background: var(--bs-bg-alt, var(--bs-secondary-bg)); border-radius: 0.5rem; }

.review-4-card-head { display: flex; gap: 10px; align-items: center; margin-bottom: 8px; }

.review-4-avatar {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--bs-primary, var(--bs-border-accent));
    color: var(--bs-body-bg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    text-transform: uppercase;
}

.review-4-author { display: block; font-weight: 600; color: var(--bs-body-color, var(--bs-body-color)); font-size: 0.9375rem; }

.review-4-meta { display: flex; align-items: center; gap: 8px; }

.review-4-stars-track {
    width: 90px; height: 14px;
    background: var(--bs-border-color, var(--bs-border-color));
    display: inline-block;
    position: relative;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 90 14'%3E%3Cg fill='%23000'%3E%3Cpolygon points='9,0 11,4.5 16,4.8 12,8.2 13.5,13 9,10.6 4.5,13 6,8.2 2,4.8 7,4.5'/%3E%3Cpolygon points='27,0 29,4.5 34,4.8 30,8.2 31.5,13 27,10.6 22.5,13 24,8.2 20,4.8 25,4.5'/%3E%3Cpolygon points='45,0 47,4.5 52,4.8 48,8.2 49.5,13 45,10.6 40.5,13 42,8.2 38,4.8 43,4.5'/%3E%3Cpolygon points='63,0 65,4.5 70,4.8 66,8.2 67.5,13 63,10.6 58.5,13 60,8.2 56,4.8 61,4.5'/%3E%3Cpolygon points='81,0 83,4.5 88,4.8 84,8.2 85.5,13 81,10.6 76.5,13 78,8.2 74,4.8 79,4.5'/%3E%3C/g%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 90 14'%3E%3Cg fill='%23000'%3E%3Cpolygon points='9,0 11,4.5 16,4.8 12,8.2 13.5,13 9,10.6 4.5,13 6,8.2 2,4.8 7,4.5'/%3E%3Cpolygon points='27,0 29,4.5 34,4.8 30,8.2 31.5,13 27,10.6 22.5,13 24,8.2 20,4.8 25,4.5'/%3E%3Cpolygon points='45,0 47,4.5 52,4.8 48,8.2 49.5,13 45,10.6 40.5,13 42,8.2 38,4.8 43,4.5'/%3E%3Cpolygon points='63,0 65,4.5 70,4.8 66,8.2 67.5,13 63,10.6 58.5,13 60,8.2 56,4.8 61,4.5'/%3E%3Cpolygon points='81,0 83,4.5 88,4.8 84,8.2 85.5,13 81,10.6 76.5,13 78,8.2 74,4.8 79,4.5'/%3E%3C/g%3E%3C/svg%3E");
}

.review-4-stars-fill { position: absolute; inset: 0 auto 0 0; height: 100%; background: var(--bs-warning); width: 0; }

.review-4-date { font-size: 0.75rem; color: var(--bs-secondary-color, var(--bs-secondary-color)); }

.review-4-title { font-size: 0.9375rem; font-weight: 700; margin: 4px 0 6px; color: var(--bs-body-color, var(--bs-body-color)); }

.review-4-body { font-size: 0.9375rem; color: var(--bs-body-color, var(--bs-body-color)); margin: 0; line-height: 1.5; }

.review-4-load-more { text-align: center; margin-top: 20px; }

.review-4-load-btn {
    padding: 10px 24px;
    border: 1px solid var(--bs-primary, var(--bs-border-accent));
    background: transparent;
    color: var(--bs-primary, var(--bs-border-accent));
    border-radius: 999px;
    font-weight: 600;
    cursor: pointer;
    font-size: 0.875rem;
}

.review-4-load-btn:hover { background: var(--bs-primary, var(--bs-border-accent)); color: var(--bs-body-bg); }

@media (max-width: 767.98px) {
    .review-4 { padding: 20px; }
    .review-4-aggregate { grid-template-columns: 1fr; gap: 24px; }
    .review-4-form-submit { margin-left: 0; }
}
