/* ============================================
   Estilos del INDICE PUBLICO DE ARTISTAS
   artistas.php — clases .ap-
   ============================================ */

.ap-titulo{
  font-family:var(--display);
  font-size:clamp(28px,4vw,42px);
  letter-spacing:.02em;
  line-height:1;
  margin-bottom:8px;
}
.ap-intro{
  font-size:14px;
  color:var(--muted);
  max-width:600px;
  line-height:1.55;
}

/* Buscador de artistas */
.ap-search{
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 18px;
  max-width:360px;
  margin-top:18px;
}
.ap-search input{
  background:transparent;
  border:0;
  outline:none;
  color:var(--text);
  font-family:var(--sans);
  font-size:14px;
  width:100%;
}
.ap-search input::placeholder{color:var(--muted)}

/* Grid de circulos */
.ap-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fill, minmax(110px, 1fr)) !important;
  gap:20px 16px !important;
  margin-top:28px;
}

/* Tarjeta circulo */
.ap-card{
  display:flex !important;
  flex-direction:column;
  align-items:center;
  text-align:center;
  text-decoration:none;
  color:var(--text);
  gap:10px;
  padding:4px;
  border-radius:16px;
  transition:transform .18s;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}
.ap-card:hover{
  transform:translateY(-3px);
}
.ap-card:hover .ap-foto{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(255,45,111,.25);
}

/* Circulo de la foto */
.ap-card .ap-foto{
  width:90px !important;
  height:90px !important;
  aspect-ratio:1/1 !important;
  border-radius:50% !important;
  overflow:hidden;
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  border:2px solid var(--line) !important;
  transition:border-color .18s, box-shadow .18s;
  flex-shrink:0;
  position:relative;
}
.ap-card .ap-foto img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block;
  border-radius:50% !important;
}
.ap-foto-fb{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);
  font-size:32px;
  color:#fff;
  text-transform:uppercase;
}

.ap-info{
  padding:0 !important;
  width:100%;
}
.ap-nombre{
  font-size:12.5px;
  font-weight:700;
  line-height:1.2;
  margin-bottom:3px;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:110px;
  display:block;
  margin-left:auto;
  margin-right:auto;
}
.ap-meta{
  font-size:11px;
  color:var(--muted);
  line-height:1.3;
}

/* Sin resultados de busqueda */
.ap-sin-resultados{
  text-align:center;
  padding:40px;
  color:var(--muted);
  font-size:14px;
  display:none;
}

/* Responsive */
@media(max-width:600px){
  .ap-grid{
    grid-template-columns:repeat(auto-fill, minmax(80px, 1fr)) !important;
    gap:16px 10px !important;
  }
  .ap-card .ap-foto{
    width:72px !important;
    height:72px !important;
  }
  .ap-nombre{max-width:80px}
}
@media(min-width:1280px){
  .ap-grid{
    grid-template-columns:repeat(auto-fill, minmax(120px, 1fr)) !important;
  }
  .ap-card .ap-foto{
    width:100px !important;
    height:100px !important;
  }
}