/* === CARTES & GRILLE D’AVIS === */
.sym-avis-card {
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 12px;
  margin: 10px 0;
  background: #fff;
}

.sym-avis-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}

.sym-avis-stars {
  font-size: 14px;
  line-height: 1;
}

.sym-avis-meta {
  color: #777;
  font-size: 12px;
  margin-top: 4px;
}

/* === PHOTOS === */
.sym-avis-photos {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.sym-avis-photos img {
  max-width: 96px;
  height: auto;
  border-radius: 6px;
  border: 1px solid #eee;
}

/* Vignettes carrées avec zoom */
.sym-avis-photos img.sym-avis-thumb {
  max-width: 96px;
  width: 96px;
  height: 96px;
  object-fit: cover;
  border-radius: 6px;
  border: 1px solid #eee;
  cursor: zoom-in;
}

/* === FORMULAIRE === */
.sym-avis-form,
.sym-avis-form * {
  box-sizing: border-box;
}

.sym-avis-form {
  border: 1px solid #e6e8ec;
  background: #fafafa;
  border-radius: 10px;
  padding: 14px;
  max-width: 100%;
  overflow-wrap: anywhere;
}

/* Lignes de formulaire */
.sym-avis-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin: 8px 0;
}

.sym-avis-row > *:not(label) {
  flex: 1 1 auto;
  min-width: 0;
}

.sym-avis-row label {
  min-width: 200px;
  font-weight: 600;
}

.sym-avis-row select,
.sym-avis-row textarea,
.sym-avis-row input[type="file"] {
  max-width: 100%;
  width: 100%;
}

#avis_comment {
  width: 100%;
}

.sym-avis-row input[type="file"] {
  display: block;
}

/* Zone d’actions (bouton + message) */
.sym-avis-actions {
  margin-top: 12px;
  display: flex;
  gap: 10px;
  align-items: center;
}

/* États du formulaire */
.sym-avis-success {
  background: #e8f7ee;
  border: 1px solid #bfe8cf;
  color: #186a3b;
  padding: 10px;
  border-radius: 8px;
  margin: 10px 0;
}

.sym-avis-error {
  background: #fff1f1;
  border: 1px solid #ffcccc;
  color: #a00;
  padding: 10px;
  border-radius: 8px;
  margin: 10px 0;
}

/* === LIGHTBOX === */
#sym-avis-lightbox {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}

#sym-avis-lightbox.open {
  display: block;
}

#sym-avis-lightbox .sym-avis-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

#sym-avis-lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
}

#sym-avis-lightbox #sym-avis-lightbox-close {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: none;
  background: #fff;
  font-size: 22px;
  line-height: 38px;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}

#sym-avis-lightbox #sym-avis-lightbox-close:hover {
  transform: scale(1.06);
}

/* === COMPTEUR COMMENTAIRE === */
#avis_comment_count {
  font-variant-numeric: tabular-nums;
}

/* === RESPONSIVE MOBILE === */
@media (max-width: 640px) {
  .sym-avis-row {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }

  .sym-avis-row label {
    min-width: 0;
    width: 100%;
    margin: 0 0 2px 0;
  }

  .sym-avis-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  
  /* Bouton "Envoyer mon avis" : bordure au repos, pas de bordure au hover */
.sym-avis-actions #avis_submit_btn.stl-btn {
  border: 1px solid #60b339;
}

.sym-avis-actions #avis_submit_btn.stl-btn:hover {
  border: none;
}

  .sym-avis-row label input[type="radio"],
  .sym-avis-row label input[type="checkbox"] {
    margin-right: 6px;
  }
}


.sym-avis-stats-wrapper {
  margin: 1.5rem 0;
}

.sym-avis-stats-card {
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  padding: 16px 18px;
  background: #fafafa;
  max-width: 480px;
}

.sym-avis-stats-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.sym-avis-stats-score-number {
  font-size: 2rem;
  font-weight: 700;
  margin-right: 8px;
}

.sym-avis-stats-score-stars {
  font-size: 1.4rem;
  letter-spacing: 1px;
}

.sym-avis-stats-meta {
  font-size: 0.9rem;
  color: #555;
}

.sym-avis-stats-count {
  font-weight: 500;
}

.sym-avis-stats-sub {
  font-size: 0.9rem;
  color: #333;
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(160px,1fr));
  gap: 4px 16px;
}

.sym-avis-stats-loading,
.sym-avis-stats-error,
.sym-avis-stats-empty {
  font-size: 0.95rem;
  color: #555;
}

.sym-avis-stats-label{
  font-size: 12px;
  opacity: .8;
  margin-bottom: 4px;
}
.sym-avis-stats-score-criteria{
  margin-left: 18px; /* si tu veux 2 blocs côte à côte */
}
@media (max-width: 480px){
  .sym-avis-stats-score-criteria{ margin-left: 0; }
}

.sym-avis-stats-score{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 140px;
}

