/* =====================
   OPINIONI — compatibile tema chiaro/scuro
   ===================== */

.recensione-form-section {
  padding: 64px 20px;
  max-width: 600px;
  margin: 0 auto;
}

.form-container {
  border: 1px solid var(--border-strong);
  padding: 48px 52px;
  border-radius: var(--radius-lg);
  background: var(--bg-card);
  transition: background 0.4s ease;
}

.form-container h3 {
  font-family: 'Cinzel', serif;
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.14em;
  margin-bottom: 40px;
  text-align: center;
  color: var(--gold-bright);
}

.form-group { margin-bottom: 30px; }

.form-group label {
  display: block;
  margin-bottom: 10px;
  font-family: 'Cinzel', serif;
  font-size: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-dim);
}

.form-group input[type="text"],
.form-group textarea {
  width: 100%;
  padding: 10px 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border-strong);
  color: var(--text);
  font-size: 1.05rem;
  font-family: 'Cormorant Garamond', serif;
  transition: border-color var(--transition);
  border-radius: 0 !important;
  -webkit-appearance: none;
  appearance: none;
}

.form-group input[type="text"]:focus,
.form-group textarea:focus {
  outline: none;
  border-bottom-color: var(--gold-bright);
}

.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--text-dim); }

.form-group textarea { resize: vertical; min-height: 90px; }

#char-count {
  display: block;
  margin-top: 6px;
  font-size: 0.68rem;
  color: var(--text-dim);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.06em;
}

/* Stelle */
.stelle-input {
  display: flex;
  gap: 8px;
  font-size: 1.8rem;
  cursor: pointer;
}

.stella {
  color: var(--star-dim);
  transition: color 0.2s ease, transform 0.2s ease;
}

.stella:hover,
.stella.active {
  color: var(--star);
  transform: scale(1.15);
}

/* Bottone invia */
.btn-invia {
  width: 100%;
  padding: 14px;
  background: transparent;
  color: var(--gold);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-family: 'Cinzel', serif;
  font-size: 0.62rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  margin-top: 8px;
}

.btn-invia:hover {
  background: var(--gold);
  color: var(--bg);
}

.btn-invia:disabled { opacity: 0.3; cursor: not-allowed; background: transparent; color: var(--gold); }

/* Lista recensioni */
.recensioni-section {
  padding: 64px 20px 100px;
  max-width: 800px;
  margin: 0 auto;
}

.recensioni-section h3 {
  font-family: 'Cinzel', serif;
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.14em;
  text-align: center;
  margin-bottom: 44px;
  color: var(--gold-bright);
}

#loading {
  text-align: center;
  padding: 24px;
  color: var(--text-muted);
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
}

#recensioni-lista { display: flex; flex-direction: column; gap: 16px; }

/* Card recensione */
.recensione-card {
  background: var(--bg-card);
  color: var(--text);
  padding: 32px 38px;
  border-radius: 14px;
  border: 1px solid var(--border);
  border-left: 2px solid transparent;
  transition: background 0.4s ease, border-left-color var(--transition);
}

.recensione-card:hover {
  border-left-color: var(--gold-dim);
}

.recensione-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.recensione-nickname {
  font-family: 'Cinzel', serif;
  font-weight: 400;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.recensione-stelle {
  color: var(--star);
  font-size: 0.88rem;
  letter-spacing: 3px;
}

.recensione-testo {
  margin: 12px 0;
  color: var(--text-muted);
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.12rem;
  line-height: 1.8;
  font-style: italic;
  word-wrap: break-word;
}

.recensione-data {
  font-size: 0.62rem;
  color: var(--text-dim);
  margin-bottom: 18px;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.1em;
}

.recensione-actions { display: flex; gap: 12px; align-items: center; }

.btn-like,
.btn-dislike {
  background: transparent;
  border: 1px solid var(--border);
  padding: 6px 16px;
  border-radius: var(--radius);
  cursor: pointer;
  color: var(--text-dim);
  font-family: 'Cinzel', serif;
  font-size: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  transition: all var(--transition);
  display: flex;
  align-items: center;
  gap: 5px;
}

.btn-like:hover    { border-color: #5a9a6a; color: #5a9a6a; }
.btn-dislike:hover { border-color: #d47070; color: #d47070; }
.btn-like:disabled,
.btn-dislike:disabled { opacity: 0.25; cursor: not-allowed; }

@media (max-width: 768px) {
  .recensione-form-section,
  .recensioni-section { padding: 36px 16px; }
  .form-container { padding: 32px 24px; }
  .stelle-input { font-size: 1.5rem; }
  .recensione-card { padding: 24px 22px; }
}