/* Reviews Page Styles - ZapchShoPL */
.reviews-hero {
  background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-dark) 100%);
  padding: var(--space-16) 0 var(--space-10);
}
.hero-inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-8); align-items: center; }
.hero-copy h1 { margin-bottom: var(--space-3); }
.hero-copy p { margin-bottom: var(--space-4); }
.hero-rating { display: flex; align-items: center; gap: var(--space-4); margin-bottom: var(--space-4); }
.rating-stars { color: var(--color-accent); letter-spacing: 2px; font-weight: var(--font-weight-bold); }
.hero-stats { color: var(--color-text-secondary); }
.hero-ctas { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.hero-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }

@media (max-width: 1024px) { .hero-inner { grid-template-columns: 1fr; } }

.review-highlight { padding: var(--space-12) 0; }
.highlight-card .card-body { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-6); align-items: center; }
.highlight-media img { border-radius: var(--radius-lg); }
.highlight-product { color: var(--color-text-secondary); margin-bottom: var(--space-2); }
.highlight-rating { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }
.badge-verified { display: inline-flex; align-items: center; gap: var(--space-2); background: var(--color-success-light); color: var(--color-success-dark); padding: 0.25rem 0.5rem; border-radius: var(--radius-full); font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); text-transform: uppercase; letter-spacing: var(--letter-spacing-wide); }
.highlight-text { font-style: italic; color: var(--color-text-primary); margin-bottom: var(--space-2); }
.highlight-meta { color: var(--color-text-muted); font-size: var(--font-size-sm); }
@media (max-width: 1024px) { .highlight-card .card-body { grid-template-columns: 1fr; } }

.reviews-aggregate { padding: var(--space-8) 0; background: var(--color-surface); }
.aggregate-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
.aggregate-item { background: var(--color-background); border: var(--border-width) solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-6); text-align: center; box-shadow: var(--shadow-sm); }
.aggregate-label { color: var(--color-text-muted); font-size: var(--font-size-sm); margin-bottom: var(--space-2); text-transform: uppercase; letter-spacing: var(--letter-spacing-wide); }
.aggregate-value { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); color: var(--color-text-primary); }
@media (max-width: 1024px) { .aggregate-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .aggregate-grid { grid-template-columns: 1fr; } }

.reviews-controls { padding: var(--space-10) 0 var(--space-6); }
.controls-form .controls-row { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-6); align-items: end; }
.controls-form .w-full { grid-column: 1 / -1; }
@media (max-width: 1024px) { .controls-form .controls-row { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .controls-form .controls-row { grid-template-columns: 1fr; } }

.reviews-list { padding: var(--space-6) 0 var(--space-12); }
.reviews-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
@media (max-width: 1024px) { .reviews-grid { grid-template-columns: 1fr; } }
.review-head { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-2); }
.review-meta { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; color: var(--color-text-muted); font-size: var(--font-size-sm); }
.review-info { color: var(--color-text-muted); }
.review-media img { margin-top: var(--space-3); border-radius: var(--radius-md); }
.review-actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); }
.review-response { margin-top: var(--space-4); padding: var(--space-4); background: var(--color-surface); border-radius: var(--radius-md); border: var(--border-width) solid var(--color-border); }

.reviews-submit { padding: var(--space-12) 0; background: var(--color-surface); }
.submit-form { margin-top: var(--space-4); }
.rating-fieldset .rating-input { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.rating-fieldset input { position: absolute; left: -9999px; }
.rating-fieldset label { cursor: pointer; padding: 0.25rem 0.5rem; border-radius: var(--radius-md); border: var(--border-width) solid var(--color-border); color: var(--color-accent-dark); background: var(--color-background); }
.rating-fieldset input:focus + label, .rating-fieldset label:focus { outline: var(--focus-ring-width) solid var(--color-border-focus); outline-offset: var(--focus-ring-offset); }
.rating-fieldset input:checked + label { background: var(--color-accent); border-color: var(--color-accent); color: var(--color-text-primary); font-weight: var(--font-weight-bold); }
.submit-actions { margin-top: var(--space-4); display: flex; align-items: center; gap: var(--space-3); }
.submit-status { color: var(--color-text-secondary); font-size: var(--font-size-sm); }

.reviews-guidelines { padding: var(--space-12) 0; }
.guidelines-list { list-style: disc inside; color: var(--color-text-secondary); display: grid; gap: var(--space-2); }
.guidelines-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); margin-top: var(--space-4); }

.reviews-aggregation { padding: var(--space-10) 0 var(--space-12); }
.aggregate-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
@media (max-width: 1024px) { .aggregate-cards { grid-template-columns: 1fr; } }

/* Utility enhancement for rating stars shown in summaries */
.rating-stars[aria-label] { font-variant-numeric: tabular-nums; }

/* Hide elements when filtered out */
.review-card[hidden] { display: none !important; }
