/* Two-tier reviews — service + product. Tied to single-listing.php and single-amazon_product.php. */

.petsomo-reviews-section { margin-top: 48px; }
.petsomo-reviews-section h2 { margin-bottom: 16px; }

.petsomo-review-list { list-style: none; padding: 0; margin: 0 0 24px; display: grid; gap: 16px; }
.petsomo-review-item { background: var(--surface-strong, #fff); border: 1px solid var(--sand, #dce9ff); border-radius: 12px; padding: 16px 18px; }
.petsomo-review-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.petsomo-review-stars { color: #f5a623; letter-spacing: 1px; font-size: 16px; }
.petsomo-review-verified { background: #eaf6ec; color: #1f7a3a; font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.5px; }
.petsomo-review-title { margin: 4px 0 6px; font-size: 16px; }
.petsomo-review-body { color: var(--ink, #163152); line-height: 1.55; }
.petsomo-review-empty { color: var(--muted, #4a6387); font-style: italic; }
.petsomo-review-self-note { color: var(--muted, #4a6387); font-size: 14px; margin-top: 12px; }

.petsomo-review-form-toggle { margin-top: 12px; }
.petsomo-review-form-toggle > summary { cursor: pointer; list-style: none; display: inline-block; }
.petsomo-review-form-toggle[open] > summary { margin-bottom: 16px; }

.petsomo-review-form { display: grid; gap: 14px; padding: 18px; background: var(--surface, #f8fbff); border: 1px solid var(--sand, #dce9ff); border-radius: 12px; }
.petsomo-review-field { display: grid; gap: 6px; }
.petsomo-review-field span { font-weight: 600; font-size: 14px; color: var(--ink, #163152); }
.petsomo-review-field input[type="text"],
.petsomo-review-field input[type="number"],
.petsomo-review-field input[type="date"],
.petsomo-review-field textarea,
.petsomo-review-field select,
.petsomo-review-grid input,
.petsomo-review-grid select,
.petsomo-review-vertical select,
.petsomo-review-vertical input[type="number"] {
	width: 100%;
	padding: 8px 10px;
	border: 1px solid var(--sand, #dce9ff);
	border-radius: 8px;
	font: inherit;
	background: #fff;
}
.petsomo-review-field textarea { resize: vertical; min-height: 100px; }

.petsomo-star-input { display: flex; flex-direction: row-reverse; justify-content: flex-end; gap: 0; }
.petsomo-star-input label { padding: 4px 6px; cursor: pointer; color: var(--muted, #4a6387); font-size: 18px; }
.petsomo-star-input input { position: absolute; opacity: 0; width: 1px; height: 1px; }
.petsomo-star-input label:hover,
.petsomo-star-input label:hover ~ label,
.petsomo-star-input input:checked ~ label { color: #f5a623; }

.petsomo-review-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.petsomo-review-grid label { display: grid; gap: 4px; font-size: 14px; }

.petsomo-review-vertical { border: 1px dashed var(--sand, #dce9ff); border-radius: 10px; padding: 12px 14px; display: grid; gap: 8px; }
.petsomo-review-vertical legend { padding: 0 6px; font-weight: 600; font-size: 13px; color: var(--muted, #4a6387); }
.petsomo-review-vertical label { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.petsomo-review-vertical label.checkbox-row input { width: auto; }

.petsomo-review-help { color: var(--muted, #4a6387); font-size: 12px; }
.petsomo-review-actions { display: flex; align-items: center; gap: 14px; }
.petsomo-review-status { font-size: 14px; }

.petsomo-affiliate-disclosure { font-size: 12px; color: var(--muted, #4a6387); margin-top: 24px; padding-top: 12px; border-top: 1px dashed var(--sand, #dce9ff); }

@media (max-width: 600px) {
	.petsomo-review-form { padding: 14px; }
	.petsomo-star-input label { font-size: 22px; padding: 6px 4px; }
}
