/* ============================================================
   ACCOUNT — Avatar upload drag & drop
   ============================================================ */

/* ── Zona drop ─────────────────────────────────────────────── */

.avatar-upload-zone {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  margin: 0 auto;
  cursor: pointer;
  overflow: hidden;
  outline: 3px solid transparent;
  outline-offset: 3px;
  transition: outline-color 0.2s ease, transform 0.2s ease;
}

.avatar-upload-zone:hover,
.avatar-upload-zone:focus-within {
  outline-color: var(--accent, #185FA5);
  transform: scale(1.03);
}

.avatar-upload-zone.drag-over {
  outline-color: var(--accent, #185FA5);
  outline-style: dashed;
  transform: scale(1.06);
}

/* ── Display — foto o iniziali ─────────────────────────────── */

.avatar-display {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  font-weight: 600;
  font-family: 'Outfit', sans-serif;
  letter-spacing: 1px;
  background: var(--accent-light, #E6F1FB);
  color: var(--accent, #185FA5);
  overflow: hidden;
  user-select: none;
}

.avatar-display .avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

/* ── Overlay al hover ──────────────────────────────────────── */

.avatar-overlay {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-size: 11px;
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
}

.avatar-overlay i {
  font-size: 18px;
}

.avatar-upload-zone:hover .avatar-overlay,
.avatar-upload-zone.drag-over .avatar-overlay {
  opacity: 1;
}

/* ── Input file nascosto ───────────────────────────────────── */

.avatar-file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  width: 100%;
  height: 100%;

  /*
   * pointer-events: none — ESSENZIALE su mobile.
   *
   * L'input copre tutta la zona con opacity:0.
   * Senza questo, il tap arriva PRIMA all'input (apre il picker)
   * poi in bubbling alla zona (che chiama input.click() → 2° picker).
   *
   * Con none i tap passano attraverso l'input alla zona,
   * il click listener chiama input.click() una sola volta.
   * Il drag&drop non è influenzato: quegli eventi sono
   * registrati sulla zona, non sull'input.
   */
  pointer-events: none;
}
