/*
===============================================
🍽️ PUBLIC.CSS — GCS Restaurant WiFi Feedback
Descrizione: Stili frontend per pagina WiFi + feedback
Data creazione: 2026-02-23
===============================================
*/

.gcs-rwf{ font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; padding: 18px; background: var(--rwf-secondary); }
.gcs-rwf-card{ max-width: 520px; margin: 0 auto; background: #fff; border-radius: 18px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.gcs-rwf-hero{
  position: relative;
  height: 220px;
  background-size: cover;
  background-position: center;
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
  overflow: hidden;
}


.gcs-rwf-inner{ padding: 18px; }
.gcs-rwf-logo{ max-height: 54px; display: block; margin: 0 0 12px; }
.gcs-rwf-title{ font-size: 22px; line-height: 1.15; margin: 0 0 8px; color: #111; }
.gcs-rwf-subtitle{ margin: 0 0 14px; color: #444; }
.gcs-rwf-form{ display: grid; gap: 12px; }
.gcs-rwf-field label{ display:block; font-size: 13px; color:#333; margin-bottom: 6px; }
.gcs-rwf-field input{ width:100%; padding: 12px 12px; border: 1px solid #ddd; border-radius: 12px; }
.gcs-rwf-check{ font-size: 13px; color:#333; }
.gcs-rwf-check a{ color: var(--rwf-primary); }
.gcs-rwf-btn{ width:100%; padding: 14px 16px; border: 0; border-radius: 14px; background: var(--rwf-primary); color:#fff; font-weight: 700; cursor:pointer; }
.gcs-rwf-alert{ background: #fff3cd; border: 1px solid #ffe69c; color:#664d03; padding: 10px 12px; border-radius: 12px; margin: 0 0 12px; }
.gcs-rwf-cred{ background:#f7f7f7; border: 1px solid #eee; padding: 12px; border-radius: 14px; display:grid; gap: 6px; margin: 14px 0; }

.gcs-rwf-cred-row{
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 10px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid #eee;
}

.gcs-rwf-cred-label{ font-size: 12px; color: #333; }
.gcs-rwf-cred-value{
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .2px;
  word-break: break-word;
}

.gcs-rwf-copy{
  padding: 12px 12px;
  border: 0;
  border-radius: 12px;
  background: #111;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}

.gcs-rwf-copy-hint{
  margin-top: 10px;
  font-size: 13px;
  color: #0a7a2f;
  min-height: 18px;
  opacity: 0;
  transition: opacity .2s ease;
}
.gcs-rwf-copy-hint.is-on{ opacity: 1; }

@media (min-width: 520px){
  .gcs-rwf-cred-row{
    grid-template-columns: 140px 1fr auto;
    align-items: center;
  }
  .gcs-rwf-cred-label{ margin: 0; }
}

/* ===========================================
   ⭐ RATING STARS — premium (outline -> fill)
   =========================================== */

.rwf-rating{
  border: 0;
  padding: 0;
  margin: 0 0 14px;
}

.rwf-rating__label{
  font-size: 13px;
  font-weight: 700;
  color:#333;
  margin: 0 0 8px;
  padding: 0;
}

.rwf-rating__stars{
  display: inline-flex;
  flex-direction: row-reverse;
  gap: 8px;
  align-items: center;
}

.rwf-rating__input{
  position: absolute;
  left: -9999px;
  opacity: 0;
}

.rwf-rating__star .rwf-star{
  width: 28px;
  height: 28px;
  display:block;
  fill: transparent;
  stroke: rgba(17,17,17,.35);
  stroke-width: 1.6;
  transition: transform .12s ease, fill .12s ease, stroke .12s ease;
  cursor: pointer;
}

.rwf-rating__star:hover .rwf-star,
.rwf-rating__star:hover ~ .rwf-rating__star .rwf-star{
  fill: rgba(245,158,11,.95);
  stroke: rgba(245,158,11,.95);
  transform: translateY(-1px);
}

.rwf-rating__input:checked + .rwf-rating__star .rwf-star,
.rwf-rating__input:checked + .rwf-rating__star ~ .rwf-rating__star .rwf-star{
  fill: rgba(245,158,11,.95);
  stroke: rgba(245,158,11,.95);
}

.rwf-rating__input:focus-visible + .rwf-rating__star .rwf-star{
  transform: scale(1.05);
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.12));
}

.rwf-rating__hint{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(17,17,17,.55);
}


