/* CWS Suite — WooCommerce product reviews block
 * Ported from the Claude Design handoff (`reviews.css`), scoped to .cws-reviews-block
 * so it does not collide with the host theme. Tokens are declared on the wrapper
 * so the inline `style` from render() overrides cleanly.
 */

.cws-reviews-block {
    --acc-bg: #f6f7f9;
    --acc-surface: #ffffff;
    --acc-surface-alt: #fbfcfd;
    --acc-border: #e6e9ef;
    --acc-border-strong: #d6dbe3;
    --acc-text: #0b1220;
    --acc-text-2: #4a5468;
    --acc-text-3: #7a8398;
    --acc-text-muted: #9aa3b6;
    --acc-success: #0b8a5d;
    --acc-success-soft: #e7f6ef;
    --acc-danger: #c0392b;
    --acc-danger-soft: #fbeae7;
    --acc-radius: 12px;
    --acc-radius-sm: 8px;
    --acc-accent: #3b5bdb;
    --acc-accent-soft: #3b5bdb14;
    --rev-star: #e0a019;
    --rev-star-soft: #fbe9c2;

    font-family: 'Geist', 'Plus Jakarta Sans', ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
    color: var(--acc-text);
    font-size: 14px;
    line-height: 1.5;
    box-sizing: border-box;
}

.cws-reviews-block *,
.cws-reviews-block *::before,
.cws-reviews-block *::after { box-sizing: border-box; }

.cws-reviews-block button { font-family: inherit; }

/* ─── Primitives ─────────────────────────────────────────────────────────── */
.cws-reviews-block .acc-card {
    background: var(--acc-surface);
    border: 1px solid var(--acc-border);
    border-radius: var(--acc-radius);
}
.cws-reviews-block .acc-section {
    background: var(--acc-surface);
    border: 1px solid var(--acc-border);
    border-radius: var(--acc-radius);
    padding: 18px 20px;
    margin-top: 16px;
}

.cws-reviews-block .acc-btn {
    appearance: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 14px;
    border-radius: var(--acc-radius-sm);
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    border: 1px solid transparent;
    background: var(--acc-surface);
    color: var(--acc-text);
    transition: background .12s ease, color .12s ease, border-color .12s ease, transform .08s ease;
}
.cws-reviews-block .acc-btn:disabled { opacity: .55; cursor: not-allowed; }
.cws-reviews-block .acc-btn svg { display: block; }

.cws-reviews-block .acc-btn-primary {
    background: var(--acc-text);
    color: #fff;
    border-color: var(--acc-text);
}
.cws-reviews-block .acc-btn-primary:hover:not(:disabled) { background: #000; }

.cws-reviews-block .acc-btn-ghost {
    background: transparent;
    color: var(--acc-text-2);
    border-color: var(--acc-border);
}
.cws-reviews-block .acc-btn-ghost:hover:not(:disabled) {
    background: var(--acc-surface-alt);
    color: var(--acc-text);
    border-color: var(--acc-border-strong);
}

.cws-reviews-block .acc-btn-sm { padding: 7px 11px; font-size: 12px; }

.cws-reviews-block .acc-chip {
    appearance: none;
    cursor: pointer;
    background: transparent;
    border: 1px solid var(--acc-border);
    color: var(--acc-text-2);
    padding: 6px 11px;
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 500;
    transition: background .12s, color .12s, border-color .12s;
}
.cws-reviews-block .acc-chip:hover { background: var(--acc-surface-alt); color: var(--acc-text); border-color: var(--acc-border-strong); }
.cws-reviews-block .acc-chip.is-active { background: var(--acc-text); color: #fff; border-color: var(--acc-text); }

.cws-reviews-block .acc-input {
    width: 100%;
    appearance: none;
    background: var(--acc-surface);
    border: 1px solid var(--acc-border);
    color: var(--acc-text);
    border-radius: var(--acc-radius-sm);
    padding: 10px 12px;
    font-size: 13.5px;
    font-family: inherit;
    line-height: 1.4;
    transition: border-color .12s, box-shadow .12s;
}
.cws-reviews-block .acc-input:focus {
    outline: none;
    border-color: var(--acc-accent);
    box-shadow: 0 0 0 3px var(--acc-accent-soft);
}
.cws-reviews-block .acc-textarea { resize: vertical; min-height: 110px; }

.cws-reviews-block .acc-select-wrap {
    position: relative;
    display: inline-flex;
    min-width: 160px;
}
.cws-reviews-block .acc-select { padding-right: 32px; }
.cws-reviews-block .acc-select-chev {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--acc-text-3);
}

/* ─── Stars ──────────────────────────────────────────────────────────────── */
.cws-reviews-block .rev-stars { display: inline-flex; align-items: center; gap: 2px; color: var(--rev-star); }
.cws-reviews-block .rev-stars svg { display: block; }
.cws-reviews-block .rev-star-empty { color: var(--rev-star-soft); }
.cws-reviews-block .rev-stars-md svg { width: 16px; height: 16px; }
.cws-reviews-block .rev-stars-sm svg { width: 13px; height: 13px; }

/* ─── Summary card ───────────────────────────────────────────────────────── */
.cws-reviews-block .rev-summary {
    display: grid;
    grid-template-columns: minmax(220px, 280px) 1fr auto;
    gap: 32px;
    align-items: center;
    padding: 28px;
}
.cws-reviews-block .rev-score {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-right: 32px;
    border-right: 1px solid var(--acc-border);
}
.cws-reviews-block .rev-score-row { display: flex; align-items: baseline; gap: 8px; }
.cws-reviews-block .rev-score-num { font-size: 56px; font-weight: 600; letter-spacing: -.04em; line-height: .95; font-variant-numeric: tabular-nums; color: var(--acc-text); }
.cws-reviews-block .rev-score-out { font-size: 14px; color: var(--acc-text-3); font-variant-numeric: tabular-nums; }
.cws-reviews-block .rev-score-count { font-size: 12.5px; color: var(--acc-text-3); margin-top: 4px; }

.cws-reviews-block .rev-dist { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.cws-reviews-block .rev-dist-row {
    appearance: none;
    background: transparent;
    border: 0;
    padding: 4px 6px;
    border-radius: 8px;
    display: grid;
    grid-template-columns: 36px 1fr 44px;
    gap: 10px;
    align-items: center;
    cursor: pointer;
    text-align: left;
}
.cws-reviews-block .rev-dist-row:hover { background: var(--acc-surface-alt); }
.cws-reviews-block .rev-dist-row:hover .rev-dist-lbl { color: var(--acc-text); }
.cws-reviews-block .rev-dist-lbl { font-size: 12px; color: var(--acc-text-2); display: inline-flex; align-items: center; gap: 3px; font-variant-numeric: tabular-nums; transition: color .12s; }
.cws-reviews-block .rev-dist-lbl svg { width: 11px; height: 11px; color: var(--rev-star); }
.cws-reviews-block .rev-dist-bar { height: 8px; background: var(--acc-bg); border-radius: 999px; overflow: hidden; }
.cws-reviews-block .rev-dist-bar-fill { height: 100%; background: var(--rev-star); border-radius: 999px; transition: width .4s ease; display: block; }
.cws-reviews-block .rev-dist-row.is-active .rev-dist-bar-fill { background: var(--acc-text); }
.cws-reviews-block .rev-dist-count { font-size: 11.5px; color: var(--acc-text-3); text-align: right; font-variant-numeric: tabular-nums; }

.cws-reviews-block .rev-cta {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: stretch;
    min-width: 200px;
}
.cws-reviews-block .rev-cta .acc-btn { justify-content: center; }
.cws-reviews-block .rev-cta-meta { font-size: 11.5px; color: var(--acc-text-3); text-align: center; }

/* ─── Filter bar ─────────────────────────────────────────────────────────── */
.cws-reviews-block .rev-filter {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 6px 0 14px;
    border-bottom: 1px solid var(--acc-border);
    margin-bottom: 4px;
    flex-wrap: wrap;
}
.cws-reviews-block .rev-filter-l { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.cws-reviews-block .rev-filter-r { display: flex; align-items: center; gap: 8px; }
.cws-reviews-block .rev-filter-lbl { font-size: 11.5px; font-weight: 500; color: var(--acc-text-3); text-transform: uppercase; letter-spacing: .06em; margin-right: 4px; }

/* ─── Review list ────────────────────────────────────────────────────────── */
.cws-reviews-block .rev-list { display: flex; flex-direction: column; }
.cws-reviews-block .rev-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px 16px;
    padding: 22px 4px;
    border-bottom: 1px solid var(--acc-border);
}
.cws-reviews-block .rev-item:last-child { border-bottom: 0; }
.cws-reviews-block .rev-item.is-pending { opacity: .85; }
.cws-reviews-block .rev-item.is-pending .rev-name::after {
    content: attr(data-pending-badge);
    display: inline-block;
    margin-left: 8px;
    padding: 2px 8px;
    border-radius: 999px;
    background: var(--acc-warn-soft, #fdf2e2);
    color: var(--acc-warn, #b25e09);
    font-size: 10.5px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.cws-reviews-block .rev-avatar {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--acc-accent-soft); color: var(--acc-accent);
    display: grid; place-items: center;
    font-size: 13.5px; font-weight: 600; letter-spacing: -.01em;
    flex: none;
}
.cws-reviews-block .rev-avatar-1 { background: #eef2ff; color: #4338ca; }
.cws-reviews-block .rev-avatar-2 { background: #ecfdf5; color: #047857; }
.cws-reviews-block .rev-avatar-3 { background: #fef3c7; color: #b45309; }
.cws-reviews-block .rev-avatar-4 { background: #fdf2f8; color: #be185d; }
.cws-reviews-block .rev-avatar-5 { background: #ecfeff; color: #0e7490; }
.cws-reviews-block .rev-avatar-6 { background: #f5f3ff; color: #6d28d9; }

.cws-reviews-block .rev-body { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.cws-reviews-block .rev-head { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.cws-reviews-block .rev-name { font-size: 13.5px; font-weight: 600; color: var(--acc-text); }
.cws-reviews-block .rev-verified {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 11px; color: var(--acc-success); font-weight: 500;
}
.cws-reviews-block .rev-verified svg { width: 11px; height: 11px; }

.cws-reviews-block .rev-stars-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cws-reviews-block .rev-date { font-size: 11.5px; color: var(--acc-text-3); }
.cws-reviews-block .rev-title { font-size: 14px; font-weight: 600; letter-spacing: -.005em; color: var(--acc-text); }
.cws-reviews-block .rev-text {
    font-size: 13.5px;
    color: var(--acc-text-2);
    line-height: 1.6;
    margin: 0;
    white-space: pre-wrap;
}

.cws-reviews-block .rev-no-match {
    padding: 36px 0;
    text-align: center;
    color: var(--acc-text-3);
    font-size: 13px;
}

/* ─── Pagination ─────────────────────────────────────────────────────────── */
.cws-reviews-block .rev-pager { display: flex; justify-content: center; align-items: center; gap: 8px; padding: 22px 0 4px; }
.cws-reviews-block .rev-pager-info { font-size: 12px; color: var(--acc-text-3); margin: 0 8px; font-variant-numeric: tabular-nums; }

/* ─── Empty state ────────────────────────────────────────────────────────── */
.cws-reviews-block .rev-empty {
    text-align: center;
    padding: 60px 24px 50px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}
.cws-reviews-block .rev-empty-stars { color: var(--rev-star-soft); display: flex; justify-content: center; gap: 4px; margin-bottom: 4px; }
.cws-reviews-block .rev-empty-stars svg { width: 26px; height: 26px; }
.cws-reviews-block .rev-empty-title { font-size: 17px; font-weight: 600; letter-spacing: -.01em; }
.cws-reviews-block .rev-empty-body { font-size: 13px; color: var(--acc-text-3); max-width: 36ch; margin: 0 auto; }

/* ─── Write-a-review ─────────────────────────────────────────────────────── */
.cws-reviews-block .rev-write {
    margin-top: 18px;
    padding: 0;
    overflow: hidden;
}
.cws-reviews-block .rev-write-collapsed {
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    padding: 22px 26px;
    background: linear-gradient(180deg, var(--acc-surface), var(--acc-surface-alt));
    cursor: pointer;
}
.cws-reviews-block .rev-write-collapsed:hover { background: var(--acc-surface-alt); }
.cws-reviews-block .rev-write-prompt-l { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.cws-reviews-block .rev-write-prompt-title { font-size: 15px; font-weight: 600; letter-spacing: -.01em; }
.cws-reviews-block .rev-write-prompt-sub { font-size: 12.5px; color: var(--acc-text-3); }

.cws-reviews-block .rev-write-open[hidden] { display: none; }
.cws-reviews-block .rev-write-open {
    padding: 26px;
    display: flex;
    flex-direction: column;
    gap: 22px;
}
.cws-reviews-block .rev-write-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.cws-reviews-block .rev-write-head h3 { font-size: 16px; font-weight: 600; letter-spacing: -.01em; margin: 0; }
.cws-reviews-block .rev-write-head p { font-size: 12.5px; color: var(--acc-text-3); margin: 4px 0 0; }
.cws-reviews-block .rev-write-close {
    appearance: none;
    border: 1px solid var(--acc-border);
    background: var(--acc-surface);
    color: var(--acc-text-2);
    width: 28px; height: 28px; border-radius: 8px;
    display: grid; place-items: center; cursor: pointer;
}

.cws-reviews-block .rev-rate-pick {
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
    padding: 16px 18px;
    background: var(--acc-surface-alt);
    border: 1px solid var(--acc-border);
    border-radius: 10px;
}
.cws-reviews-block .rev-rate-pick-lbl { font-size: 13px; font-weight: 500; }
.cws-reviews-block .rev-rate-stars { display: inline-flex; gap: 4px; }
.cws-reviews-block .rev-rate-star {
    appearance: none; border: 0; background: transparent; cursor: pointer;
    padding: 2px; color: var(--rev-star-soft);
    transition: transform .1s ease, color .1s ease;
}
.cws-reviews-block .rev-rate-star:hover { transform: scale(1.08); }
.cws-reviews-block .rev-rate-star.is-on { color: var(--rev-star); }
.cws-reviews-block .rev-rate-star svg { width: 28px; height: 28px; display: block; }
.cws-reviews-block .rev-rate-readout { font-size: 12.5px; color: var(--acc-text-3); font-weight: 500; min-width: 80px; }
.cws-reviews-block .rev-rate-readout-strong { color: var(--acc-text); }

.cws-reviews-block .rev-write-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.cws-reviews-block .rev-write-col-2 { grid-column: span 2; }
.cws-reviews-block .rev-write-field { display: flex; flex-direction: column; gap: 6px; }
.cws-reviews-block .rev-write-label { font-size: 12.5px; font-weight: 500; color: var(--acc-text-2); }
.cws-reviews-block .rev-write-label em { color: var(--acc-danger); font-style: normal; }
.cws-reviews-block .rev-write-hint { font-size: 11.5px; color: var(--acc-text-3); }

.cws-reviews-block .rev-write-status {
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 12.5px;
    line-height: 1.5;
}
.cws-reviews-block .rev-write-status.is-success { background: var(--acc-success-soft); color: var(--acc-success); }
.cws-reviews-block .rev-write-status.is-error   { background: var(--acc-danger-soft); color: var(--acc-danger); }

.cws-reviews-block .rev-write-locked {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 14px;
    border-radius: 10px;
    background: var(--acc-surface-alt);
    color: var(--acc-text-2);
    font-size: 12.5px;
}

.cws-reviews-block .rev-write-foot {
    display: flex; justify-content: space-between; align-items: center; gap: 12px;
    padding-top: 18px; border-top: 1px solid var(--acc-border);
}
.cws-reviews-block .rev-write-foot-info { font-size: 11.5px; color: var(--acc-text-3); display: flex; align-items: center; gap: 6px; }
.cws-reviews-block .rev-write-foot-actions { display: flex; gap: 8px; }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .cws-reviews-block .rev-summary {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 22px;
    }
    .cws-reviews-block .rev-score {
        border-right: 0;
        padding-right: 0;
        padding-bottom: 18px;
        border-bottom: 1px solid var(--acc-border);
        align-items: center;
        text-align: center;
    }
    .cws-reviews-block .rev-score-row { justify-content: center; }
    .cws-reviews-block .rev-score-num { font-size: 48px; }
    .cws-reviews-block .rev-stars { justify-content: center; }
    .cws-reviews-block .rev-cta { min-width: 0; }

    .cws-reviews-block .rev-filter {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }
    .cws-reviews-block .rev-filter-l {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 4px;
    }
    .cws-reviews-block .rev-filter-l::-webkit-scrollbar { display: none; }
    .cws-reviews-block .rev-filter-l .acc-chip { white-space: nowrap; flex: 0 0 auto; }
    .cws-reviews-block .rev-filter-r { justify-content: space-between; }
    .cws-reviews-block .rev-filter-r .acc-select-wrap { flex: 1; }

    .cws-reviews-block .rev-item { padding: 18px 0; gap: 10px 12px; }
    .cws-reviews-block .rev-avatar { width: 34px; height: 34px; font-size: 12px; }
    .cws-reviews-block .rev-title { font-size: 13.5px; }
    .cws-reviews-block .rev-text { font-size: 13px; line-height: 1.55; }

    .cws-reviews-block .rev-write-collapsed { padding: 18px; flex-direction: column; align-items: stretch; gap: 12px; }
    .cws-reviews-block .rev-write-open { padding: 18px; gap: 16px; }
    .cws-reviews-block .rev-rate-pick { flex-direction: column; align-items: flex-start; gap: 10px; padding: 14px; }
    .cws-reviews-block .rev-rate-star svg { width: 32px; height: 32px; }
    .cws-reviews-block .rev-write-grid { grid-template-columns: 1fr; }
    .cws-reviews-block .rev-write-col-2 { grid-column: 1; }
    .cws-reviews-block .rev-write-foot { flex-direction: column-reverse; align-items: stretch; }
    .cws-reviews-block .rev-write-foot-actions { width: 100%; }
    .cws-reviews-block .rev-write-foot-actions .acc-btn { flex: 1; }

    .cws-reviews-block .rev-pager { padding: 16px 0 0; flex-wrap: wrap; }
}
