/* home_avatar.css — Selector de avatar tipo Netflix para index.php
   Reutiliza .overlay (ya definido en home_shared.css) para el backdrop y
   focus trap visual. La tarjeta y el grid son específicos del avatar picker. */

/* La pill del usuario en index.php es un stack vertical:
   avatar grande arriba + email (y info de pago) centrados debajo.
   Override específico de `.userpill` (definido en home_shared.css) cuando
   es-clickable, para no afectar otras páginas que reusen la pill. */
.userpill.is-clickable{
  cursor:pointer;
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border:0;
  background:transparent;
  backdrop-filter:none;
  border-radius:12px;
  transition:transform .15s ease;
}
.userpill.is-clickable:hover{
  transform:translateY(-1px);
}
.userpill.is-clickable:hover .avatar{
  box-shadow:0 8px 24px rgba(15,23,42,.20);
  border-color:rgba(37,99,235,.45);
}
.userpill.is-clickable:focus-visible{
  outline:2px solid var(--accent, #2563EB);
  outline-offset:4px;
}

/* Avatar grande sobre el correo. El SVG ya viene clip-path circular interno;
   el border/box-shadow le da el "ring" que invita al click. */
.userpill.is-clickable .avatar{
  width:64px;height:64px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.85);
  box-shadow:0 4px 12px rgba(15,23,42,.12);
  transition:box-shadow .15s ease, border-color .15s ease;
}
.avatar.is-svg{
  background:transparent;
  object-fit:cover;
}

/* La info bajo el avatar se centra horizontalmente, pero su tamaño y
   max-width siguen siendo los de home_shared.css — discreta a propósito. */
.userpill.is-clickable .uinfo{
  align-items:center;
  text-align:center;
}
.userpill.is-clickable .uname{
  text-align:center;
}
.userpill.is-clickable .payHint,
.userpill.is-clickable .payReminder{
  justify-content:center;
}

/* Mobile: solo ajusta el avatar; el correo conserva su tamaño y ancho
   originales (font-size:9px, max-width:140px en home_shared.css). */
@media (max-width:768px){
  .userpill.is-clickable .avatar{
    width:48px;height:48px;border-width:2px;
  }
  .userpill.is-clickable{gap:4px;padding:2px 4px}
}

/* === Modal selector === */
.avatarOverlay{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(15,23,42,.70);
  backdrop-filter:blur(6px);
  padding:20px;
  animation:avFade .18s ease-out;
}
@keyframes avFade{from{opacity:0}to{opacity:1}}

.avatarCard{
  background:#fff;
  border-radius:16px;
  width:min(720px, 100%);
  max-height:min(90vh, 720px);
  overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 30px 60px rgba(0,0,0,.40);
  animation:avPop .22s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes avPop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}

.avatarHead{
  padding:18px 22px 12px;
  border-bottom:1px solid rgba(15,23,42,.06);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.avatarTitle{
  margin:0;font-size:18px;font-weight:700;color:#0f172a;
  letter-spacing:-.01em;
}
.avatarSub{
  margin:2px 0 0;font-size:12px;color:#64748b;
}
.avatarClose{
  background:none;border:0;padding:6px;
  font-size:26px;line-height:1;cursor:pointer;color:#64748b;
  border-radius:8px;
}
.avatarClose:hover{background:rgba(15,23,42,.05);color:#0f172a}

.avatarBody{
  padding:18px 22px;overflow-y:auto;flex:1;
}

.avatarGrid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(120px, 1fr));
  gap:14px;
}

.avatarTile{
  position:relative;
  background:none;border:0;padding:0;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  border-radius:12px;
  transition:transform .15s ease;
}
.avatarTile:hover{transform:scale(1.05)}
.avatarTile:focus-visible{outline:2px solid #2563EB;outline-offset:4px}

.avatarTileImgWrap{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  border-radius:14px;
  overflow:hidden;
  border:3px solid transparent;
  transition:border-color .15s ease, box-shadow .15s ease;
  background:#f1f5f9;
}
.avatarTile:hover .avatarTileImgWrap{
  border-color:rgba(37,99,235,.40);
  box-shadow:0 6px 18px rgba(15,23,42,.18);
}
.avatarTile.is-selected .avatarTileImgWrap{
  border-color:#2563EB;
  box-shadow:0 0 0 3px rgba(37,99,235,.18);
}
.avatarTile.is-saving{opacity:.7;pointer-events:none}

.avatarTileImg{
  width:100%;height:100%;display:block;object-fit:cover;
}

/* Badge de seleccionado */
.avatarTileCheck{
  position:absolute;top:6px;right:6px;
  width:22px;height:22px;border-radius:50%;
  background:#2563EB;color:#fff;
  display:none;align-items:center;justify-content:center;
  font-size:13px;font-weight:bold;
  box-shadow:0 2px 6px rgba(37,99,235,.40);
}
.avatarTile.is-selected .avatarTileCheck{display:flex}

.avatarTileLabel{
  font-size:12px;font-weight:600;color:#0f172a;
  text-align:center;line-height:1.2;
  max-width:100%;
  overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;
}
.avatarTileHint{
  font-size:10px;color:#64748b;text-align:center;line-height:1.1;
  max-width:100%;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.avatarErr{
  margin:10px 22px 14px;color:#b91c1c;font-size:12px;
  display:none;
}
.avatarErr.is-visible{display:block}

@media (max-width:480px){
  .avatarGrid{grid-template-columns:repeat(auto-fill, minmax(90px, 1fr));gap:10px}
  .avatarTileLabel{font-size:11px}
  .avatarTileHint{display:none}
}
